找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2809|回复: 3
收起左侧

51单片机+温湿度DHT11+灰层颗粒传感器+nrf24l01源码

[复制链接]
ID:246275 发表于 2018-9-6 10:37 | 显示全部楼层 |阅读模式
51单片机+温湿度DHT11+灰层颗粒传感器+nrf24l01.

附件:
包含一个主机代码和从机代码,以及整个设计的结构框图。很容易看懂。

0.jpg

0.png
单片机源程序如下:
  1. #include <reg51.h>
  2. #include "Type.h"
  3. #include "LCD1602.h"  
  4. #include "intrins.h"
  5. #include "nrf2401.C"
  6. sbit dht=P0^1 ;
  7. uint8  U8FLAG,U8temp,flag;
  8. uint8  U8T_data_H,U8T_data_L,U8RH_data_H,U8RH_data_L,U8checkdata;
  9. uint8  U8T_data_H_temp,U8T_data_L_temp,U8RH_data_H_temp,U8RH_data_L_temp,U8checkdata_temp;
  10. uint8  U8comdata,U8pmdata;         
  11. uint8  pmdata[]={0},rece[]={0};   
  12. void  Delay_10us(void)
  13. {
  14.         uint8 i;
  15.         i--;
  16.         i--;
  17.         i--;
  18.         i--;
  19.         i--;
  20.         i--;
  21. }
  22. void Delay_100us(uint16 j)
  23. {      
  24.         uint8 i;
  25.     for(;j>0;j--)
  26.     {         
  27.                 for(i=0;i<27;i++);
  28.         }
  29. }
  30. void delay1s()   //误差 0us
  31. {
  32.     unsigned char a,b,c;
  33.     for(c=46;c>0;c--)
  34.     for(b=152;b>0;b--)
  35.     for(a=70;a>0;a--);
  36.     _nop_();  //if Keil,require use intrins.h
  37. }
  38. void InitUART(void)
  39. {
  40.     TMOD = 0x20;
  41.     SCON = 0x50;
  42.     TH1 = 0xFD;
  43.     TL1 = TH1;
  44.     PCON = 0x00;
  45.     EA = 1;
  46.     ES = 1;
  47.     TR1 = 1;
  48. }
  49. void SendOneByte(unsigned char c)
  50. {
  51.     SBUF = c;
  52.     while(!TI);
  53.     TI = 0;
  54. }
  55. void SendByte(unsigned char *p)
  56. {
  57.         while(*p!='\0')
  58.         {
  59.                 SBUF =*p;
  60.                 p++;
  61.                  while(!TI);
  62.             TI = 0;
  63.         }
  64.    
  65. }        
  66. void  COM(void)
  67. {
  68.         uint8 i;
  69.         for(i=0;i<8;i++)           
  70.         {
  71.                 U8FLAG=2;        
  72.                 while((!dht)&&U8FLAG++);
  73.                 Delay_10us();
  74.                 Delay_10us();
  75.                 Delay_10us();
  76.                 U8temp=0;
  77.                 if(dht)U8temp=1;
  78.                 U8FLAG=2;
  79.                 while((dht)&&U8FLAG++);
  80.                 //超时则跳出for循环                  
  81.                 if(U8FLAG==1)break;
  82.                 //判断数据位是0还是1         
  83.                 // 如果高电平高过预定0高电平值则数据位为 1
  84.                 U8comdata<<=1;
  85.                 U8comdata|=U8temp;        //0
  86.         }//rof
  87. }
  88.         //--------------------------------
  89.         //-----湿度读取子程序 ------------
  90.         //--------------------------------
  91.         //----以下变量均为全局变量--------
  92.         //----温度高8位== U8T_data_H------
  93.         //----温度低8位== U8T_data_L------
  94.         //----湿度高8位== U8RH_data_H-----
  95.         //----湿度低8位== U8RH_data_L-----
  96.         //----校验 8位 == U8checkdata-----
  97.         //----调用相关子程序如下----------
  98.         //---- Delay();, Delay_10us();,COM();
  99.         //--------------------------------

  100. void RH(void)                                 //温度检测子函数
  101. {
  102.         //主机拉低18ms
  103.         dht=0;
  104.         Delay_100us(180);
  105.         dht=1;
  106.         //总线由上拉电阻拉高 主机延时20us
  107.         Delay_10us();
  108.         Delay_10us();
  109.         Delay_10us();
  110.         Delay_10us();
  111.         //主机设为输入 判断从机响应信号
  112.         dht=1;
  113.         //判断从机是否有低电平响应信号 如不响应则跳出,响应则向下运行         
  114.         if(!dht)                 //T !         
  115.         {
  116.                 U8FLAG=2;
  117.                 //判断从机是否发出 80us 的低电平响应信号是否结束         
  118.                 while((!dht)&&U8FLAG++);
  119.                 U8FLAG=2;
  120.                 //判断从机是否发出 80us 的高电平,如发出则进入数据接收状态
  121.                 while((dht)&&U8FLAG++);
  122.                 //数据接收状态                 
  123.                 COM();
  124.                 U8RH_data_H_temp=U8comdata;
  125.                 COM();
  126.                 U8RH_data_L_temp=U8comdata;
  127.                 COM();
  128.                 U8T_data_H_temp=U8comdata;
  129.                 COM();
  130.                 U8T_data_L_temp=U8comdata;
  131.                 COM();
  132.                 U8checkdata_temp=U8comdata;
  133.                 dht=1;
  134.                 //数据校验
  135.                 U8temp=(U8T_data_H_temp+U8T_data_L_temp+U8RH_data_H_temp+U8RH_data_L_temp);
  136.                 if(U8temp==U8checkdata_temp)
  137.                 {
  138.                   U8RH_data_H=U8RH_data_H_temp;
  139.                   U8RH_data_L=U8RH_data_L_temp;
  140.                   U8T_data_H=U8T_data_H_temp;
  141.                   U8T_data_L=U8T_data_L_temp;
  142.                   U8checkdata=U8checkdata_temp;
  143.                 }//fi
  144.         }//fi
  145. }
  146. unsigned char FucCheckSum(uint8 *i,uint8 ln)  //PM2.5颗粒检测检验函数
  147. {
  148.         uint8 j,tempq=0;
  149.         i+=1;
  150.         for(j=0;j<(ln-2);j++)
  151.         {
  152.                 tempq+=*i;
  153.                 i++;
  154.         }
  155.         tempq=(~tempq)+1;
  156.         return(tempq);
  157. }
  158. void sendbuf()
  159. {        
  160.         RH();
  161.         U8pmdata=FucCheckSum(pmdata,9);
  162.         if(U8pmdata==pmdata[8])
  163.         {        
  164.                 SendOneByte(U8RH_data_H/10+'0');
  165.                 SendOneByte(U8RH_data_H%10+'0');
  166.                 SendOneByte(' ');
  167.                 SendOneByte(U8T_data_H/10+'0');
  168.                 SendOneByte(U8T_data_H%10+'0');
  169.                 SendOneByte(' ');
  170.                 SendOneByte(pmdata[3]/10+'0');
  171.                 SendOneByte(pmdata[3]%10+'0');
  172.                 SendOneByte('.');
  173.                 SendOneByte(pmdata[4]/10+'0');
  174.                 SendOneByte(pmdata[4]%10+'0');
  175.                 SendOneByte(' ');        
  176.                 SendOneByte(rece[0]/10+'0');
  177.                 SendOneByte(rece[0]%10+'0');
  178.                 SendOneByte(' ');
  179.                 SendOneByte(rece[1]/10+'0');
  180.                 SendOneByte(rece[1]%10+'0');
  181.                 SendOneByte(' ');
  182.                 SendOneByte(rece[2]/10+'0');
  183.                 SendOneByte(rece[2]%10+'0');
  184.                 SendOneByte('.');
  185.                 SendOneByte(rece[3]/10+'0');
  186.                 SendOneByte(rece[3]%10+'0');
  187.                 SendOneByte(' ');        
  188.         }
  189. }
  190. void main()
  191. {        
  192.         LCD_Initial();    //液晶初始化
  193.         init_io();                                
  194.         InitUART();             //串口初始化
  195.         while(1)
  196.         {        
  197.                 sta = SPI_Read(STATUS);          // 读状态寄存器
  198.             if(RX_DR)                                  // 判断是否接受到数据
  199.                 {                                               
  200.                         SPI_Read_Buf(RD_RX_PLOAD, RX_BUF, TX_PLOAD_WIDTH);  // 从RX FIFO读出数据
  201.                         flag=1;
  202.                 }
  203.                 SPI_RW_Reg(WRITE_REG + STATUS, sta);  // 清除RX_DS中断标志
  204.                 if(flag)                   // 接受  子系统1 完成
  205.                 {
  206.                         rece[0]=RX_BUF[0];
  207.                         rece[1]=RX_BUF[1];
  208.                         rece[2]=RX_BUF[2];
  209.                         rece[3]=RX_BUF[3];
  210.                         rece[4]=RX_BUF[4];
  211.                 }
  212.                 GotoXY(0,0);
  213.                 Print("T:");
  214.                 disp_uint(2,0,U8T_data_H);
  215.                 GotoXY(6,0);
  216.                 Print("RH:");
  217.                 disp_uint(9,0,U8RH_data_H);
  218. ……………………

  219. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
基于ZGBEE无线环境监测系统.zip (215.03 KB, 下载次数: 93)

评分

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

查看全部评分

回复

使用道具 举报

ID:371423 发表于 2018-9-8 10:16 | 显示全部楼层
需要了解无线模块的使用,下载学习了~
回复

使用道具 举报

ID:246275 发表于 2018-9-10 17:55 | 显示全部楼层
NPC-1024 发表于 2018-9-8 10:16
需要了解无线模块的使用,下载学习了~

可以的 使用模拟spi协议 nrf24l01

评分

参与人数 1黑币 +5 收起 理由
NPC-1024 + 5 嗯嗯,阿里嘎都~

查看全部评分

回复

使用道具 举报

ID:726750 发表于 2020-4-11 09:52 | 显示全部楼层
很棒,下载学习了
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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