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

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

QQ登錄

只需一步,快速開(kāi)始

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

Proteus仿真1602字符液晶滾動(dòng)源程序(鍵控垂直與水平滾動(dòng))

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
proteus仿真的LCD1602實(shí)例
帶源代碼和電路


仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機(jī)源程序如下:
  1. /***************   writer:shopping.w   ******************/
  2. #include <reg52.h>
  3. #include <string.h>
  4. #define uchar unsigned char
  5. #define uint unsigned int
  6. void Initialize_LCD();
  7. void ShowString(uchar,uchar,uchar *);
  8. sbit K1 = P3^0;
  9. sbit K2 = P3^1;
  10. sbit K3 = P3^2;

  11. uchar code Prompt[]="PRESS K1--K4 TO START DEMO PROG";
  12. uchar const Line_Count = 6;
  13. uchar code Msg[][80]=
  14. {
  15.         "Many CAD users dismiss",
  16.         "process of creating PCB",
  17.         "of view.with PCB layout",
  18.         "placement and track routing,",
  19.         "can often be the most time",
  20.         "And if you use circuit simulation",
  21.         "you are going to spend even more"
  22. };
  23. uchar Disp_Buffer[32];
  24. void Delayxms(uint ms)
  25. {
  26.         uchar i;
  27.         while(ms--)
  28.         {
  29.                  for(i=0;i<120;i++);
  30.         }
  31. }

  32. void V_Scroll_Display()
  33. {
  34.         uchar i,j,k = 0;
  35.         uchar *p = Msg[0];
  36.         uchar *q = Msg[Line_Count] + strlen(Msg[Line_Count]);
  37.         while(p<q)
  38.         {
  39.                  for(i=0;(i<16)&&(p<q);i++)
  40.                 {
  41.                          if(((i==0)||(i==15))&& *p == ' ')
  42.                                 p++;
  43.                         if(*p != '\0')
  44.                         {
  45.                                  Disp_Buffer[i] = *p++;
  46.                         }
  47.                         else
  48.                         {
  49.                                  if(++k>Line_Count)
  50.                                         break;
  51.                                 p = Msg[k];
  52.                                 Disp_Buffer[i] = *p++;
  53.                         }
  54.                 }
  55.                 for(j=i;j<16;j++)
  56.                         Disp_Buffer[j]=' ';
  57.                 while(F0)
  58.                         Delayxms(5);
  59.                 ShowString(0,0,"      ");
  60.                 Delayxms(150);
  61.                 while(F0)
  62.                         Delayxms(5);
  63.                 ShowString(0,1,Disp_Buffer);
  64.                 Delayxms(150);
  65.                 while(F0)
  66.                         Delayxms(5);
  67.                 ShowString(0,0,Disp_Buffer);
  68.                 ShowString(0,1,"      ");
  69.                 Delayxms(150);       
  70.         }
  71.         ShowString(0,0,"         ");
  72.         ShowString(0,1,"         ");
  73. }

  74. void H_Scroll_Display()
  75. {
  76.         uchar m,n,t = 0,L=0;
  77.         uchar *p = Msg[0];
  78.         uchar *q = Msg[Line_Count] + strlen(Msg[Line_Count]);
  79.         for(m=0;m<16;m++)
  80.                         Disp_Buffer[m]=' ';       
  81.         while(p<q)
  82.         {
  83.                  if((m=16||m==31)&& *p == ' ')
  84.                         p++;
  85.                 for(m=16;m<32&&p<q;m++)
  86.                 {
  87.                          if(*p != '\0')
  88.                         {
  89.                                 Disp_Buffer[m] = *p++;        
  90.                         }
  91.                         else
  92.                         {
  93.                                  if(++t>Line_Count)
  94.                                         break;
  95.                                 p = Msg[t];
  96.                                 Disp_Buffer[m] = *p++;
  97.                         }
  98.                 }
  99.                 for(n=m;n<32;n++)
  100.                         Disp_Buffer[n]=' ';
  101.                 for(m=0;m<=16;m++)
  102.                 {
  103.                          while(F0)
  104.                                  Delayxms(5);
  105.                            ShowString(0,L,Disp_Buffer+1);
  106.                            while(F0)
  107.                                  Delayxms(5);
  108.                         Delayxms(20);
  109.                 }
  110.                 L = (L==0)? 1:0;
  111.                 Delayxms(200);
  112.         }
  113.         if(L==1)
  114.                 ShowString(0,1,"      ");       
  115. }

  116. void EX_INT0() interrupt 0
  117. {
  118.         F0 = !F0;
  119. }

  120. void main()
  121. {
  122.         uint Count = 0;
  123.         IE = 0x81;
  124.         IT0 = 1;
  125. ……………………

  126. …………限于本文篇幅 余下代碼請(qǐng)從51黑下載附件…………
復(fù)制代碼

所有資料51hei提供下載:
1602字符液晶滾動(dòng)演示程序.rar (108.21 KB, 下載次數(shù): 27)



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

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 久久九九99 | 亚洲成人一级 | 久久一及片 | 亚洲精品一区二区在线观看 | 日本久久综合网 | 特黄视频 | 一区二区三区四区国产 | 日韩精品一区二区三区中文字幕 | 高清视频一区 | 男女羞羞视频在线看 | 国产毛片久久久 | 欧美网站一区二区 | 国产精品成av人在线视午夜片 | 国产精品99久久久久久宅男 | a视频在线观看 | 91伊人网| 成人黄色av网站 | 日韩一区二区在线视频 | 国产成人免费视频 | 日日天天| 久久久久久久久久久久一区二区 | 亚洲精品日韩在线 | www.9191.com | 亚洲精品一区二区三区蜜桃久 | h视频免费在线观看 | 青青草这里只有精品 | 国产成在线观看免费视频 | 五月婷婷 六月丁香 | 在线视频第一页 | 日日干日日 | 精品欧美乱码久久久久久1区2区 | 久久久久久久久久久久久九 | 欧美日韩国产一区二区 | 2019天天干夜夜操 | 97精品一区二区 | 久久伊人免费视频 | 一级高清免费毛片 | 二区av| 欧美日韩在线视频一区 | 中文字幕成人av | 综合第一页 |