找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机红外温度报警器 带24l01无线收发 课程设计报告 程序 原理图 pcb都有

[复制链接]
跳转到指定楼层
楼主

所有资料下载: 基于单片机无线收发装置的红外温度报警器.rar (15.5 MB, 下载次数: 102)





调整电路的设计
如图5所示为最基本的调整电路,图中1为输出,接单片机的P1.7,P1.6输入输出口。
图5 调整电路电路图
4.2.3 时钟电路的设计
XTAL1和XTAL2分别为反向放大器的输入和输出。该反向放大器可以配置为片内振荡器。石晶振荡和陶瓷振荡均可采用。如采用外部时钟源驱动器件,XTAL2应不接。
因为一个机器周期含有6个状态周期,而每个状态周期为2个振荡周期,所以一个机器周期共有12个振荡周期,如果外接石英晶体振荡器的振荡频率为12MHZ,一个振荡周期为1/12us,故而一个机器周期为1us。如图6所示为时钟电路。
图6 时钟电路图
4.2.4 复位电路的设计
复位方法一般有上电自动复位和外部按键手动复位,单片机在时钟电路工作以后, 在RESET端持续给出2个机器周期的高电平时就可以完成复位操作。例如使用晶振频率为12MHz时,则复位信号持续时间应不小于2us。该复位电路连接单片机的RESET引脚,如图7示为复位电路。
图7 复位电路图
4.2.5 数码管显示报警电路的设计
由1个数码管接上电阻后连上单片的P0输入输出口的引脚,外接VCC,当单片机的相应引脚被置低电平后,数码管显示相应的数字,起到报警作用。注:当P0口输出0F9f时,数码管WEI显示数字1,当P2口输出0x25时,数码管WEI1显示数字2。图8所示为数码管报警电路。
图8 数码管仿真图
4.2.6 声音报警电路的设计
如下图所示,用一个Speaker和三极管、电阻接到单片机的P2.0引脚上,构成声音报警电路,低电平触发,如图9示为声音报警电路。
图9 声音报警电路图
4.3 系统硬件电路的选择及说明
硬件电路的设计见附图1示,从以上的分析可知在本设计中要用到如下器件: AT89C51、热释电红外传感器、LED、发光二极管、蜂鸣器等一些单片机外围应用电路。
5、 软件程序的实现


下面是温度采集程序:
  1. #include
  2. #include

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

  5. //****************************************NRF24L01端口定义***************************************
  6. sbit CE  = P1^0;
  7. sbit CSN = P1^5;
  8. sbit SCK = P1^1;
  9. sbit MOSI = P1^4;
  10. sbit MISO = P1^2;
  11. sbit IRQ = P1^3;
  12. sbit LED = P3^2;
  13. sbit re = P2^7;
  14. //*****************************************DS1820端口设置****************************************
  15. sbit      DQ=P1^6;                                                                                                                //显示缓冲区
  16. //******************************************************************************************
  17. uint         bdata sta;                                   //NRF24L01状态标志
  18. sbit        RX_DR        =sta^6;                                
  19. sbit        TX_DS        =sta^5;
  20. sbit        MAX_RT        =sta^4;
  21. //*************************************NRF24L01**************************************************

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

  24. #define TX_PLOAD_WIDTH  20                 // 4 字节数据长度
  25. #define RX_PLOAD_WIDTH  20                // 4 字节数据长度

  26. uint const TX_ADDRESS[TX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01};        //本地地址
  27. uint const RX_ADDRESS[RX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01};        //接收地址
  28. uchar RX_BUF[RX_PLOAD_WIDTH];
  29. uchar TX_BUF[TX_PLOAD_WIDTH];
  30. //*****************************NRF24L01寄存器指令,详细请对照,Page18******************************

  31. #define READ_REG        0x00          // 读寄存器指令
  32. #define WRITE_REG       0x20         // 写寄存器指令
  33. #define RD_RX_PLOAD     0x61          // 读取接收数据指令
  34. #define WR_TX_PLOAD     0xA0          // 写待发数据指令
  35. #define FLUSH_TX        0xE1         // 冲洗发送 FIFO指令
  36. #define FLUSH_RX        0xE2          // 冲洗接收 FIFO指令
  37. #define REUSE_TX_PL     0xE3          // 定义重复装载数据指令
  38. #define NOP             0xFF          // 保留
  39. //****************************SPI(nRF24L01)寄存器地址,详细请对照,Page18-24**********************

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

  65. void Delay(unsigned int s);
  66. void inerDelay_us(unsigned char n);
  67. void init_NRF24L01(void);
  68. uint SPI_RW(uint uchar);
  69. uchar SPI_Read(uchar reg);
  70. //void SetRX_Mode(void);
  71. uint SPI_RW_Reg(uchar reg, uchar value);
  72. uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars);
  73. uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars);
  74. //unsigned char nRF24L01_RxPacket(unsigned char* rx_buf);
  75. void nRF24L01_TxPacket(unsigned char * tx_buf);

  76. //*****************************************长延时*****************************************
  77. void Delay(unsigned int s)
  78. {
  79.         unsigned int i;
  80.         for(i=0; i<s; i++);
  81.         for(i=0; i<s; i++);
  82. }

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

  230. uchar Check_ACK()
  231. {
  232. sta=SPI_Read(STATUS);                    // 读状态寄存器
  233. if(TX_DS||MAX_RT)
  234. {
  235.   SPI_RW_Reg(WRITE_REG + STATUS, 0xff);  //清除TX_DS或MAX_RT中断标志
  236.   CSN = 0;
  237.   SPI_RW(FLUSH_TX);        //清除TX_FIFO
  238.      CSN  = 1;         
  239.   return(0);
  240. }                          
  241.               
  242.     else
  243.         return(1);
  244. }
  245. uchar Temp_Value[]={0x00,0x00};
  246. //bit DS18B20_IS_OK = 1;
  247. uint temp=0;
  248. uchar Display_Digit[]={0,0,0,0,0};
  249. uchar code df_Table[]={0,1,1,2,3,3,4,4,5,6,6,7,8,8,9,9};
  250. sbit LCD_RS = P2^0;
  251. sbit LCD_RW = P2^1;
  252. sbit LCD_EN = P3^7;

  253. uchar  Temp_Disp_Title[]=       {"reshidian1:  "};        //1602 液晶第一行显示内容
  254. uchar Current_Temp_Display_Buffer[]={"TEMP1:      "};  //1602 液晶第二行显示内容

  255. void delay1ms(unsigned int ms)//延时1毫秒(不够精确的)
  256. {unsigned int i,j;
  257.    for(i=0;i<ms;i++)
  258.     for(j=0;j<100;j++);
  259. }

  260. bit LCD_Busy_Check()  //LCD 忙标志,返回值为 1602LCD 的忙标志位,为 1 表示忙
  261. {
  262.   bit result;
  263. LCD_RS = 0;
  264. LCD_RW = 1;
  265. LCD_EN = 1;
  266. delay1ms(1);
  267. result = (bit)(P0&0x80);
  268. LCD_EN=0;
  269. return result;
  270. }
  271. void Write_LCD_Command(uchar cmd)  //1602LCD 写指令函数
  272. {
  273. while(LCD_Busy_Check());
  274. LCD_RS = 0;
  275. LCD_RW = 0;
  276. LCD_EN = 0;
  277. _nop_();
  278. _nop_();
  279. P0 = cmd;
  280. delay1ms(1);
  281. LCD_EN = 1;
  282. delay1ms(1);
  283. LCD_EN = 0;
  284. }
  285. void Write_LCD_Data(uchar dat)  //1602LCD 写数据函数
  286. {
  287. while(LCD_Busy_Check());
  288. LCD_RS = 1;
  289. LCD_RW = 0;
  290. LCD_EN = 0;
  291. P0 = dat;
  292.   delay1ms(1);
  293. LCD_EN = 1;  
  294.   delay1ms(1);
  295. LCD_EN = 0;  
  296.   delay1ms(1);
  297. }
  298. void LCD_Initialise()   //1602LCD 初始化
  299. {
  300.   Write_LCD_Command(0x01);
  301. delay1ms(5);
  302. Write_LCD_Command(0x08);
  303. delay1ms(5);
  304. Write_LCD_Command(0x38);
  305. delay1ms(5);
  306. Write_LCD_Command(0x0c);
  307. delay1ms(5);
  308. Write_LCD_Command(0x06);
  309. delay1ms(5);  
  310. }
  311. void Set_LCD_POS(uchar pos)   //1602LCD 设置显示位置
  312. {
  313.   Write_LCD_Command(pos|0x80);  
  314. }
  315. void Delayl(uint x)   //延时 2
  316. {
  317.   while(x--);
  318. }
  319. uchar Init_DS18B20()  //初始化(或者说复位)DS18B20
  320. {
  321.   uchar status;
  322. DQ = 1;
  323. Delayl(8);
  324. DQ = 0;
  325. Delayl(90);
  326. DQ = 1;
  327. Delayl(8);
  328. status=DQ;Delayl(100);   
  329. DQ = 1;
  330. return status;
  331. }
  332. uchar ReadOneByte()    //从 DS18B20 读一字节数据
  333. {
  334.   uchar i,dat=0;
  335. DQ = 1;
  336. _nop_();
  337. for(i=0;i<8;i++)
  338. {
  339.    DQ = 0;
  340. dat >>= 1;
  341. DQ = 1;
  342. _nop_();
  343. _nop_();
  344. if(DQ)
  345. dat |= 0X80;
  346. Delayl(30);
  347. DQ = 1;
  348. }
  349. return dat;
  350. }
  351. void WriteOneByte(uchar dat)   //从 DS18B20 写一字节数据
  352. {
  353. uchar i;
  354. for(i=0;i<8;i++)
  355. {
  356. DQ = 0;
  357. DQ = dat& 0x01;
  358. Delayl(5);
  359. DQ = 1;
  360. dat >>= 1;
  361. }
  362. }

  363. void Read_Temperature()  //从 DS18B20 读取温度值
  364. {
  365.   
  366. Init_DS18B20();
  367. WriteOneByte(0xcc);  //跳过序列号命令
  368. WriteOneByte(0x44);  //启动温度转换命令
  369. Init_DS18B20();  //复位 DS18B20 (每一次读写之前都要对 DS18B20 进行复位操作)  
  370. WriteOneByte(0xcc);  //跳过序列号命令
  371. WriteOneByte(0xbe); //读取温度寄存器
  372. Temp_Value[0] = ReadOneByte(); //读取温度低 8 位(先读低字节,再读高字节, )
  373. Temp_Value[1] = ReadOneByte();//读取温度高 8 位  (每次只能读一个字节)  
  374. }
  375. void Display_Temperature()  //在 1602LCD 上显示当前温度
  376. {
  377.   uchar i;
  378. uchar t = 150, ng = 0;  //延时值与负数标志
  379. if((Temp_Value[1]&0xf8)==0xf8)  //高字节高 5 位如果全为 1, 则为负数, 为负数时取反                     
  380. {                            //加 1,并设置负数标志为 1
  381. Temp_Value[1] = ~Temp_Value[1];
  382. Temp_Value[0] = ~Temp_Value[0]+1;
  383. if(Temp_Value[0]==0x00)   //若低字节进位,则高字节加 1  
  384. Temp_Value[1]++;
  385. ng = 1; //设置负数标志为 1
  386. }  
  387. Display_Digit[0] = df_Table[Temp_Value[0]&0x0f];   //查表得到温度小数部分
  388.    //获取温度整数部分(低字节低 4 位清零,高 4 位右移 4 位)+(高字节高 5 位清零,   
  389.    //低三位左移 4 位)
  390. temp= ((Temp_Value[0]&0xf0)>>4) | ((Temp_Value[1]&0x07)<<4);
  391. //将温度整数部分分解为 3 位待显示数字
  392.    Display_Digit[3] = temp/100;
  393. Display_Digit[2] = temp%100/10;
  394. Display_Digit[1] = temp%10;
  395. Display_Digit[4] = ng;
  396.    //刷新 LCD 缓冲     //加字符 0 是为了将待数字转化为字符显示
  397. Current_Temp_Display_Buffer[11] = Display_Digit[0] + '0';  
  398. Current_Temp_Display_Buffer[10] = '.';
  399. Current_Temp_Display_Buffer[9]  = Display_Digit[1] + '0';
  400. Current_Temp_Display_Buffer[8]  = Display_Digit[2] + '0';
  401. Current_Temp_Display_Buffer[7]  = Display_Digit[3] + '0';
  402. if(Display_Digit[3] == 0)  //高位为 0 时不显示
  403. Current_Temp_Display_Buffer[7]  = ' ';
  404. if(Display_Digit[2] == 0&&Display_Digit[3]==0) //高位为 0, 且次高位为 0, 则次高位不显示
  405. Current_Temp_Display_Buffer[8]  = ' ';
  406. //负号显示在恰当位置
  407. if(Display_Digit[4]==1)
  408. Current_Temp_Display_Buffer[6]  = '-';
  409. else
  410. Current_Temp_Display_Buffer[6]  = ' ';


  411. if (re ==0)
  412.         {Temp_Disp_Title[14] = '0';  Delay(2000);        }            
  413. else
  414.     {        Temp_Disp_Title[14] = '1';         Delay(2000); }
  415. Set_LCD_POS(0x00);  //第一行显示标题
  416. for(i=0;i<16;i++)
  417. {
  418. Write_LCD_Data(Temp_Disp_Title[i]);  
  419. }
  420. Set_LCD_POS(0x40); //第二行显示当前温度
  421. for(i=0;i<16;i++)
  422. {
  423. Write_LCD_Data(Current_Temp_Display_Buffer[i]);  
  424. }
  425.   //显示温度符号
  426.   Set_LCD_POS(0x0d);   
  427. Write_LCD_Data(' ');
  428. Set_LCD_POS(0x0f);   
  429. Write_LCD_Data(' ');
  430. Set_LCD_POS(0x4c);   
  431. Write_LCD_Data(' ');
  432. Set_LCD_POS(0x4d);   
  433. Write_LCD_Data(0xdf);
  434. Set_LCD_POS(0x4e);
  435. Write_LCD_Data('C');
  436. Set_LCD_POS(0x4f);   
  437. Write_LCD_Data(' ');
  438. }
  439. void main()
  440. {
  441.    uchar i;
  442.         P0=0xff;
  443.         P1=0xff;
  444.         P2=0xff;
  445.         P3=0xff;
  446.    init_NRF24L01() ;                // 初始化IO
  447.    Read_Temperature();
  448.    LCD_Initialise();
  449.    Delay(6000);
  450. while(1)
  451. {
  452.      Read_Temperature();
  453.      Display_Temperature();
  454.      Delayl(500);
  455.             for(i=0;i<5;i++)
  456.           {
  457.                       TX_BUF[i]=Display_Digit[i];
  458.                       LED=~LED;
  459.               Delay(2000);
  460.                   }
  461.                   TX_BUF[5] = Temp_Disp_Title[14];
  462.       nRF24L01_TxPacket(TX_BUF);
  463.       Delay(1000);
  464.      while(Check_ACK());        //检测是否发送完毕      
  465. }
  466. }
复制代码

评分

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

查看全部评分

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

使用道具 举报

沙发
ID:150544 发表于 2016-11-27 15:36 | 只看该作者
谢谢分享,请问程序是直接可用的吗
回复

使用道具 举报

板凳
ID:150544 发表于 2016-11-27 15:54 | 只看该作者
请问仿真图还有吗
回复

使用道具 举报

地板
ID:350853 发表于 2018-7-2 09:13 | 只看该作者
电路图的报表清单有?
回复

使用道具 举报

5#
ID:186637 发表于 2018-10-16 16:45 | 只看该作者
谢谢分享!学习学习!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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