久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 1972|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

為什么我的Proteus仿真是可以顯示濕度的,但是真實(shí)焊起來(lái),顯示濕度一直是00,有時(shí)候是99

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:953926 發(fā)表于 2021-7-29 20:48 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
60黑幣
為什么我程序測(cè)試是可以正常顯示濕度的,用yl69土壤濕度傳感器,但是做到實(shí)物里面就失敗了,一直顯示的是00,換了ch0和ch1都是顯示00這是怎么回事。是我程序的問(wèn)題還是adc0832的芯片有問(wèn)題

  1. #include <reg52.h>                 //調(diào)用單片機(jī)頭文件
  2. #define uchar unsigned char  //無(wú)符號(hào)字符型 宏定義        變量范圍0~255
  3. #define uint  unsigned int         //無(wú)符號(hào)整型 宏定義        變量范圍0~65535

  4. #include <intrins.h>
  5. sbit deng=P2^1;                //加熱燈的定義口
  6. sbit SCL=P1^4;                //SCL定義為P1口的第位腳,連接ADC0832SCL腳
  7. sbit DO=P1^5;                //DO定義為P1口的第位腳,連接ADC0832DO腳
  8. sbit CS=P1^3;                //CS定義為P1口的第位腳,連接ADC0832CS腳
  9. sbit DQ=P2^0;              //定義DS18B20總線I/O
  10.    //IO口定義
  11. uint c=0;//溫度計(jì)算值

  12. uchar shidu;     //濕度等級(jí)
  13. uchar s_high = 70,s_low = 25;        //濕度報(bào)警參數(shù)
  14. uchar w_high = 40,w_low =10;     //溫度報(bào)警參數(shù)
  15. uchar wendu;      //溫度等級(jí)
  16. sbit dianji = P1^6;     //電機(jī)IO定義

  17. bit flag_300ms ;
  18. uchar key_can;                 //按鍵值的變量
  19. uchar menu_1;        //菜單設(shè)計(jì)的變量

  20. //這三個(gè)引腳參考資料
  21. sbit rs=P1^0;         //1602數(shù)據(jù)/命令選擇引腳 H:數(shù)據(jù)              L:命令
  22. sbit rw=P1^1;         //1602讀寫引腳                 H:數(shù)據(jù)寄存器          L:指令寄存器
  23. sbit e =P1^2;         //1602使能引腳          下降沿觸發(fā)


  24. /********************************************************************
  25. * 名稱 : delay_uint()
  26. * 功能 : 小延時(shí)。
  27. * 輸入 : 無(wú)
  28. * 輸出 : 無(wú)
  29. ***********************************************************************/
  30. void delay_uint(uint q)
  31. {
  32.         while(q--);
  33. }

  34. /********************************************************************
  35. * 名稱 : write_com(uchar com)
  36. * 功能 : 1602命令函數(shù)
  37. * 輸入 : 輸入的命令值
  38. * 輸出 : 無(wú)
  39. ***********************************************************************/
  40. void write_com(uchar com)
  41. {
  42.         e=0;
  43.         rs=0;
  44.         rw=0;
  45.         P0=com;
  46.         delay_uint(3);
  47.         e=1;
  48.         delay_uint(25);
  49.         e=0;
  50. }

  51. /********************************************************************
  52. * 名稱 : write_data(uchar dat)
  53. * 功能 : 1602寫數(shù)據(jù)函數(shù)
  54. * 輸入 : 需要寫入1602的數(shù)據(jù)
  55. * 輸出 : 無(wú)
  56. ***********************************************************************/
  57. void write_data(uchar dat)
  58. {
  59.         e=0;
  60.         rs=1;
  61.         rw=0;
  62.         P0=dat;
  63.         delay_uint(3);
  64.         e=1;
  65.         delay_uint(25);
  66.         e=0;        
  67. }

  68. /********************************************************************
  69. * 名稱 : write_sfm2(uchar hang,uchar add,uchar date)
  70. * 功能 : 顯示2位十進(jìn)制數(shù),如果要讓第一行,第五個(gè)字符開始顯示"23" ,調(diào)用該函數(shù)如下
  71.                   write_sfm1(1,5,23)
  72. * 輸入 : 行,列,需要輸入1602的數(shù)據(jù)
  73. * 輸出 : 無(wú)
  74. ***********************************************************************/
  75. void write_sfm2(uchar hang,uchar add,uint date)
  76. {
  77.         if(hang==1)   
  78.                 write_com(0x80+add);
  79.         else
  80.                 write_com(0x80+0x40+add);
  81.                 write_data(0x30+date/10%10);
  82.                 write_data(0x30+date%10);        
  83. }

  84. /********************************************************************
  85. * 名稱 : write_string(uchar hang,uchar add,uchar *p)
  86. * 功能 : 改變液晶中某位的值,如果要讓第一行,第五個(gè)字符開始顯示"ab cd ef" ,調(diào)用該函數(shù)如下
  87.                   write_string(1,5,"ab cd ef;")
  88. * 輸入 : 行,列,需要輸入1602的數(shù)據(jù)
  89. * 輸出 : 無(wú)
  90. ***********************************************************************/
  91. void write_string(uchar hang,uchar add,uchar *p)
  92. {
  93.         if(hang==1)   
  94.                 write_com(0x80+add);
  95.         else
  96.                 write_com(0x80+0x40+add);
  97.                 while(1)
  98.                 {
  99.                         if(*p == '\0')  break;
  100.                         write_data(*p);
  101.                         p++;
  102.                 }        
  103. }

  104. /********************************************************************
  105. * 名稱 : init_1602()
  106. * 功能 : 初始化1602液晶
  107. * 輸入 : 無(wú)
  108. * 輸出 : 無(wú)
  109. ***********************************************************************/
  110. void init_1602()
  111. {
  112.         write_com(0x38);
  113.         write_com(0x38);
  114.         write_com(0x0c);
  115.         write_com(0x06);
  116.         delay_uint(1000);
  117.         write_string(1,0," T:00 H:00 L:00 ");
  118.         write_string(2,0," W:00 H:00 L:00 ");
  119.         write_sfm2(1,8,s_high);        //顯示濕度上限
  120.         write_sfm2(1,13,s_low);                   //顯示濕度下限
  121.         write_sfm2(2,8,w_high);                   //顯示溫度上線
  122.         write_sfm2(2,13,w_low);                   //顯示溫度下線
  123. }


  124. /***********************1ms延時(shí)函數(shù)*****************************/
  125. void delay_1ms(uint q)
  126. {
  127.         uint i,j;
  128.         for(i=0;i<q;i++)
  129.                 for(j=0;j<120;j++);
  130. }

  131. /***********讀數(shù)模轉(zhuǎn)換數(shù)據(jù)********************************************************/        
  132. //請(qǐng)先了解ADC0832模數(shù)轉(zhuǎn)換的串行協(xié)議,再來(lái)讀本函數(shù),主要是對(duì)應(yīng)時(shí)序圖來(lái)理解,本函數(shù)是模擬0832的串行協(xié)議進(jìn)行的
  133.                                                 
  134. unsigned int Adc0832()
  135. {
  136.         uchar i=0;
  137.         uint dat=0;
  138.         uchar ndat=0;



  139.         CS=0;//拉低CS端
  140.         _nop_();
  141.         _nop_();
  142.          DO=1;
  143.         _nop_();
  144.         _nop_();

  145.         SCL=1;//拉高CLK端
  146.         _nop_();
  147.         _nop_();
  148.         SCL=0;//拉低CLK端,形成下降沿1
  149.         _nop_();
  150.         _nop_();
  151.         
  152.         SCL=1;//拉高CLK端
  153.         DO=1;
  154.         _nop_();
  155.         _nop_();
  156.         SCL=0;//拉低CLK端,形成下降沿2
  157.         _nop_();
  158.         _nop_();
  159.         SCL=1;//拉高CLK端
  160.         DO=1;
  161.         _nop_();
  162.         _nop_();
  163.         SCL=0;//拉低CLK端,形成下降沿3
  164.         DO=1;//控制命令結(jié)束
  165.         _nop_();
  166.         _nop_();
  167.         dat=0;
  168.         for(i = 0; i < 8; ++i)
  169.         {
  170.                 _nop_();
  171.                 _nop_();
  172.                 SCL =1;
  173.                 _nop_();
  174.                 _nop_();
  175.                 SCL =0;
  176.                 dat<<= 1;
  177.                 if(DO ==1)
  178.                         dat|= 0x01;
  179.         }
  180.         for(i = 0; i < 8; ++i)
  181.         {
  182.                 ndat >>= 1;
  183.                 if(DO ==1)
  184.                         ndat |= 0x80;
  185.                 _nop_();
  186.                 _nop_();
  187.                 SCL =1;
  188.                 _nop_();
  189.                 _nop_();
  190.                 SCL =0;
  191.         }


  192.         CS=1;//拉低CS端
  193.         SCL=0;//拉低CLK端
  194.         DO=1;//拉高數(shù)據(jù)端,回到初始狀態(tài)

  195.         return (dat==ndat) ? dat : 0;            //return ad data
  196. }



  197. /*************定時(shí)器0初始化程序***************/
  198. void time_init()         
  199. {
  200.     TH0=0x3c;
  201.         TL0=0xb0;
  202.         EA   = 1;                   //開總中斷
  203.         TMOD = 0X01;          //定時(shí)器0、定時(shí)器1工作方式1
  204.         ET0  = 1;                  //開定時(shí)器0中斷
  205.         TR0  = 1;                  //允許定時(shí)器0定時(shí)
  206. }


  207. /********************獨(dú)立按鍵程序*****************/
  208. uchar key_can;         //按鍵值

  209. void key()         //獨(dú)立按鍵程序
  210. {
  211.         static uchar key_new;
  212.         key_can = 20;                   //按鍵值還原
  213.         P3 |= 0xf0;
  214.         if((P3 & 0xf0) != 0xf0)                //按鍵按下
  215.         {
  216.                 delay_1ms(1);                     //按鍵消抖動(dòng)
  217.                 if(((P3 & 0xf0) != 0xf0) && (key_new == 1))
  218.                 {                                                //確認(rèn)是按鍵按下
  219.                         key_new = 0;
  220.                         switch(P3 & 0xf0)
  221.                         {
  222.                                 case 0xd0: key_can = 3; break;           //得到k2鍵值
  223.                                 case 0xb0: key_can = 2; break;           //得到k3鍵值
  224.                                 case 0x70: key_can = 1; break;           //得到k4鍵值
  225.                         }                                       
  226.                 }                        
  227.         }
  228.         else
  229.                 key_new = 1;        
  230. }

  231. /****************按鍵處理顯示函數(shù)***************/
  232. void key_with()
  233. {
  234.         if(key_can == 1)         //設(shè)置鍵
  235.         {
  236.                 menu_1 ++;
  237.                 if(menu_1 >= 5)
  238.                 {
  239.                         menu_1 = 0;
  240.                         init_1602() ;  //初始化顯示
  241.                 }
  242.         }
  243.         if(menu_1 == 1)                        //設(shè)置濕度上限
  244.         {
  245.                 if(key_can == 2)
  246.                 {
  247.                         s_high ++ ;                //濕度上限值加1
  248.                         if(s_high > 99)
  249.                                 s_high = 99;
  250.                 }
  251.                 if(key_can == 3)
  252.                 {
  253.                         s_high -- ;                //濕度上限值減1
  254.                         if(s_high <= s_low)
  255.                                 s_high = s_low + 1 ;
  256.                 }
  257.                 write_sfm2(1,8,s_high);        //顯示濕度上限
  258.                 write_sfm2(1,13,s_low);                   //顯示濕度下限
  259.                 write_com(0x80+8);           //將光標(biāo)移動(dòng)到第1行第到7位
  260.                 write_com(0x0f);                  //顯示光標(biāo)并且閃爍

  261.         }        
  262.         if(menu_1 == 2)                        //設(shè)置濕度下限
  263.         {
  264.                 if(key_can == 2)
  265.                 {
  266.                         s_low ++ ;          //濕度下限值加1
  267.                         if(s_low >= s_high)
  268.                                 s_low = s_high - 1;
  269.                 }
  270.                 if(key_can == 3)
  271.                 {
  272.                         s_low --;          //濕度下限值減1
  273.                         if(s_low <= 1)
  274.                                 s_low = 1;
  275.                 }
  276.                 write_sfm2(1,8,s_high);        //顯示濕度上限
  277.                 write_sfm2(1,13,s_low);                   //顯示濕度下限
  278.                 write_com(0x80+13);           //將光標(biāo)移動(dòng)到第1行第到7位
  279.                 write_com(0x0f);
  280.                 }                  //顯示光標(biāo)并且閃爍
  281.         if(menu_1 ==3)
  282.         {
  283.                 if(key_can == 2)
  284.                 {
  285.                         w_high ++ ;          //溫度上線限值加1
  286.                         if(w_high > 99)
  287.                                 w_high = 99;
  288.                 }
  289.                 if(key_can == 3)
  290.                 {
  291.                         w_high --;          //溫度上限值減1
  292.                         if(w_high <= 1)
  293.                                 w_high = 1;
  294.                 }
  295.             write_sfm2(2,8,w_high);        //顯示濕度上限
  296.                 write_sfm2(2,13,w_low);                   //顯示濕度下限
  297.                 write_com(0x80+0x40+8);           //將光標(biāo)移動(dòng)到第1行第到7位
  298.                 write_com(0x0f);                  //顯示光標(biāo)并且閃爍
  299.                 }
  300.         if(menu_1 ==4)
  301.         {
  302.                 if(key_can == 2)
  303.                 {
  304.                         w_low ++ ;          //溫度下限值加1
  305.                         if(w_low >= w_high)
  306.                                 w_low = w_high - 1;
  307.                 }
  308.                 if(key_can == 3)
  309.                 {
  310.                         w_low --;          //溫度下限值減1
  311.                         if(w_low <= 1)
  312.                                 w_low = 1;
  313.                 }
  314.                 write_sfm2(2,8,w_high);        //顯示溫度上限
  315.                 write_sfm2(2,13,w_low);                   //顯示溫度下限
  316.                 write_com(0x80+0x40+13);           //將光標(biāo)移動(dòng)
  317.                 write_com(0x0f);                  //顯示光標(biāo)并且閃爍        
  318. }             }

  319. /****************報(bào)警函數(shù)***************/
  320. void clock_h_l()
  321. {
  322.         static uchar value,value1;
  323.         if(shidu <= s_low)
  324.         {
  325.                 value ++;
  326.                 if(value >= 2)
  327.                 {
  328.                         value = 10;
  329.                                        
  330.                         dianji = 0;       //打開電機(jī)
  331.                 }
  332.         }   
  333.         
  334.         if(shidu >= s_high)
  335.         {
  336.                 value1 ++;
  337.                 if(value1 >= 2)
  338.                 {
  339.                         value1 = 10;
  340.                           
  341.                         dianji = 1;       //關(guān)機(jī)電機(jī)
  342.                 }
  343.         }else
  344.                 value1 = 0;
  345.         if((c/10)>=w_high)
  346.                 {
  347.                   
  348.                 }
  349.                 else if((c/10)<w_low)
  350.                 {
  351.                     
  352.                         deng=0;
  353.                
  354.                 }
  355.                 else if(deng==0)
  356.                 {  if((c/10)>((w_high+w_low)/2)) deng=1;}
  357.                 else
  358.                 {
  359.                         deng=1;               
  360.                 }
  361. }
  362. /*****延時(shí)子程序*****/
  363. void Delay_DS18B20(int num)
  364. {
  365.   while(num--) ;
  366. }
  367. void delay(uint xms)//延時(shí)函數(shù),有參函數(shù)
  368. {
  369.         uint x,y;
  370.         for(x=xms;x>0;x--)
  371.          for(y=110;y>0;y--);
  372. }
  373. /*****初始化DS18B20*****/
  374. void Init_DS18B20(void)
  375. {
  376.   unsigned char x=0;
  377.   DQ = 1;         //DQ復(fù)位
  378.   Delay_DS18B20(8);    //稍做延時(shí)
  379.   DQ = 0;         //單片機(jī)將DQ拉低
  380.   Delay_DS18B20(80);   //精確延時(shí),大于480us
  381.   DQ = 1;         //拉高總線
  382.   Delay_DS18B20(24);
  383.   x = DQ;           //稍做延時(shí)后,如果x=0則初始化成功,x=1則初始化失敗
  384.   Delay_DS18B20(30);
  385. }
  386. /*****讀一個(gè)字節(jié)*****/
  387. unsigned char ReadOneChar(void)
  388. {
  389.   unsigned char i=0;
  390.   unsigned char dat = 0;
  391.   for (i=8;i>0;i--)
  392.   {
  393.     DQ=1;
  394.     DQ = 0;     // 給脈沖信號(hào)
  395.     dat>>=1;
  396.     DQ = 1;     // 給脈沖信號(hào)
  397.     if(DQ)
  398.     dat|=0x80;
  399.     Delay_DS18B20(4);
  400.   }
  401.   return(dat);
  402. }
  403. /*****寫一個(gè)字節(jié)*****/
  404. void WriteOneChar(unsigned char dat)
  405. {
  406.   unsigned char i=0;
  407.   for (i=8; i>0; i--)
  408.   {
  409.     DQ = 0;
  410.     DQ = dat&0x01;
  411.     Delay_DS18B20(5);
  412.     DQ = 1;
  413.     dat>>=1;
  414.   }
  415. }
  416. /*****讀取溫度*****/
  417. unsigned int ReadTemperature(void)
  418. {
  419.   unsigned char a=0;
  420.   unsigned char b=0;
  421.   unsigned int t=0;
  422.   float tt=0;
  423.   Init_DS18B20();
  424.   WriteOneChar(0xCC);  //跳過(guò)讀序號(hào)列號(hào)的操作
  425.   WriteOneChar(0x44);  //啟動(dòng)溫度轉(zhuǎn)換
  426.   Init_DS18B20();
  427.   WriteOneChar(0xCC);  //跳過(guò)讀序號(hào)列號(hào)的操作
  428.   WriteOneChar(0xBE);  //讀取溫度寄存器
  429.   a=ReadOneChar();     //讀低8位
  430.   b=ReadOneChar();    //讀高8位
  431.   t=b;
  432.   t<<=8;
  433.   t=t|a;
  434.   tt=t*0.0625;
  435. // t= tt*10+0.5;     //放大10倍輸出并四舍五入
  436.   t= tt*10+0.5;
  437.   return(t);
  438. }

  439. /*****讀取溫度*****/
  440. void check_wendu(void)
  441. {
  442.         c=ReadTemperature()-5;                          //獲取溫度值并減去DS18B20的溫漂誤差
  443.         if(c>1200)
  444.         c=1200;
  445. }
  446. /****顯示溫度****/
  447. void display()
  448. {
  449.         if(menu_1==0)
  450.         {
  451.                 write_com(0x80+0x40+3);
  452.                
  453.                 write_data((c%1000)/100+0x30);
  454.                 write_data(((c%1000)%100)/10+0x30);
  455.                
  456.                 write_com(0x80+0x40+5);
  457.                 write_data(0xdf);
  458.                                        
  459.         }                                                                  
  460. }




  461. /***************主函數(shù)*****************/
  462. void main()
  463. {
  464.            //uint z;
  465.         init_1602();                           //1602液晶初始化
  466.         time_init();
  467.         Init_DS18B20();
  468.         dianji=1;
  469.         deng=1;                                //初始化定時(shí)器

  470.         while(1)
  471.         {
  472.                 key();                                        //獨(dú)立按鍵程序
  473.                 if(key_can < 10)
  474.                 {
  475.                         key_with();                        //按鍵按下要執(zhí)行的程序
  476.                 }
  477.            
  478.          
  479.                                 
  480.                 if(flag_300ms ==1)                  
  481.                 {
  482.                      flag_300ms =0 ;
  483.                          check_wendu();
  484.                         display();
  485.                         delay(1);
  486.                    clock_h_l();         //報(bào)警函數(shù)
  487.                    shidu = Adc0832();        //讀出濕度
  488.                shidu = 99 - shidu * 99 / 255;
  489.                         if(menu_1 == 0)
  490.                         {
  491.                                 write_sfm2(1,3,shidu);                   //顯示濕度等級(jí)
  492.                         }
  493.                         
  494.                  }
  495.                 delay_1ms(1);
  496.         }
  497. }

  498. /*************定時(shí)器0中斷服務(wù)程序***************/
  499. void time0_int() interrupt 1
  500. {        
  501.         static uchar value;
  502.         TH0 = 0x3c;
  503.         TL0 = 0xb0;     // 50ms
  504.         value ++;         
  505.         if(value % 6 == 0)
  506.         {
  507.                 flag_300ms = 1;           //300ms
  508.                 value = 0;
  509.         }
  510. }


復(fù)制代碼

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:642999 發(fā)表于 2021-8-3 22:44 | 只看該作者
既然在仿真上能實(shí)現(xiàn),說(shuō)明程序應(yīng)該沒(méi)問(wèn)題,所有可能出在電路或原件上
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产在线视频一区 | 日韩成人在线播放 | 狠狠躁躁夜夜躁波多野结依 | 久久亚洲综合 | 国产欧美一区二区三区另类精品 | 欧美日韩黄色一级片 | 九一在线 | 免费观看的黄色网址 | 国产精品黄 | 三级高清 | 国产美女黄色 | 欧美最猛黑人xxxx黑人 | 91中文视频 | 成人综合视频在线观看 | 美女日皮网站 | 欧美日本韩国一区二区三区 | 午夜看电影在线观看 | 黄色毛片在线播放 | 午夜免费网站 | 欧美日韩免费在线 | 四虎在线观看 | 色久五月| 中文字幕不卡在线88 | 欧美视频日韩 | 久久99网 | 久久久激情 | 成人做爰9片免费看网站 | 麻豆av在线免费观看 | 国产亚洲一区在线 | 国产精品一区在线观看 | 国产片一区二区三区 | 精产国产伦理一二三区 | 91麻豆精品国产91久久久久久久久 | 国产欧美久久精品 | 中文字幕视频在线观看 | 国产精品一区二区欧美黑人喷潮水 | 嫩草黄色影院 | 色婷婷亚洲一区二区三区 | a在线观看 | 精品久久久久久亚洲国产800 | 一区二区影视 |