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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2733|回復: 6
打印 上一主題 下一主題
收起左側

新人求問關于單片機LCD1206的仿真問題

[復制鏈接]
跳轉到指定樓層
樓主
新人剛接觸編程剛接觸proteus,現實中沒人可以請教,所以問下網絡中的大師們。
本人用網上的資料東平西湊成了一份編譯通過的代碼,實物也焊接完成并燒寫了程序調試過了,雖說是還有點問題,但是大致上能完成功能。
后來知道了Proteus可以不做實物直接仿真便捷高效,于是乎就開始學習一下proteus,由于沒有找到教學資料只能自己摸索。了解了簡單的放置元件連線以后準備將之前做的實物+程序用proteus來完成。目前只準備仿真DS18B20+LCD1206.所以 仿真的原理圖上只放了最基本的幾個元器件。
仿真運行后發現屏幕亮了但是沒有字,查找了問題發現是RS RW兩個信號沒有按程序變化而且固定在了高和低電平上。不知道問題出在哪,同一份程序放在實物上可以運行且顯示正常,這是為啥。

仿真和代碼.rar

110.07 KB, 下載次數: 9

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

使用道具 舉報

沙發
ID:390416 發表于 2021-5-16 19:35 | 只看該作者
LCD1602顯示℃ 這種自定義符號 http://www.zg4o1577.cn/bbs/dpj-200685-1.html
LCD1602液晶最新資料 說明了具體的時間要求 http://www.zg4o1577.cn/bbs/dpj-205768-1.html
回復

使用道具 舉報

板凳
ID:917199 發表于 2021-5-17 10:29 | 只看該作者
本帖最后由 timerzero 于 2021-5-17 11:35 編輯

定義的rs,rw,e都與電路圖不同,這個錯誤是不是有些低級
顯示了但數據還有問題,搞不定了,見圖
回復

使用道具 舉報

地板
ID:798165 發表于 2021-5-17 18:36 | 只看該作者
timerzero 發表于 2021-5-17 10:29
定義的rs,rw,e都與電路圖不同,這個錯誤是不是有些低級
顯示了但數據還有問題,搞不定了,見圖

sbit RS = P2^4;   
sbit RW = P2^5;
sbit EN = P2^6;
定義的是P2口的4 5 6腳啊,這個我也是反復確認的?難道是大小寫?點擊高亮同一網絡 RS rs都會亮的啊?
回復

使用道具 舉報

5#
ID:213173 發表于 2021-5-18 16:16 | 只看該作者
panxiping1 發表于 2021-5-17 18:36
sbit RS = P2^4;   
sbit RW = P2^5;
sbit EN = P2^6;

程序沒有問題,在相應C文件和H文件中找到下列定義改正即可
//#define CHECK_BUSY
sbit RS = P2^4;   //定義端口
sbit RW = P2^5;
sbit EN = P2^6;
sbit DQ=P1^0;//ds18b20 端口
回復

使用道具 舉報

6#
ID:798165 發表于 2021-5-18 17:00 | 只看該作者
wulin 發表于 2021-5-18 16:16
程序沒有問題,在相應C文件和H文件中找到下列定義改正即可
//#define CHECK_BUSY
sbit RS = P2^4;   // ...

//#define CHECK_BUSY
sbit RS = P2^4;   //定義端口
sbit RW = P2^5;
sbit EN = P2^6;
sbit DQ=P1^0;//ds18b20 端口這些定義在我的程序中有的呀,也和仿真圖紙上一樣的呢。。。。不知道錯哪了
回復

使用道具 舉報

7#
ID:213173 發表于 2021-5-18 17:23 | 只看該作者
panxiping1 發表于 2021-5-18 17:00
//#define CHECK_BUSY
sbit RS = P2^4;   //定義端口
sbit RW = P2^5;


  1. #include<reg52.h> //包含頭文件,一般情況不需要改動,頭文件包含特殊功能寄存器的定義
  2. #include<stdio.h>
  3. #include <intrins.h>       
  4. //#define CHECK_BUSY
  5. #define RS_CLR RS=0
  6. #define RS_SET RS=1
  7. #define RW_CLR RW=0
  8. #define RW_SET RW=1
  9. #define EN_CLR EN=0
  10. #define EN_SET EN=1
  11. #define DataPort P0
  12. #define KeyPort P3 //定義按鍵端口
  13. sbit RS = P2^0;
  14. sbit RW = P2^1;
  15. sbit EN = P2^2;
  16. sbit DQ = P3^3;
  17. sbit SPK=P1^2;    //定義喇叭端口
  18. sbit Relay=P1^3;    //定義Relay端口

  19. bit ReadTempFlag;//定義讀時間標志

  20. void Init_Timer0(void);//定時器初始化
  21. unsigned char KeyScan(void);//鍵盤掃描

  22. /*------------------------------------------------
  23. uS延時函數,含有輸入參數 unsigned char t,無返回值
  24. unsigned char 是定義無符號字符變量,其值的范圍是
  25. 0~255 這里使用晶振12M,精確延時請使用匯編,大致延時
  26. 長度如下 T=tx2+5 uS
  27. ------------------------------------------------*/
  28. void DelayUs2x(unsigned char t)
  29. {   
  30.         while(--t);
  31. }
  32. /*------------------------------------------------
  33. mS延時函數,含有輸入參數 unsigned char t,無返回值
  34. unsigned char 是定義無符號字符變量,其值的范圍是
  35. 0~255 這里使用晶振12M,精確延時請使用匯編
  36. ------------------------------------------------*/
  37. void DelayMs(unsigned char t)
  38. {
  39.         while(t--)
  40.         {
  41.                 //大致延時1mS
  42.                 DelayUs2x(245);
  43.                 DelayUs2x(245);
  44.         }
  45. }
  46. /*------------------------------------------------
  47.                     18b20初始化
  48. ------------------------------------------------*/
  49. bit Init_DS18B20(void)
  50. {
  51.         bit dat=0;
  52.         DQ = 1;    //DQ復位
  53.         DelayUs2x(5);   //稍做延時
  54.         DQ = 0;         //單片機將DQ拉低
  55.         DelayUs2x(200); //精確延時 大于 480us 小于960us
  56.         DelayUs2x(200);
  57.         DQ = 1;        //拉高總線
  58.         DelayUs2x(50); //15~60us 后 接收60-240us的存在脈沖
  59.         dat=DQ;        //如果x=0則初始化成功, x=1則初始化失敗
  60.         DelayUs2x(25); //稍作延時返回
  61.         return dat;
  62. }

  63. /*------------------------------------------------
  64.                     讀取一個字節
  65. ------------------------------------------------*/
  66. unsigned char ReadOneChar(void)
  67. {
  68.         unsigned char i=0;
  69.         unsigned char dat = 0;
  70.         for (i=8;i>0;i--)
  71.         {
  72.                 DQ = 0; // 給脈沖信號
  73.                 dat>>=1;
  74.                 DQ = 1; // 給脈沖信號
  75.                 if(DQ)
  76.                 dat|=0x80;
  77.                 DelayUs2x(25);
  78.         }
  79.         return(dat);
  80. }
  81. /*------------------------------------------------
  82.                     寫入一個字節
  83. ------------------------------------------------*/
  84. void WriteOneChar(unsigned char dat)
  85. {
  86.         unsigned char i=0;
  87.         for (i=8; i>0; i--)
  88.         {
  89.                 DQ = 0;
  90.                 DQ = dat&0x01;
  91.                 DelayUs2x(25);
  92.                 DQ = 1;
  93.                 dat>>=1;
  94.         }
  95.         DelayUs2x(25);
  96. }

  97. /*------------------------------------------------
  98.                     讀取溫度
  99. ------------------------------------------------*/
  100. unsigned int ReadTemperature(void)
  101. {
  102.         unsigned char a=0;
  103.         unsigned int b=0;
  104.         unsigned int t=0;
  105.         Init_DS18B20();
  106.         WriteOneChar(0xCC); // 跳過讀序號列號的操作
  107.         WriteOneChar(0x44); // 啟動溫度轉換
  108.         DelayMs(10);
  109.         Init_DS18B20();
  110.         WriteOneChar(0xCC); //跳過讀序號列號的操作
  111.         WriteOneChar(0xBE); //讀取溫度寄存器等(共可讀9個寄存器) 前兩個就是溫度
  112.         a=ReadOneChar();   //低位
  113.         b=ReadOneChar();   //高位
  114.         b<<=8;
  115.         t=a+b;
  116.         return(t);
  117. }
  118. /*------------------------------------------------
  119.               判忙函數
  120. ------------------------------------------------*/
  121. bit LCD_Check_Busy(void)
  122. {
  123.         #ifdef CHECK_BUSY
  124.         DataPort= 0xFF;
  125.         RS_CLR;
  126.         RW_SET;
  127.         EN_CLR;
  128.         _nop_();
  129.         EN_SET;
  130.         return (bit)(DataPort & 0x80);
  131.         #else
  132.         return 0;
  133.         #endif
  134. }
  135. /*------------------------------------------------
  136.               寫入命令函數
  137. -----------------   ----------------------------*/
  138. void LCD_Write_Com(unsigned char com)
  139. {  
  140.         while(LCD_Check_Busy()); //忙則等待
  141.         RS_CLR;
  142.         RW_CLR;
  143.         EN_SET;
  144.         DataPort= com;
  145.         _nop_();
  146.         _nop_();
  147.         EN_CLR;

  148. }
  149. /*------------------------------------------------
  150.               寫入數據函數
  151. ------------------------------------------------*/
  152. void LCD_Write_Data(unsigned char Data)
  153. {
  154.         while(LCD_Check_Busy()); //忙則等待
  155.         RS_SET;
  156.         RW_CLR;
  157.         EN_SET;
  158.         DataPort= Data;
  159.         _nop_();
  160.         _nop_();
  161.         EN_CLR;
  162. }
  163. /*------------------------------------------------
  164.                 清屏函數
  165. ------------------------------------------------*/
  166. void LCD_Clear(void)
  167. {
  168.         LCD_Write_Com(0x01);
  169.         DelayMs(5);
  170. }
  171. /*------------------------------------------------
  172.               寫入字符串函數
  173. ------------------------------------------------*/
  174. void LCD_Write_String(unsigned char x,unsigned char y,unsigned char *s)
  175. {     
  176.         if (y == 0)
  177.         {     
  178.                 LCD_Write_Com(0x80 + x);     //表示第一行
  179.         }
  180.         else
  181.         {      
  182.                 LCD_Write_Com(0xC0 + x);      //表示第二行
  183.         }        
  184.         while (*s)
  185.         {     
  186.                 LCD_Write_Data( *s);     
  187.                 s ++;     
  188.         }
  189. }
  190. /*------------------------------------------------
  191.               寫入字符函數
  192. ------------------------------------------------*/
  193. void LCD_Write_Char(unsigned char x,unsigned char y,unsigned char Data)
  194. {     
  195.         if (y == 0)
  196.         {     
  197.                 LCD_Write_Com(0x80 + x);     
  198.         }   
  199.         else
  200.         {     
  201.                 LCD_Write_Com(0xC0 + x);     
  202.         }        
  203.         LCD_Write_Data( Data);  
  204. }
  205. /*------------------------------------------------
  206.               初始化函數
  207. ------------------------------------------------*/
  208. void LCD_Init(void)
  209. {
  210.         RW_CLR;
  211.         LCD_Write_Com(0x38);    /*顯示模式設置*/
  212.         DelayMs(5);
  213.         LCD_Write_Com(0x38);
  214.         DelayMs(5);
  215.         LCD_Write_Com(0x38);
  216.         DelayMs(5);
  217.         LCD_Write_Com(0x38);  
  218. //        LCD_Write_Com(0x08);    /*顯示關閉*/
  219.         LCD_Write_Com(0x01);    /*顯示清屏*/
  220.         LCD_Write_Com(0x06);    /*顯示光標移動設置*/
  221.         LCD_Write_Com(0x0C);    /*顯示開及光標設置*/
  222. }
  223. /*------------------------------------------------   
  224. 設定二個自定義字符,LCD1602中自定義字符的地址為0x00--0x07,
  225. 即可定義8個字符
  226. 這里我們設定把一個自定義字符放在0x00位置(000),
  227. 另一個放在0x01位子(001)
  228. ------------------------------------------------*/
  229. void Lcd_User_Chr(void)
  230. { //第一個自定義字符
  231.         LCD_Write_Com(0x40); //"01 000 000"  第1行地址 (D7D6為地址設定命令形式D5D4D3為字符存放位置(0--7),D2D1D0為字符行地址(0--7))
  232.         LCD_Write_Data(0x00); //"XXX 11111" 第1行數據(D7D6D5為XXX,表示為任意數(一般用000),D4D3D2D1D0為字符行數據(1-點亮,0-熄滅)
  233.         LCD_Write_Com(0x41); //"01 000 001"  第2行地址
  234.         LCD_Write_Data(0x04); //"XXX 10001" 第2行數據
  235.         LCD_Write_Com(0x42); //"01 000 010"  第3行地址
  236.         LCD_Write_Data(0x0e); //"XXX 10101" 第3行數據
  237.         LCD_Write_Com(0x43); //"01 000 011"  第4行地址
  238.         LCD_Write_Data(0x0e); //"XXX 10001" 第4行數據
  239.         LCD_Write_Com(0x44); //"01 000 100"  第5行地址
  240.         LCD_Write_Data(0x0e); //"XXX 11111" 第5行數據
  241.         LCD_Write_Com(0x45); //"01 000 101"  第6行地址
  242.         LCD_Write_Data(0x1f); //"XXX 01010" 第6行數據
  243.         LCD_Write_Com(0x46); //"01 000 110"  第7行地址
  244.         LCD_Write_Data(0x04); //"XXX 11111" 第7行數據
  245.         LCD_Write_Com(0x47); //"01 000 111"  第8行地址
  246.         LCD_Write_Data(0x00); //"XXX 00000" 第8行數據
  247.         //第二個自定義字符
  248.         LCD_Write_Com(0x48); //"01 001 000"  第1行地址  
  249.         LCD_Write_Data(0x03); //"XXX 00001" 第1行數據
  250.         LCD_Write_Com(0x49); //"01 001 001"  第2行地址
  251.         LCD_Write_Data(0x03); //"XXX 11011" 第2行數據
  252.         LCD_Write_Com(0x4a); //"01 001 010"  第3行地址
  253.         LCD_Write_Data(0x00); //"XXX 11101" 第3行數據
  254.         LCD_Write_Com(0x4b); //"01 001 011"  第4行地址
  255.         LCD_Write_Data(0x00); //"XXX 11001" 第4行數據
  256.         LCD_Write_Com(0x4c); //"01 001 100"  第5行地址
  257.         LCD_Write_Data(0x00); //"XXX 11101" 第5行數據
  258.         LCD_Write_Com(0x4d); //"01 001 101"  第6行地址
  259.         LCD_Write_Data(0x00); //"XXX 11011" 第6行數據
  260.         LCD_Write_Com(0x4e); //"01 001 110"  第7行地址
  261.         LCD_Write_Data(0x00); //"XXX 00001" 第7行數據
  262.         LCD_Write_Com(0x4f); //"01 001 111"  第8行地址
  263.         LCD_Write_Data(0x00); //"XXX 00000" 第8行數據
  264. }

  265. /*------------------------------------------------
  266.               串口通訊初始化
  267. ------------------------------------------------*/
  268. void UART_Init(void)
  269. {
  270.         SCON  = 0x50;                        // SCON: 模式 1, 8-bit UART, 使能接收  
  271.         TMOD |= 0x20;               // TMOD: timer 1, mode 2, 8-bit 重裝
  272.         TH1   = 0xFD;               // TH1:  重裝值 9600 波特率 晶振 11.0592MHz  
  273.         TR1   = 1;                  // TR1:  timer 1 打開                        
  274. //        EA    = 1;                  //打開總中斷
  275. //        ES    = 1;                  //打開串口中斷
  276.         TI=1;
  277. }
  278. /*------------------------------------------------
  279.                     主函數
  280. ------------------------------------------------*/
  281. void main (void)
  282. {                  
  283.         int temp,tempH=50,tempL=1;
  284.         float temperature;
  285.         unsigned char TempFlag=0;
  286.         char displaytemp[16],num;//定義顯示區域臨時存儲數組
  287.         LCD_Init();           //初始化液晶
  288.         DelayMs(20);          //延時有助于穩定
  289.         LCD_Clear();          //清屏
  290.         Init_Timer0();
  291.         UART_Init();
  292.         Lcd_User_Chr();       //寫入自定義字符
  293.         while(1)         //主循環
  294.         {
  295.                 num=KeyScan();
  296.                 switch(num)
  297.                 {
  298.                         case 4:if(tempH<127)tempH++;break;
  299.                         case 5:if(tempH>-55)tempH--;break;
  300.                         case 6:if(tempL<127)tempL++;break;
  301.                         case 7:if(tempL>-55)tempL--;break;
  302.                         default:break;
  303.                 }
  304.                 switch(TempFlag)
  305.                 {
  306.                         case 0:    //輸出溫度上限下限
  307.                         sprintf(displaytemp,"H.%3d  L.%3d ",tempH,tempL);
  308.                         LCD_Write_String(0,1,displaytemp);//顯示第二行
  309.                         break;
  310.                         case 1:LCD_Write_String(0,1,"over  tempH    ");break;
  311.                         case 2:LCD_Write_String(0,1,"under  tempL   ");break;
  312.                         default:break;
  313.                 }
  314.                 switch(TempFlag)
  315.                 {
  316.                         case 1:SPK=!SPK;DelayMs(1);break;
  317.                         case 2:SPK=!SPK;DelayMs(1);break;
  318.                         default:break;
  319.                 }       
  320.                 if(ReadTempFlag==1)
  321.                 {
  322.                         ReadTempFlag=0;
  323.                         temp=ReadTemperature();
  324.                         temperature=temp*0.0625;
  325.                         temp>>=4;
  326.                         if(temp>tempH)
  327.                                 TempFlag=1;  //高于高溫標志
  328.                         else if(temp<tempL)
  329.                                 TempFlag=2;  //低于低溫標志
  330.                         else
  331.                         TempFlag=0;   //正常顯示標志
  332.                         sprintf(displaytemp,"Temp  %6.2f ",temperature);//打印溫度值
  333.                         LCD_Write_String(0,0,displaytemp);//顯示第一行
  334.                         LCD_Write_Char(13,0,0x01);//寫入溫度右上角點
  335.                         LCD_Write_Char(14,0,'C'); //寫入字符C
  336.                 }
  337.         }
  338. }

  339. /*------------------------------------------------
  340.                     定時器初始化子程序
  341. ------------------------------------------------*/
  342. void Init_Timer0(void)
  343. {
  344.         TMOD |= 0x01;          //使用模式1,16位定時器,使用"|"符號可以在使用多個定時器時不受影響                     
  345.         //TH0=0x00;              //給定初值
  346.         //TL0=0x00;
  347.         EA=1;            //總中斷打開
  348.         ET0=1;           //定時器中斷打開
  349.         TR0=1;           //定時器開關打開
  350. }
  351. /*------------------------------------------------
  352.                  定時器中斷子程序
  353. ------------------------------------------------*/
  354. void Timer0_isr(void) interrupt 1
  355. {
  356.         static unsigned int num;
  357.         TH0=(65536-2000)/256;                  //重新賦值 2ms
  358.         TL0=(65536-2000)%256;
  359.         num++;
  360.         if(num==400)        //
  361.         {
  362.                 num=0;
  363.                 ReadTempFlag=1; //讀標志位置1
  364.         }
  365. }

  366. /*------------------------------------------------
  367. 按鍵掃描函數,返回掃描鍵值
  368. ------------------------------------------------*/
  369. unsigned char KeyScan(void)
  370. {
  371.         unsigned char keyvalue;
  372.         if(KeyPort!=0xff)
  373.         {
  374.                 DelayMs(10);
  375.                 if(KeyPort!=0xff)
  376.                 {
  377.                         keyvalue=KeyPort;
  378.                         while(KeyPort!=0xff);
  379.                         switch(keyvalue)
  380.                         {
  381.                                 case 0xfe:return 1;break;
  382.                                 case 0xfd:return 2;break;
  383.                                 case 0xfb:return 3;break;
  384.                                 case 0xf7:return 4;break;
  385.                                 case 0xef:return 5;break;
  386.                                 case 0xdf:return 6;break;
  387.                                 case 0xbf:return 7;break;
  388.                                 case 0x7f:return 8;break;
  389.                                 default:return 0;break;
  390.                         }
  391.                 }
  392.         }
  393.         return 0;
  394. }
復制代碼



回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩av资源站 | 一级片在线视频 | 二区三区在线观看 | 欧美日韩国产精品激情在线播放 | 国产一级片av | 欧美三级不卡 | 一区二区国产在线观看 | 日韩亚洲一区二区 | 精品中文字幕视频 | 日韩中文一区二区三区 | 久久国产精品视频免费看 | 国产精品久久久久久久久久久免费看 | 国产免费让你躁在线视频 | 真人女人一级毛片免费播放 | 日韩一区二区在线观看 | 国产精品久久久久久久午夜片 | 国产日韩一区二区 | 亚洲福利在线观看 | 精品国产一区探花在线观看 | 污污的网站在线观看 | 欧美日韩国产精品一区 | 亚洲精品一区二区冲田杏梨 | 久久久久久高潮国产精品视 | 久久精品亚洲精品 | 天天拍夜夜爽 | 99久久精品免费看国产四区 | 国产区在线观看 | 国产一级在线视频 | 久久午夜电影 | 久草青青 | 国产欧美精品一区二区 | 成人在线精品视频 | 国产成人一区二区 | 中文字幕精品一区二区三区精品 | 欧美精三区欧美精三区 | 国产日韩欧美在线观看 | 精品日韩一区二区三区av动图 | 特级做a爰片毛片免费看108 | 成人激情视频免费观看 | 一区二区三区电影在线观看 | 亚洲一区二区三区免费在线观看 |