找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4947|回复: 2
打印 上一主题 下一主题
收起左侧

STM32+PT100热敏电阻测温nrf24L01无线通信程序

[复制链接]
跳转到指定楼层
楼主
ID:348691 发表于 2018-12-21 23:39 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
用于PT100的测量采集,并通过NRF通信。核心包括电压采集与数据转换与发送。

单片机源程序如下:
  1. #include "led.h"
  2. #include "delay.h"
  3. #include "key.h"
  4. #include "sys.h"
  5. #include "lcd.h"
  6. #include "usart.h"         
  7. #include "24l01.h"
  8. #include "adc.h"

  9. u8 s_zb[10]={0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39};
  10. u8 Cs_cl[14]={0xD6,0xD8,0xD0,0xC2,0xBF,0xAA,0xCA,0xBC,0xB2,0xE2,0xC1,0xBF,0x0D,0x0A};
  11. void Vccc(float dy);
  12. void Temc(float wd);
  13. void Ssdc(float sd);

  14. int main(void)
  15. {  int k=0;
  16.          u16 adcx;
  17.          float T,S,V;
  18.   u8 RX_Buf[4];           //只存4位
  19.   Adc_Init();
  20.    
  21.          
  22.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置中断优先级分组为组2:2位抢占优先级,2位响应优先级
  23.         delay_init();                     //延时函数初始化         
  24.         uart_init(115200);         //串口初始化为115200
  25.         LED_Init();
  26.         NRF24L01_Init();     //NRF24L01初始化
  27.         NRF24L01_RX_Mode();  //接受模式
  28.          
  29.         while(NRF24L01_Check())//检查NRF24L01
  30.          {
  31.                  printf ("NRF24L01 Error!!\n\r");
  32.                  delay_ms(200);
  33.          }
  34.          printf ("NRF24L01 OK!!\n\r");
  35.          
  36.   while(1)
  37.         {  
  38.                 if (k==1)
  39.                 {
  40.                         L1: NRF24L01_TX_Mode();
  41.                 NRF24L01_TxPacket(Cs_cl);
  42.                 NRF24L01_RX_Mode();  //接受模式
  43.                 }
  44.                 if(NRF24L01_RxPacket(RX_Buf)==RESET)//接收到数据
  45.                 {   
  46.                 // T=26.5;
  47.                         
  48.                         adcx=Get_Adc_Average(ADC_Channel_1,100);
  49.                   S=adcx; //四位数
  50.                         
  51.              V=(float)adcx*(3.3/4096);
  52.                   T=V*10;  //
  53.                         
  54. //                        V=adcx;
  55.                         
  56.                         LED0 =!LED0;
  57.                         switch(RX_Buf[1])//到时根据题目要求RX_Buf[1]&RX_Buf[2],RX_Buf[0]为字长
  58.                         {  
  59.                                 case 0x30:Ssdc(S);/*添加题目所需执行指令;*/break;
  60.                           case 0x31:Vccc(V);/*添加题目所需执行指令;*/break;
  61.                                 case 0x32: goto L1;
  62.                           default:Temc(T); break;
  63.                         }        
  64.                 }
  65.                
  66.         }         
  67. }

  68. void Temc(float wd)
  69. //void temc(void)
  70. {         //float wd=47.3;
  71.         
  72.            
  73.          int sw,gw,yw;
  74.         
  75.         //u8 s_zb[10]={0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39};
  76.         u8 T_buf[14]={0xCE,0xC2,0xB6,0xC8,0xCA,0xC7,0x20,0x20,0x2E,0x20,0xA1,0xE6,0x0D,0x0A};//温度是 **.* ℃
  77.         
  78.         sw=(int)(wd/10);  //十位
  79.         T_buf[6]=s_zb[sw];
  80.         
  81.         gw=(int)(wd-10*sw); // 个位
  82.         T_buf[7]=s_zb[gw];
  83.         
  84.         yw=(int)(wd*10-100*sw-10*gw); // 一位
  85.         T_buf[9]=s_zb[yw];
  86.         
  87. //        u8 i=0x0D,p=0x0A;
  88. //        tmp_buf[12]=i;
  89. //        tmp_buf[13]=p;  //外部赋值 可以改变
  90.         
  91.         //u8 tmp_buf[3]={0xC0,0xEE,0xC3};
  92.         NRF24L01_TX_Mode();
  93.         NRF24L01_TxPacket(T_buf);
  94.         NRF24L01_RX_Mode();  //接受模式
  95. }


  96. void Vccc(float dy)
  97. {
  98.         int gw,yw,ew;
  99.         
  100.         //u8 s_zb[10]={0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39};
  101.         u8 V_buf[13]={0xB5,0xE7,0xD1,0xB9,0xCA,0xC7,0x20,0x2E,0x20,0x20,0x56,0x0D,0x0A};//电压是*.**V
  102.         
  103.         gw=(int)dy;  //个位
  104.         V_buf[6]=s_zb[gw];
  105.         
  106.         yw=(int)(10*dy-10*gw); // 一位
  107.         V_buf[8]=s_zb[yw];
  108.         
  109.         ew=(int)(dy*100-100*gw-10*yw); // 二位
  110.         V_buf[9]=s_zb[ew];
  111.         
  112. //        u8 tmp_buf[5]={'2','3','5',0x0D,0x0A};
  113.         NRF24L01_TX_Mode();
  114.         NRF24L01_TxPacket(V_buf);
  115.         NRF24L01_RX_Mode();  //接受模式
  116. }        

  117. void Ssdc(float sd)
  118. //void temc(void)
  119. {         //float wd=47.3;
  120.         
  121.            
  122.          int qw,bw,sw,gw,yw;
  123.         
  124.         //u8 s_zb[10]={0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39};
  125.         
  126.         u8 SD_buf[18]={0xCA,0xAA,0xB6,0xC8,0xCA,0xC7,0x20,0x20,0x20,0x20,0x2E,0x20,0x25,0x52,0x48,0x0D,0x0A};//湿度是 **.* ℃
  127.         
  128.         qw=(int)(sd/1000);  //千位
  129.         SD_buf[6]=s_zb[qw];
  130.         
  131.         bw=(int)((sd-1000*qw)/100);  //百位
  132.         SD_buf[7]=s_zb[bw];
  133.         
  134.         sw=(int)((sd-1000*qw-100*bw)/10);  //十位
  135.         SD_buf[8]=s_zb[sw];
  136.         
  137.         gw=(int)(sd-1000*qw-100*bw-10*sw); // 个位
  138.         SD_buf[9]=s_zb[gw];
  139.         
  140.         yw=(int)((sd-1000*qw-100*bw-10*sw-gw)*10); // 一位
  141.         SD_buf[11]=s_zb[yw];
  142.         
  143. //        u8 i=0x0D,p=0x0A;
  144. //        tmp_buf[12]=i;
  145. //        tmp_buf[13]=p;  //外部赋值 可以改变
  146.         
  147.         //u8 tmp_buf[3]={0xC0,0xEE,0xC3};
  148.         NRF24L01_TX_Mode();
  149.         NRF24L01_TxPacket(SD_buf);
  150.         NRF24L01_RX_Mode();  //接受模式
  151. }
复制代码

所有资料51hei提供下载:
1_1采集发送_基本.7z (206.08 KB, 下载次数: 138)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏4 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:667303 发表于 2020-8-6 14:59 | 只看该作者
真的是好资料,学到了,感谢大佬分享
回复

使用道具 举报

板凳
ID:334781 发表于 2022-5-29 15:28 | 只看该作者
这个有原理图吗, 我觉得关键是电路图
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表