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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1838|回復: 2
收起左側

怎么修改LCD1602顯示程序,不要小數后面的

[復制鏈接]
ID:608872 發表于 2019-10-10 16:52 | 顯示全部樓層 |閱讀模式
51hei圖片_20191010165037.png
這么修改顯示+40℃呢,不要小數后面的。
我把uchar  cdis2[ ] = "+00.00";
修改成uchar  cdis2[ ] = "+00.";顯示還是不變

  1. #include < reg51.h >
  2. #include < intrins.h >

  3. #define uchar unsigned char
  4. #define uint   unsigned int

  5. //#define lcddata P0
  6. #define lcddata P2
  7. sbit LCDRS=P1^7;              //液晶數據選擇命令端
  8. sbit LCDRW=P1^6;             //液晶讀寫命令端
  9. sbit LCDEN=P1^5;            //液晶使能端
  10. //sbit LCDRS = P2^6 ;     // 命令/數據選擇端  0為寫命令 1為寫數據      
  11. //sbit LCDRW = P2^5 ;                // lcd讀寫端
  12. //sbit LCDEN = P2^7 ;                //lcd使能端
  13. void write_com(uchar com);
  14. void zdyzfxs();
  15. unsigned char code   mytab[8] = {0x10,0x06,0x09,0x08,0x08,0x09,0x06,0x00};//自定義 ℃字符
  16. //sbit DQ = P3^7 ;   //定義DS18B20端口DQ  
  17. sbit DQ = P1^0;   //定義DS18B20端口DQ
  18. bit presence;           //ds18b20 DQ被拉低 信號0允許,1禁止
  19. uint cc,cc2;       //變量cc中保存讀出的溫度值
  20. float cc1;
  21. uchar flag;                   //flag為溫度值正負標志位,“1”表示溫度為復制,“0”表示為正值//flag為溫度值正負標志位,“1”表示溫度為復制,“0”表示為正值
  22. void write_com(uchar com);

  23. uchar code cdis0[ ] = "CHECKING...";  //無字符類型0~255,定位在code區,因為定義的數據是常量,所以放在ROM(程序存儲區)里面,寫入后就不能再更改。放在RAM區也需要在ROM里占用同樣的大小
  24. uchar code cdis1[ ] = "   DS18B20 OK   " ;
  25. //uchar code cdis5[ ] = "Temp: ";
  26. uchar  cdis2[ ] = "+00.00";
  27. uchar code cdis3[ ] = " DS18B20   ERR0R " ;
  28. uchar code cdis4[ ] = "   PLEASE CHECK  " ;

  29. unsigned char data   temp_data[2] = {0x00,0x00} ;  //存儲16位溫度  有字符類型-128~127    data;內部數據存儲區     xdata;外部數據存儲區  code;程序存儲區

  30. /**********************************lcd1602********************************************/

  31. //--------------------------------- 延時程序
  32. void delaylcd(uint z)
  33. {uchar x,y;
  34. for(x=z;x>0;x--)
  35.   {for(y=110;y>0;y--);
  36.   }
  37. }

  38. /*lcd1602初始化        */
  39. /**********************************/
  40. void lcd_init(void)
  41. {
  42. LCDRW=0;                 //低電平為寫
  43. LCDEN=0;                 
  44. write_com(0x38);                 //使用8位數據開關,顯示兩行,使用5*7字形

  45. write_com(0x0c);                //顯示器開,光標關,字符不閃爍         0x0e 光標開

  46. write_com(0x06);           //字符不動,光標自動右移動一位

  47. write_com(0x01);          //清屏
  48. }

  49. /*寫命令to lcd        */
  50. /**********************************/
  51. void write_com(uchar com)//寫命令
  52. {
  53.   LCDRW=0;         //低電平為寫
  54.   LCDRS=0;         //低電平為命令選擇
  55.   //LCDEN=1;
  56.   lcddata=com;
  57.   delaylcd(5);
  58.   LCDEN=1;
  59.   delaylcd(5);
  60.   LCDEN=0;
  61. }

  62. /*寫數據to lcd             */
  63. /**********************************/
  64. void write_data(uchar  date)
  65. {
  66. LCDRW=0;  //低電平為寫
  67. LCDRS=1;  //高電平為數據選擇
  68. //LCDEN=1;
  69. lcddata=date;
  70. delaylcd(5);
  71. LCDEN=1;
  72. delaylcd(5);
  73. LCDEN=0;
  74. }

  75. /*設定顯示位置             */
  76. /********************************/
  77. void lcd_pos(uchar pos)
  78. {                                    //第一行第幾列直接寫pos為幾,第二行pos從0x40開始
  79.    write_com(pos | 0x80) ;   //數據指針=80+地址變量
  80. }
  81. /*自定義字符寫入CGRAM      */
  82. /*********************************/
  83. void mywritetab()  
  84. {  
  85.      unsigned char i ;
  86.      write_com(0x40) ;             //寫CGRAM
  87.      for(i=0;i<8;i++)
  88.          {write_data(mytab[i]);}                                                                                                                                                                                                                                                                                                                                                
  89. }

  90. /*******************************ds18b20*******************************************/
  91. /*ms級別 延時程序      */
  92. void ddelay(uint ms)
  93. {
  94. uint i;
  95. uchar j;
  96. for(i=0;i<ms;i++)
  97.    for(j=0;j<250;j++)
  98.    {
  99.     _nop_();          //一個機器周期,1us
  100.            _nop_();          //適用于精度高的
  101.         _nop_();
  102.     _nop_();
  103.    }
  104. }
  105. /*us級延時,延時時間約4+2*i*/
  106. void Delayus(uchar i)
  107. {
  108.   while(--i);
  109. }
  110. /*復位,每次讀寫之前都要進行復位*/
  111. /**********************************/
  112. bit ow_reset(void)
  113. {
  114. DQ = 1 ;       //DQ復位
  115. Delayus(8) ;     //稍做延時

  116. DQ = 0; //拉低約600us
  117. Delayus(150);
  118. Delayus(150);

  119. DQ = 1;//產生上升沿,延時約15~60us
  120. Delayus(30);

  121. if(DQ==0) {presence=0;}         
  122. else presence=1;
  123. return(presence); //等待應答信號 0允許,1禁止
  124. }

  125. /*讀取數據一位            */
  126. //---------------------------------
  127. bit Read_bit()
  128. {
  129. uint i = 0;
  130. bit b = 0;

  131. DQ = 0; //產生讀時隙  
  132. i++;         //維持低電平至少1us

  133. DQ = 1; //1us以上后拉高
  134. Delayus(2); //延時8us,DO下降沿15內ds18b20輸出的數據才有效


  135. b = DQ; //讀取數據
  136. Delayus(40);         //每個讀時隙至少持續60us

  137. return(b);
  138. }

  139. /*讀取一個字節             */
  140. //------------------------------------
  141. uchar Read_byte()
  142. {
  143. uchar byte_read = 0;
  144. uchar i, j;

  145. for(i=0; i<8; i++)
  146.   {
  147.    j = Read_bit();
  148.    byte_read = (j<<i) | byte_read; //低位讀起
  149.   }

  150. return(byte_read);
  151. }

  152. //-----------------------------------------
  153. /*寫一個字節         */
  154. void Write_byte(uchar byte_to_write)
  155. {
  156. uchar i = 0;
  157. uchar j = 0;
  158. bit write_bit = 0;

  159. for(j=0; j<8; j++)
  160.   {
  161.    write_bit =         (byte_to_write & 0x01);
  162.     if(write_bit == 1) //寫1
  163.          {
  164.           DQ = 0;  //產生寫時隙
  165.          Delayus(3);           //延時15us
  166.          
  167.           DQ = 1;  //寫1
  168.           Delayus(40);   //延時,寫時隙不得低于60us
  169.          }
  170.         else
  171.          {
  172.           DQ = 0;  //產生寫時隙
  173.           Delayus(50);   //延時,保持低約60us~120us
  174.           DQ = 1;  
  175.           i++;
  176.          }
  177.    byte_to_write = byte_to_write >> 1;
  178.   }
  179. }
  180. //-----------------------------------
  181. /*讀取溫度,啟動溫度轉換*/
  182. /*啟動溫度轉換*/
  183. void start_convert()
  184. {
  185. ow_reset();          // 發出復位脈沖,每次操作都從復位開始
  186. ddelay(1);
  187. Write_byte(0xcc); //skip room命令,跳過序列號命令字
  188. Write_byte(0x44); //啟動溫度轉換命令
  189. }

  190. /*讀取溫度值*/
  191. void read_tempreture()
  192. {
  193. ow_reset();          // 發出復位脈沖,每次操作都從復位開始
  194. ddelay(1);
  195. Write_byte(0xcc); //skip room命令
  196. Write_byte(0xbe); //讀取暫存器命令
  197. temp_data[0] = Read_byte(); //存儲溫度低字節值 (整數部分低四位和小數部分) 先從低字節讀取
  198. temp_data[1] = Read_byte(); //存儲溫度高字節值 (其中高五位為符號位)
  199. }
  200. //--------------------------------------
  201. /* CHECKING...顯示              */
  202. void lcd_display()
  203. {
  204. uchar   m ;
  205. lcd_init() ;                 //初始化LCD
  206. lcd_pos(0) ;                 //設置顯示位置為第一行的第1個字符
  207.       m = 0 ;
  208.      while(cdis0[m] != '\0')
  209.       {                          //顯示字符
  210.         write_data(cdis0[m]) ;
  211.         m++ ;
  212.       }
  213. }

  214. //--------------------------------------
  215. /* DS18B20 OK 顯示菜單                 */
  216. void Ok_Menu ()
  217. {
  218.      uchar   m ;
  219.      lcd_init() ;                 //初始化LCD

  220.      lcd_pos(0) ;                 //設置顯示位置為第一行的第1個字符
  221.       m = 0 ;
  222.      while(cdis1[m] != '\0')
  223.       {                          //顯示字符
  224.         write_data(cdis1[m]) ;
  225.         m++ ;
  226.       }         
  227. }

  228. //-----------------------------------
  229. /*DS18B20   ERR0R          */
  230. /*PLEASE   CHECK  顯示    */
  231. void Error_Menu ()
  232. {
  233.       uchar   m ;
  234.       lcd_init() ;                 //初始化LCD

  235.       lcd_pos(0) ;                 //設置顯示位置為第一行的第1個字符
  236.       m = 0 ;
  237.       while(cdis3[m] != '\0')
  238.       {                          
  239.         write_data(cdis3[m]) ;           //顯示字符
  240.         m++ ;
  241.       }

  242.       lcd_pos(0x40) ;              //設置顯示位置為第二行第1個字符
  243.       m = 0 ;
  244.       while(cdis4[m] != '\0')
  245.       {
  246.         write_data(cdis4[m]) ;       //顯示字符
  247.         m++ ;
  248.       }
  249. }

  250. //-----------------------------------
  251. /*自定義字符顯示    */
  252. void zdyzfxs()
  253. {
  254. mywritetab();
  255. lcd_pos(12);
  256. write_data(0x00);
  257. }
  258. //------------------------------------
  259. /*溫度顯示                       */
  260. void temperature_display()
  261. {
  262.   uchar m;
  263.   flag=0;
  264.   while(1)
  265.   {
  266.     ddelay(2);
  267.     EA=0;                                //DS18B20讀寫數據按照嚴格的時序,最好不要被打斷,故把所有中斷關閉
  268.         start_convert();                          //啟動溫度轉換
  269.     ddelay(250);
  270.         read_tempreture();                          //讀取溫度
  271.     EA=1;
  272.         cc=temp_data[1]*256.0+temp_data[0];
  273.         if(temp_data[1]>0xF8) {flag=1;cc=~cc+1;} else flag=0;
  274.         cc1=cc*0.0625;
  275.         cc2=cc1*100;
  276.         cdis2[1]=cc2/1000+0x30;
  277.         if(cdis2[1]==0x30)
  278.          {cdis2[1]=0x20;}
  279.         cdis2[2]=cc2/100%10+0x30;//LCD顯示溫度個位
  280.         //cdis2[4]=cc2%100/10+0x30;
  281.     //cdis2[5]=cc2%10+0x30;
  282.         if(flag==1)
  283.            cdis2[0]='-';//LCD溫度顯示  -
  284.         else
  285.            cdis2[0]='+';//LCD溫度顯示  +
  286.          
  287.          lcd_pos(6) ;                 //設置顯示位置為第一行的第6個字符
  288.      m=0;
  289.      while(cdis2[m]!='\0')
  290.       {                          //顯示字符
  291.         write_data(cdis2[m]) ;
  292.                 m++;
  293.           }                                                                  
  294.    }
  295. }

  296. //---------------------------------
  297. /*主函數             */
  298. void main()
  299. {
  300.   lcd_display();
  301.   ddelay(1000);
  302.   ow_reset();
  303.   if(presence==0)
  304.     {
  305.           Ok_Menu ();
  306.          ddelay(1000);
  307.          zdyzfxs();//顯示自定義字符 ℃
  308.          temperature_display();  
  309.     }
  310.   else
  311.     {
  312.          Error_Menu ();
  313.          while(1)
  314.          {
  315.           ow_reset();
  316.           if(presence==0)
  317.            {
  318.                 Ok_Menu ();
  319.             ddelay(1000);
  320.             temperature_display();
  321.            }
  322.          }
  323.     }
  324. }
復制代碼



回復

使用道具 舉報

ID:608872 發表于 2019-10-10 17:48 | 顯示全部樓層
自己弄好了,謝謝大家
回復

使用道具 舉報

ID:235200 發表于 2019-10-10 22:51 | 顯示全部樓層
uchar  cdis2[ ] = "+00.00";這一條是定義顯示小數部分的數據,把.00去掉即可
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 欧美乱做爰xxxⅹ久久久 | 国产欧美日韩久久久 | 中文字幕免费视频 | 久久伦理中文字幕 | 色眯眯视频在线观看 | 久久久噜噜噜久久中文字幕色伊伊 | 欧美网站一区 | 国产精品精品视频一区二区三区 | 国产精品久久久久久久久久久久 | 欧美一级大片免费看 | 精品国产乱码久久久久久老虎 | 久久久久久国产免费视网址 | 亚洲国产精品成人久久久 | 国产视频在线一区二区 | 免费黄色的网站 | 欧美综合国产精品久久丁香 | 欧美一级免费看 | 久久国产精品72免费观看 | 色综合激情 | 中文字幕第100页 | 国产精品久久国产精品 | 精品亚洲一区二区三区 | 亚洲一区二区三区四区五区午夜 | 亚洲免费在线 | av先锋资源 | 国产成人精品网站 | 国产视频一区在线 | www.久久久久久久久久久久 | 一区二区国产在线 | 国产在线高清 | 亚洲精品乱码久久久久久9色 | 国产成人99 | 国产精品久久久久久婷婷天堂 | 在线免费观看日本 | 久久免费看 | 一区二区免费 | 特级黄一级播放 | 久久久久国产一区二区三区 | 成人在线免费 | 欧美激情精品久久久久久 | 一区免费看 |