找回密码
 立即注册

QQ登录

只需一步,快速开始

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

基于51单片机的水塔智能水位控制系统 主机+从机程序 nRF24L01无线传输

[复制链接]
跳转到指定楼层
楼主
ID:672336 发表于 2019-12-24 15:29 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
原理图


单片机源程序如下:
  1. #include<reg52.h>
  2. #include"global_define.h"
  3. #include"NRF24L01.h"  
  4. #include"Delay.h"

  5. sbit LED = P2^0 ;
  6. sbit DJ = P2^6 ;

  7. unsigned int baojingzhi = 200;//默认50cm
  8. unsigned char baojing[8];
  9. unsigned char ge,shi,bai;
  10. unsigned int shuiwei ;
  11. idata unsigned char TxDate[TX_DATA_WITDH]={0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,11,12};

  12. sbit bADcs=P2^5;
  13. sbit bADcl=P2^4;
  14. sbit bADda=P2^3;
  15. unsigned char data1;
  16. unsigned char flag_1s;
  17. long        Value;
  18. unsigned char Value_buff[8];
  19. /*------------------------------------------------
  20.                     定时器初始化子程序
  21. ------------------------------------------------*/
  22. void Init_Timer0(void)
  23. {
  24. TMOD |= 0x01;          //使用模式1,16位定时器,使用"|"符号可以在使用多个定时器时不受影响                     
  25. TH0=(65536-1000)/256;                  //重新赋值 1ms
  26. TL0=(65536-1000)%256;
  27. EA=1;            //总中断打开
  28. ET0=1;           //定时器中断打开
  29. TR0=1;           //定时器开关打开
  30. PT0=1;           //优先级打开
  31. }
  32. long ad()//采样烟雾传感器的信号函数
  33. {  
  34.      unsigned char i;
  35.      //data1=0;
  36.      bADcs = 0;//当ADC0832未工作时其CS输入端应为高电平,此时芯片禁用.
  37.          bADcl=0;
  38.          bADda=1;
  39.          bADcl=1;
  40.          bADcl=0;//i down
  41.          bADda=1;
  42.          bADcl=1;
  43.          bADcl=0;        //   2 down
  44.          bADda=0;
  45.          bADcl=1;
  46.          bADcl=0;        //   3 down
  47.          bADda=1;
  48.          bADcl=1;
  49.          bADcl=0;        //   4 down

  50.          for(i=8;i>0;i--)
  51.                  {
  52.                
  53.                  data1<<=1;
  54.                  bADcl=0;
  55.                 bADcl=1;
  56.                 if(bADda==1) data1|=0x01;
  57.                            bADda=1;
  58.                  }
  59.                  bADcs=1;
  60.                  
  61.        Value=data1*1.0/256*500;
  62.            
  63.           // Value=Value*K_MG_MV;
  64.           // Value=Value-5;
  65.            if(Value<0)Value=0;
  66.            return Value;
  67. }
  68. void DelayMs(uint time)
  69. {
  70.         uint i,j;
  71.         for(i=time;i>0;i--)
  72.                 for(j=112;j>0;j--);
  73. }


  74. void main()
  75. {
  76. //   unsigned char buff[8];
  77.    uint num=0 ;
  78.     unsigned int Value_1;   
  79.     DJ = 1;
  80.    Init_Timer0();
  81.    NRF24L01Int();     
  82.    RevTempDate[0] = '2';
  83.    RevTempDate[1] = '0';
  84.    RevTempDate[2] = '0';
  85.    while(1)
  86.     {         
  87.                  ad();
  88.                  Value_1 = Value;
  89.                  if(Value_1<baojingzhi)     //        当距离小于报警值时报警
  90.                    DJ = 0 ;  
  91.                  else
  92.                    DJ = 1;
  93.              NRFSetRXMode();//设置为接收模式
  94.                  Delay_x_ms(20);
  95.                  GetDate();   //开始接收数据
  96.                  Delay_x_ms(20);
  97.                  bai =         RevTempDate[0]-'0';                //提取百位
  98.                  shi =         RevTempDate[1]-'0';            //提取十位
  99.                  ge  =         RevTempDate[2]-'0';                //提取个位
  100.                   baojingzhi = bai*100+shi*10+ge;                //计算
  101.                
  102.         


  103.                    if(flag_1s==1)          //一秒发送一次水位值
  104.                    {
  105.                             flag_1s = 0;
  106.                          Value_buff[0]=Value/100+'0';
  107.                  Value_buff[1]=Value/10%10+'0';
  108.                  Value_buff[2]=Value%10+'0';
  109.                          Value_buff[3]=        '\0';
  110.                          NRFSetTxMode(Value_buff);  //发送
  111.                  while(CheckACK_RP());        //检测是否发送完毕,检测应答信号
  112.                      Delay_x_ms(200);        
  113.                    }




  114.          }
  115.                   

  116. //                else num = 0;  
  117.          
  118. }        
  119. /*------------------------------------------------
  120. ……………………

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

所有资料51hei提供下载:
新建文件夹.7z (237.84 KB, 下载次数: 112)
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏5 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:870533 发表于 2021-1-15 13:50 | 只看该作者
请问有原理图吗?
回复

使用道具 举报

板凳
ID:64696 发表于 2021-5-12 16:30 | 只看该作者
楼主 从新上传下代码、代码编译警告5、发送和接收代码、谢谢啦!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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