单片机论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1145|回复: 4
收起左侧

NRF24L01无线温度监控系统 带上位机

[复制链接]
51黑电子迷 发表于 2017-8-2 17:21 | 显示全部楼层 |阅读模式
NRF24L01无线温度监控的上位机界面:
0.png 0.png

NRF24L01无线测温源程序:
  1. #include <reg52.h>
  2. #include <intrins.h>

  3. typedef unsigned char uchar;
  4. typedef unsigned char uint;

  5. //****************************************NRF24L01端口定义***************************************
  6. sbit         MISO        =P1^3;
  7. sbit         MOSI        =P1^4;
  8. sbit        SCK            =P1^2;
  9. sbit        CE            =P1^1;
  10. sbit        CSN                =P3^2;
  11. sbit        IRQ                =P3^3;
  12. //************************************按键***************************************************
  13. sbit        KEY1=P3^6;
  14. sbit        KEY2=P3^7;
  15. //************************************数码管位选*********************************************
  16. sbit        led3=P2^0;
  17. sbit        led2=P2^1;
  18. sbit        led1=P2^2;
  19. sbit        led0=P2^3;
  20. //************************************蜂明器***************************************************
  21. sbit         BELL=P3^4;
  22. //*****************************************DS1820端口设置****************************************
  23. sbit      DQ=P3^5          ;
  24. //***********************************数码管0-9编码***********************************************
  25. uchar seg[10]={0xC0,0xCF,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};          //0~~9段码
  26. uchar seg1[10]={0x40,0x4F,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};
  27. uchar data temp_data[2]={0x00,0x00};                                                                                //温度采集数据缓冲区
  28. uchar dispaly[7];                                                                                                                        //显示缓冲区
  29. //******************************************************************************************
  30. uint         bdata sta;                                   //NRF24L01状态标志
  31. sbit        RX_DR        =sta^6;                                
  32. sbit        TX_DS        =sta^5;
  33. sbit        MAX_RT        =sta^4;
  34. //*************************************NRF24L01**************************************************

  35. #define TX_ADR_WIDTH    5           // 本机地址宽度设置
  36. #define RX_ADR_WIDTH    5           // 接收方地址宽度设置

  37. #define TX_PLOAD_WIDTH  20                 // 4 字节数据长度
  38. #define RX_PLOAD_WIDTH  20                // 4 字节数据长度

  39. uint const TX_ADDRESS[TX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01};        //本地地址
  40. uint const RX_ADDRESS[RX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01};        //接收地址
  41. //*****************************NRF24L01寄存器指令,详细请对照,Page18******************************

  42. #define READ_REG        0x00          // 读寄存器指令
  43. #define WRITE_REG       0x20         // 写寄存器指令
  44. #define RD_RX_PLOAD     0x61          // 读取接收数据指令
  45. #define WR_TX_PLOAD     0xA0          // 写待发数据指令
  46. #define FLUSH_TX        0xE1         // 冲洗发送 FIFO指令
  47. #define FLUSH_RX        0xE2          // 冲洗接收 FIFO指令
  48. #define REUSE_TX_PL     0xE3          // 定义重复装载数据指令
  49. #define NOP             0xFF          // 保留
  50. //****************************SPI(nRF24L01)寄存器地址,详细请对照,Page18-24**********************

  51. #define CONFIG          0x00   // 配置收发状态,CRC校验模式以及收发状态响应方式
  52. #define EN_AA           0x01   // 自动应答功能设置
  53. #define EN_RXADDR       0x02   // 可用信道设置
  54. #define SETUP_AW        0x03   // 收发地址宽度设置
  55. #define SETUP_RETR      0x04   // 自动重发功能设置
  56. #define RF_CH           0x05   // 工作频率设置
  57. #define RF_SETUP        0x06   // 发射速率、功耗功能设置
  58. #define STATUS          0x07   // 状态寄存器
  59. #define OBSERVE_TX      0x08   // 发送监测功能
  60. #define CD              0x09   // 地址检测           
  61. #define RX_ADDR_P0      0x0A   // 频道0接收数据地址
  62. #define RX_ADDR_P1      0x0B   // 频道1接收数据地址
  63. #define RX_ADDR_P2      0x0C   // 频道2接收数据地址
  64. #define RX_ADDR_P3      0x0D   // 频道3接收数据地址
  65. #define RX_ADDR_P4      0x0E   // 频道4接收数据地址
  66. #define RX_ADDR_P5      0x0F   // 频道5接收数据地址
  67. #define TX_ADDR         0x10   // 发送地址寄存器
  68. #define RX_PW_P0        0x11   // 接收频道0接收数据长度
  69. #define RX_PW_P1        0x12   // 接收频道0接收数据长度
  70. #define RX_PW_P2        0x13   // 接收频道0接收数据长度
  71. #define RX_PW_P3        0x14   // 接收频道0接收数据长度
  72. #define RX_PW_P4        0x15   // 接收频道0接收数据长度
  73. #define RX_PW_P5        0x16   // 接收频道0接收数据长度
  74. #define FIFO_STATUS     0x17   // FIFO栈入栈出状态寄存器设置
  75. //************************************NRF24L01函数申明**********************************************

  76. void Delay(unsigned int s);
  77. void inerDelay_us(unsigned char n);
  78. void init_NRF24L01(void);
  79. uint SPI_RW(uint uchar);
  80. uchar SPI_Read(uchar reg);
  81. void SetRX_Mode(void);
  82. uint SPI_RW_Reg(uchar reg, uchar value);
  83. uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars);
  84. uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars);
  85. unsigned char nRF24L01_RxPacket(unsigned char* rx_buf);
  86. void nRF24L01_TxPacket(unsigned char * tx_buf);
  87. //************************************DS18B20函数申明**********************************************

  88. void delay1(uint i);
  89. void ds_reset(void);
  90. void write_byte(uchar value);
  91. uchar read_byte(void);
  92. void read_temp();
  93. void work_temp();
  94. //*****************************************长延时*****************************************
  95. void Delay(unsigned int s)
  96. {
  97.         unsigned int i;
  98.         for(i=0; i<s; i++);
  99.         for(i=0; i<s; i++);
  100. }

  101. /******************************************************************************************
  102. /*延时函数
  103. /******************************************************************************************/
  104. void inerDelay_us(unsigned char n)
  105. {
  106.         for(;n>0;n--)
  107.                 _nop_();
  108. }
  109. //****************************************************************************************
  110. /*NRF24L01初始化
  111. //***************************************************************************************/
  112. void init_NRF24L01(void)
  113. {
  114.     inerDelay_us(100);
  115.          CE=0;    // chip enable
  116.          CSN=1;   // Spi disable
  117.          SCK=0;   // Spi clock line init high
  118.         SPI_Write_Buf(WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH);    // 写本地地址        
  119.         SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, RX_ADDRESS, RX_ADR_WIDTH); // 写接收端地址
  120.         SPI_RW_Reg(WRITE_REG + EN_AA, 0x01);      //  频道0自动        ACK应答允许        
  121.         SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01);  //  允许接收地址只有频道0,如果需要多频道可以参考Page21  
  122.         SPI_RW_Reg(WRITE_REG + RF_CH, 0);        //   设置信道工作为2.4GHZ,收发必须一致
  123.         SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH); //设置接收数据长度,本次设置为4字节
  124.         SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07);                   //设置发射速率为1Mkbps,发射功率为最大值0dB
  125. }
  126. /****************************************************************************************************
  127. /*函数:uint SPI_RW(uint uchar)
  128. /*功能:NRF24L01的SPI写时序,详细看时序图,Page19
  129. /****************************************************************************************************/
  130. uint SPI_RW(uint uchar)
  131. {
  132.         uint bit_ctr;
  133.            for(bit_ctr=0;bit_ctr<8;bit_ctr++) // output 8-bit
  134.            {
  135.                 MOSI = (uchar & 0x80);         // output 'uchar', MSB to MOSI
  136.                 uchar = (uchar << 1);           // shift next bit into MSB..
  137.                 SCK = 1;                      // Set SCK high..
  138.                 uchar |= MISO;                         // capture current MISO bit
  139.                 SCK = 0;                              // ..then set SCK low again
  140.            }
  141.     return(uchar);                             // return read uchar
  142. }
  143. /****************************************************************************************************
  144. /*函数:uchar SPI_Read(uchar reg)
  145. /*功能:NRF24L01的SPI时序,详细看时序图,Page19
  146. /****************************************************************************************************/
  147. uchar SPI_Read(uchar reg)
  148. {
  149.         uchar reg_val;
  150.         
  151.         CSN = 0;                // CSN low, initialize SPI communication...
  152.         SPI_RW(reg);            // Select register to read from..
  153.         reg_val = SPI_RW(0);    // ..then read registervalue
  154.         CSN = 1;                // CSN high, terminate SPI communication
  155.         
  156.         return(reg_val);        // return register value
  157. }
  158. /****************************************************************************************************/
  159. /*功能:NRF24L01读写寄存器函数,
  160. /****************************************************************************************************/
  161. uint SPI_RW_Reg(uchar reg, uchar value)
  162. {
  163.         uint status;
  164.         
  165.         CSN = 0;                   // CSN low, init SPI transaction
  166.         status = SPI_RW(reg);      // select register
  167.         SPI_RW(value);             // ..and write value to it..
  168.         CSN = 1;                   // CSN high again
  169.         
  170.         return(status);            // return nRF24L01 status uchar
  171. }
  172. /****************************************************************************************************/
  173. /*函数:uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)
  174. /*功能: 用于读数据,reg:为寄存器地址,pBuf:为待读出数据地址,uchars:读出数据的个数
  175. /****************************************************************************************************/
  176. uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)
  177. {
  178.         uint status,uchar_ctr;
  179.         
  180.         CSN = 0;                                    // Set CSN low, init SPI tranaction
  181.         status = SPI_RW(reg);                       // Select register to write to and read status uchar
  182.         
  183.         for(uchar_ctr=0;uchar_ctr<uchars;uchar_ctr++)
  184.                 pBuf[uchar_ctr] = SPI_RW(0);    //
  185.         
  186.         CSN = 1;                           
  187.         
  188.         return(status);                    // return nRF24L01 status uchar
  189. }
  190. /*********************************************************************************************************
  191. /*函数:uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)
  192. /*功能: 用于写数据:为寄存器地址,pBuf:为待写入数据地址,uchars:写入数据的个数
  193. /*********************************************************************************************************/
  194. uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)
  195. {
  196.         uint status,uchar_ctr;
  197.         
  198.         CSN = 0;            //SPI使能      
  199.         status = SPI_RW(reg);   
  200.         for(uchar_ctr=0; uchar_ctr<uchars; uchar_ctr++) //
  201.                 SPI_RW(*pBuf++);
  202.         CSN = 1;           //关闭SPI
  203.         return(status);    //
  204. }
  205. /*
  206. /****************************************************************************************************/
  207. /*函数:void SetRX_Mode(void)
  208. /*功能:数据接收配置
  209. /****************************************************************************************************
  210. void SetRX_Mode(void)
  211. {
  212.         CE=0;
  213.         SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f);                   // IRQ收发完成中断响应,16位CRC        ,主接收
  214.         CE = 1;
  215.         inerDelay_us(130);
  216. }
  217. /******************************************************************************************************
  218. /*函数:unsigned char nRF24L01_RxPacket(unsigned char* rx_buf)
  219. /*功能:数据读取后放如rx_buf接收缓冲区中
  220. /******************************************************************************************************
  221. unsigned char nRF24L01_RxPacket(unsigned char* rx_buf)
  222. {
  223.     unsigned char revale=0;
  224.         sta=SPI_Read(STATUS);        // 读取状态寄存其来判断数据接收状况
  225.         if(RX_DR)                                // 判断是否接收到数据
  226.         {
  227.             CE = 0;                         //SPI使能
  228.                 SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH);// read receive payload from RX_FIFO buffer
  229.                 revale =1;                        //读取数据完成标志
  230.         }
  231.         SPI_RW_Reg(WRITE_REG+STATUS,sta);   //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标志
  232.         return revale;
  233. }
  234. */
  235. /***********************************************************************************************************
  236. /*函数:void nRF24L01_TxPacket(unsigned char * tx_buf)
  237. /*功能:发送 tx_buf中数据
  238. /**********************************************************************************************************/
  239. void nRF24L01_TxPacket(unsigned char * tx_buf)
  240. {
  241.         CE=0;                        //StandBy I模式        
  242.         SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH); // 装载接收端地址
  243.         SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH);                          // 装载数据        
  244.         SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e);                    // IRQ收发完成中断响应,16位CRC,主发送
  245.         CE=1;                 //置高CE,激发数据发送
  246.         inerDelay_us(10);
  247. }
  248. /***********************************************************************************************************
  249. /*以下是DS18B20温度传感相关函数
  250. /**********************************************************************************************************/

  251. void delay1(uint i)
  252. {
  253.         for(;i>0;i--);   
  254. }
  255. //****************************************************DS1820复位函数***************************************
  256. void ds_reset(void)
  257. {
  258.         char temp=1;
  259.         while(temp)
  260. {
  261. while(temp)
  262. {
  263.     DQ=1;_nop_();_nop_();
  264.         DQ=0;
  265.         delay1(80);
  266.         DQ=1;
  267.         delay1(9);
  268.         temp=DQ;
  269.   }
  270.           delay1(64);
  271.          temp=~DQ;  
  272. }
  273. DQ=1;
  274. }
  275. //***********************************************DS1820写函数*********************************************
  276. void write_byte(uchar value)
  277. {
  278.         uchar i;
  279.         for(i=8;i>0;i--)
  280. {
  281.          DQ=1;_nop_();_nop_();
  282.           DQ=0;_nop_();_nop_();_nop_();_nop_();_nop_();
  283.          DQ=value&0x01;
  284.           delay1(9);
  285.     value>>=1;
  286. }
  287.         DQ=1;
  288.         delay1(1);
  289. }
  290. //****************************************************DS1820读函数*****************************************
  291. uchar read_byte(void)
  292. {
  293.         uchar i;
  294.         uchar value1=0;
  295. for(i=8;i>0;i--)
  296. {
  297.         DQ=1;_nop_();_nop_();
  298.         value1>>=1;
  299.         DQ=0;
  300.         _nop_();_nop_();_nop_();_nop_();
  301.         DQ=1;
  302.         _nop_();_nop_();_nop_();_nop_();
  303.         if(DQ)
  304.         value1|=0x80;
  305.          delay1(9);
  306. }
  307.         DQ=1;
  308.         return(value1);
  309. }
  310. //****************************************************读取温度**********************************************
  311. void read_temp()
  312. {
  313.         ds_reset();
  314.         write_byte(0xcc);
  315.         write_byte(0xbe);
  316.         temp_data[0]=read_byte();
  317.         temp_data[1]=read_byte();
  318.         ds_reset();
  319.         write_byte(0xcc);
  320.         write_byte(0x44);
  321. }
  322. //****************************************************温度处理*********************************************
  323. void work_temp()
  324. {
  325.         uchar n=0;
  326. if(temp_data[1]>127)
  327.         {
  328.         temp_data[1]=(256-temp_data[1]);                        //负值
  329.         temp_data[0]=(256-temp_data[0]);
  330.         n=1;
  331.         }
  332.         dispaly[6]=((temp_data[0]&0xf0)>>4)|((temp_data[1]&0x0f)<<4);
  333.         dispaly[5]=dispaly[6]/100;                                //百位
  334.         dispaly[4]=dispaly[6]%100;                                //
  335.         dispaly[2]=dispaly[4]/10;                                //十位
  336.         dispaly[1]=dispaly[4]%10;                                //个位        
  337.         switch        (temp_data[0]&0x0f)                                //小数位
  338.         {
  339.         case 0x0f:dispaly[0]=9;break;
  340.         case 0x0e:dispaly[0]=9;break;
  341.         case 0x0d:dispaly[0]=8;break;
  342.         case 0x0c:dispaly[0]=8;break;
  343.         case 0x0b:dispaly[0]=7;break;
  344.         case 0x0a:dispaly[0]=6;break;
  345.         case 0x09:dispaly[0]=6;break;
  346.         case 0x08:dispaly[0]=5;break;
  347.         case 0x07:dispaly[0]=4;break;
  348.         case 0x06:dispaly[0]=4;break;
  349.         case 0x05:dispaly[0]=3;break;
  350.         case 0x04:dispaly[0]=3;break;
  351.         case 0x03:dispaly[0]=2;break;
  352.         case 0x02:dispaly[0]=1;break;
  353.         case 0x01:dispaly[0]=1;break;
  354.         case 0x00:dispaly[0]=1;break;
  355.         default:break;
  356.         }
  357. if(n)                                                                                //负值时显示aa,正直显示dd
  358.         {
  359.         dispaly[3]=0x11;                                                //
  360.         }
  361. else         dispaly[3]=0x22;
  362. }
  363. //****************************************************温度显示****************************************************
  364. void disdignit()
  365. {
  366.                         P0=0xC6;
  367.                         led0=0;
  368.                         delay1(40);
  369.                         led0=1;
  370.                         P0=seg[dispaly[0]];
  371.                         led1=0;
  372.                         delay1(40);
  373.                         led1=1;
  374.                                 P0=seg1        [dispaly[1]];
  375.                                 led2=0;
  376.                         delay1(40);
  377.                         led2=1;
  378.                                 P0=seg[        dispaly[2]];
  379.                         led3=0;
  380.                                 delay1(40);
  381.                                 led3=1;
  382.                
  383. }
  384. //************************************主函数************************************************************
  385. void main(void)
  386. {
  387.         uchar i=0;
  388. //        uchar TxBuf[4]={0};                                  //4字节发送数据缓冲区
  389.     init_NRF24L01() ;                                 //NRF24L01初始化配置
  390.          ds_reset();
  391.          write_byte(0xcc);
  392.          write_byte(0x44);
  393.         Delay(6000);
  394.         while(1)
  395.         {
  396.         if(i==3)
  397.         {
  398.                 i=0;
  399.                 read_temp();
  400.                 work_temp();
  401.                 delay1(500);
  402.         }
  403.         i++;
  404.         disdignit();
  405.         nRF24L01_TxPacket(dispaly);        // Transmit Tx buffer data
  406.         SPI_RW_Reg(WRITE_REG+STATUS,0XFF);  
  407.         }
  408.         
  409. }
复制代码

全部资料下载地址:
http://www.51hei.com/bbs/dpj-91589-1.html



回复

使用道具 举报

fefen0 发表于 2017-8-3 18:09 | 显示全部楼层
谢谢分享!!!!!!
回复

使用道具 举报

持勤补拙 发表于 2017-8-4 18:22 | 显示全部楼层
正好需要这方面的资源
回复

使用道具 举报

typ123 发表于 2017-8-9 21:50 | 显示全部楼层
你好  请问你这上位机界面是用什么软件做的呀  
回复

使用道具 举报

lgc961104 发表于 2019-5-20 01:19 来自手机 | 显示全部楼层
上位机用什么做的?
回复

使用道具 举报

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

本版积分规则

QQ|手机版|小黑屋|单片机论坛 |51Hei单片机16群 联系QQ:125739409;技术交流QQ群7344883

Powered by 单片机教程网

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