找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机16x64点阵仿真程序 左右移动模式

  [复制链接]
跳转到指定楼层
楼主
ID:642138 发表于 2019-11-17 21:01 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  16x64 nokta vuruşlu program
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


  1. /***********************************************************
  2. 名称: 16*64点阵
  3. MCU:                89C52
  4. 晶振:                12M
  5. 时间:                2008年12月06日
  6. 外部器件:        16*64点阵,ds1302
  7. 接线:                见ds1302.h和本主文件
  8. 版本:                V1.0
  9. ------------------更新记录---------------------------------
  10. 20081206        开始记录编辑过程,养成良好习惯.添加了1302.h的头文件.实现了实时时钟的显示.
  11.                         因还未添加按键部分,故只能在proteus仿真.
  12. ***********************************************************/

  13. #include <REGX52.H>
  14. //#include <intins.h>
  15. #include "DS1302.h"
  16. #include "ascii.h"
  17. #define SPEED 5                          //移动速度,数字越大越慢


  18. sbit H_CLK         =         P1^3;
  19. sbit H_D         =         P1^2;
  20. sbit L_CLK        =         P3^1;
  21. sbit L_D         =         P3^0;
  22. sbit L_STB         =         P1^0;
  23. sbit L_OE   =         P1^1;

  24. SYSTEMTIME CurrentTime;

  25. unsigned char date[]=
  26. {
  27. ' ',' ',' ',' ',' ',' ',' ',' ',         //开头8个空格
  28.         '2','0',                                                 //21世纪
  29.         '0','8',                                                 //年数据        No.10,11
  30.         'Y','Y',                                                //“年”
  31.         '1','2',                                                //月数据         No.14,15
  32.         'M','M',                                                //“月”
  33.         '0','6',                                                //日数据        No.18,19
  34.         'D','D',                                                //“日”
  35.        
  36.         0,                                                         //空格
  37.        
  38.         'W','E','E','K',                                //“星期”
  39.         '?','?',                                                //星期几        No.27,28
  40.        
  41.         0,                                                                //空格
  42.        
  43.         '1','9',                                                  //小时数据         No.30,31
  44.         ':',                                                    //':'                 No.32
  45.         '4','1',                                                  //分钟数据         No.33,34
  46.         ':',                                                    //':'                No.35
  47.         '0','0',                                                   //秒数据         No.36,37                                       
  48.                                        
  49. ' ',' ',' ',' ',' ',' ',' ',' ',   
  50. ' ',' ',' ',' ',' ',                                //数组最大用到No.52                                                                                  
  51. ' ',' ',' ',' ',' ',' ',' ',' ',        //末尾8个空格
  52. };

  53. void time_to_buff(void);
  54. void delay_nms(unsigned int count);
  55. void set_row(unsigned char row);
  56. void sendRbyte(unsigned char wdata);                                        //模拟spi的方式往列4094传送字模数据
  57. void sendR2byte(unsigned char wdata,unsigned char n);        //模拟spi的方式往列4094传送字模数据
  58. void time_to_buff(void);

  59. void main(void)
  60. {
  61.         unsigned char i,offset=0,disrow=0,j,k=0;

  62.         Initial_DS1302();

  63.         L_OE=0;                                 //列不输出
  64.         for(i=0;i<16;i++)          //行驱动的4094填16个1,使行不输出,去掉大概也没问题.反正就一会
  65.         {
  66.                 H_CLK=0;
  67.                 H_D=1;
  68.                 H_CLK=0;
  69.         }

  70.         while(1)
  71.         {
  72.                 for(j=0;j<SPEED;j++,offset++)
  73.                 {
  74.                          for(disrow=0;disrow<16;disrow++)                  //disrow,当前扫描的行
  75.                         {
  76.                                 set_row(disrow);                //行4094的输出.依次点亮1~16行.

  77.                                 L_STB=0;                                //STB low
  78.                        
  79.                                 for(i=0;i<8;i++)                  //送往8个4094的数据.
  80.                                         sendRbyte(~a[date[k+i]-32][disrow]);        //acsii-32 就是实际的字模位置       
  81.                                 sendR2byte(~a[date[k+8]-32][disrow],offset);
  82.                                 if(offset==8)
  83.                                 {
  84.                                         offset=0;k++;
  85.                                         if(k>45) k=0;
  86.                                 }
  87.                
  88.                                 L_STB=1;       //STB high                               
  89.                                 L_OE=1;                   //列4094输出
  90.                                 delay_nms(2);  //此处延时,请根据点阵闪烁状况加以调整,仿真时候无法仿真闪烁.
  91.                                 L_OE=0;                       
  92.                         }
  93.                 }
  94.                 time_to_buff();
  95.         }
  96. }


  97. void delay_nms(unsigned int count)
  98. {
  99.         unsigned int i,j;
  100.         for(i=0;i<count;i++)
  101.         for(j=0;j<120;j++);          
  102. }

  103. void set_row(unsigned char row)
  104. {
  105.         H_CLK=0;                          //行4094的输出.依次点亮1~16行.
  106.         if(row==0)        H_D=0;
  107.         else                H_D=1;
  108.         H_CLK=1;
  109. }

  110. void sendRbyte(unsigned char wdata)                                                //模拟spi的方式往列4094传送字模数据
  111. {
  112.         unsigned char i;
  113.         for(i=0;i<8;i++)
  114.         {
  115.                 L_CLK=0;                //时钟拉低
  116.                 L_D=wdata&0x80;
  117.                 L_CLK=1;                //时钟拉高,产生上升沿               
  118.                 wdata <<= 1;        //左移一位
  119.         }
  120. }

  121. void sendR2byte(unsigned char wdata,unsigned char n)        //模拟spi的方式往列4094传送字模数据
  122. {
  123.         unsigned char i;
  124.         for(i=0;i<n;i++)
  125.         {
  126.                 L_CLK=0;                //时钟拉低
  127.                 L_D=wdata&0x80;
  128.                 L_CLK=1;                //时钟拉高,产生上升沿               
  129.                 wdata <<= 1;        //左移一位
  130.         }
  131. }

  132. /*
  133. void send_0_pulse(unsigned char n)         //送n个脉冲,
  134. {
  135.         unsigned char i;
  136.         L_D=1;                                //其实应该是0,仿真时用1
  137.         for(i=0;i<n;i++)
  138.         {
  139.                 L_CLK=0;                //时钟拉低
  140.                 L_CLK=1;                //时钟拉高,产生上升沿
  141.         }
  142. }
  143. */

  144. void time_to_buff(void)
  145. {
  146.         DS1302_GetTime(&CurrentTime);
  147.         DateToStr(&CurrentTime);
  148.         TimeToStr(&CurrentTime);

  149.            date[10]=CurrentTime.DateString[0];
  150.            date[11]=CurrentTime.DateString[1];
  151.            date[14]=CurrentTime.DateString[3];
  152.            date[15]=CurrentTime.DateString[4];
  153.            date[18]=CurrentTime.DateString[6];
  154.            date[19]=CurrentTime.DateString[7];

  155.            date[30]=CurrentTime.TimeString[0];
  156.            date[31]=CurrentTime.TimeString[1];
  157.            date[33]=CurrentTime.TimeString[3];
  158.            date[34]=CurrentTime.TimeString[4];
  159.            date[36]=CurrentTime.TimeString[6];
  160.            date[37]=CurrentTime.TimeString[7];
  161. }
复制代码



单片机源程序如下:
  1. #include<reg52.h>
  2. #include"MacroAndConst.h"
  3. #include"delay.h"
  4. #include"display.h"
  5. #include"ziku.h"

  6. extern bit fLeftFlag;  //声明外部变量
  7. extern bit fRightFlag;        //声明外部变量
  8. uchar scan;
  9. uchar speed=2;        //设定移动速度
  10. uint words;                //字模计数器
  11. uchar move;                //列指针
  12. uchar line;                //行指针
  13. uchar temp;
  14. uchar BUFF[10];        //缓存数组
  15. sbit ST=P3^5;        //595 STR
  16. sbit SH=P3^6;  //595 CLK
  17. sbit DATA=P3^7;        //595 DATAS

  18. /**********************************************************
  19. 函数名称:LeftflowDisplay
  20. 函数功能:左移显示函数
  21. 入口参数:无  
  22. 出口参数:无
  23. 备  注:
  24. **********************************************************/
  25. void LeftflowDisplay()                //逐行 阴码 逆向
  26. {
  27.         uchar sp,y=0;
  28.         move=0;
  29.         words=0;
  30.                 while(words<46*32)                //
  31.                 {        
  32.                          if(fLeftFlag==1)
  33.                         {
  34.                                 while(move<16)        //数据移位
  35.                                 {        
  36.                                         if(fLeftFlag==1)
  37.                                         {        
  38.                                        
  39.                                                 for(sp=0;sp<speed;sp++)        //移动速度
  40.                                                 {        
  41.                                                         if(fLeftFlag==1)
  42.                                                         {
  43.                                                                 for(line=0;line<16;line++)        //行扫描
  44.                                                                 {
  45.                                                                         loadline1();        //装载一线点阵数据
  46.                                                                         sendline1();        //发送一线移动数据
  47.                                                                         scan=line;        //显示第line行
  48.                                                                         P2=scan;
  49.                                                                         ST=1;                //锁存为高,595锁存信号
  50.                                                                         ST=0;
  51.                                                                         delay_10us(50);        //延时500us,等待一段时间,产生视觉暂留
  52.                                                                 }
  53.                                                         }
  54.                                                         else
  55.                                                         break;
  56.                                                 }
  57.                                                 move=move+1;                //移动一步(一位)
  58.                                         }
  59.                                         else
  60.                                         break;
  61.                                 }
  62.                                 move=0;
  63.                                 words=words+32;        //下一个字
  64.                         }
  65.                         else
  66.                         break;
  67.                 }
  68.                 words=0;
  69.         }
  70. /**********************************************************
  71. 函数名称:loadline1
  72. 函数功能:装载点阵数据        缓存
  73. 入口参数:无  
  74. 出口参数:无
  75. 备  注:
  76. **********************************************************/

  77. void loadline1()
  78. {
  79.         uchar s;
  80.         for(s=0;s<5;s++)        //s为要显示的字数+1(显示4字+1=5)
  81.         {
  82.                 BUFF[2*s]=zuoyi[words+ 32*s + 2*line];
  83.                 BUFF[2*s+1]=zuoyi[words+1+ 32*s + 2*line];
  84.                
  85.                
  86.         }
  87. }
  88. /**********************************************************
  89. 函数名称:sendline1
  90. 函数功能:发送点阵数据        缓存
  91. 入口参数:无  
  92. 出口参数:无
  93. 备  注:
  94. **********************************************************/
  95. void sendline1()
  96. {
  97.         uchar s;
  98.         uchar inc,temp,tempcol;
  99.         uchar  k;
  100.         DATA=1;
  101.         if(move<8) inc=0;
  102.         else inc=1;
  103.         for(s=0+inc;s<=7+inc;s++)
  104.         {
  105.                 if(move<8)
  106.                         tempcol=move;
  107.                 else
  108.                         tempcol=move-8;
  109.                 temp=(BUFF[s]>>tempcol)|(BUFF[s+1]<<(8-tempcol));        //字模左边字节右移tempcol位,右边字节左移8-tempcol位,2者相或
  110.                 for(k=0;k<8;k++)
  111.               {
  112.                       SH=0;
  113.                         DATA=(bit)(temp&0x80);
  114.                        temp=temp<<1;
  115.                       SH=1;
  116.            }
  117.         }
  118. }
  119. /**********************************************************
  120. 函数名称:RightflowDisplay
  121. 函数功能:右移显示函数
  122. 入口参数:无  
  123. 出口参数:无
  124. 备  注:
  125. **********************************************************/
  126. void RightflowDisplay()        //流动右移         逐行 阴码 顺向
  127. {
  128.         uchar i;
  129.         move=0;
  130.         words=0;
  131.         while(words<=46*32)          //数组元素。46组,每组32个
  132.         {        
  133.                 if(fRightFlag==1)
  134.             {
  135.                         while(move<16)// 循环16次,点亮并移动一个汉字
  136.                         {         
  137.                                 if(fRightFlag==1)
  138.                                 {
  139.                                         for(i=0;i<speed;i++)//汉字在屏幕上的停留时间(即移动速度快慢)
  140.                                         {
  141.                                                 if(fRightFlag==1)
  142.                                                 {
  143.                                                         for(line=0;line<16;line++)//扫描16行                        
  144.                                                         {
  145.                                                                 loadoneline();//装载一线点阵数据
  146.                                                                 sendoneline();//发送一线点阵数据
  147.                                                                 P2=line;                 
  148.                                                             ST= 0;
  149.                                                                 ST= 1;
  150.                                                             delay_10us(50); //延时500us,等待一段时间,产生视觉暂留                                                              
  151.                                                         }
  152.                                                  }
  153.                                                  else
  154.                                                  break;
  155.                                         }
  156.                                         move++;        //列指针递增
  157.                                 }
  158.                                 else
  159.                                 break;                        
  160.                         }
  161.                         move=0;
  162.                         words=words+32;// 一个汉字移动后,指向下一个汉字         
  163.                 }
  164.                 else
  165.                 break;

  166.         }
  167.         words=0;
  168. }
  169. /**********************************************************
  170. 函数名称:loadoneline
  171. 函数功能:装载点阵数据        缓存
  172. 入口参数:无  
  173. 出口参数:无
  174. 备  注:
  175. **********************************************************/
  176. void loadoneline()
  177. {
  178.         uchar s;        
  179.     for(s=0;s<5;s++)              //s为要显示的数字+1
  180.                 {
  181.                         BUFF[2*s+1]=youyi[words+32*s+2*line];
  182.                         BUFF[2*s]=youyi[words+1+32*s+2*line];//~
  183.                 }
  184. }
  185. /**********************************************************
  186. 函数名称:sendoneline
  187. 函数功能:发送点阵数据        缓存
  188. 入口参数:无  
  189. 出口参数:无
  190. 备  注:
  191. **********************************************************/
  192. void sendoneline()
  193. {
  194.         char s;
  195.         uchar inc,k,tempcol;
  196.         if(move<8)
  197.                 inc=0;
  198.         else
  199.                 inc=1;      
  200.         for(s=7+inc;s>=0+inc;s--)
  201.                 {
  202.                         if(move<8)
  203.                                 tempcol=move;
  204.                         else
  205.                                 tempcol=move-8;
  206.                                 temp=(BUFF[s]>>tempcol)|(BUFF[s+1]<<(8-tempcol));
  207.                         for(k=0;k<8;k++)
  208.                              {        
  209.                               SH=0;
  210.                                 DATA=(bit)(temp&0x01);
  211.                                temp=temp>>1;
  212.                               SH=1;
  213.                           }
  214.                 }
  215. }
复制代码

所有资料51hei提供下载:
16X64点阵左右移动模式.7z (1.41 MB, 下载次数: 168)
程序+fz.7z (37.19 KB, 下载次数: 105)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏9 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:633576 发表于 2019-11-27 14:56 | 只看该作者
谢谢楼主
回复

使用道具 举报

板凳
ID:633576 发表于 2019-11-27 14:57 | 只看该作者
好人一生平安
回复

使用道具 举报

地板
ID:650808 发表于 2019-12-21 10:52 | 只看该作者
[img][/img]

新建文件夹.zip

267.19 KB, 下载次数: 14, 下载积分: 黑币 -5

回复

使用道具 举报

5#
ID:675834 发表于 2020-6-30 16:49 来自手机 | 只看该作者
为什么下载16*64点阵左右移动模式.7z(1.41MB)
回复

使用道具 举报

6#
ID:675834 发表于 2020-6-30 16:52 来自手机 | 只看该作者
为什么下载16X64点阵左右移动模式.7z (1.41 MB) 解压出来里面没有程序啊
回复

使用道具 举报

7#
ID:800832 发表于 2020-8-19 14:28 | 只看该作者
不错,准备研究下
回复

使用道具 举报

8#
ID:800832 发表于 2020-8-19 14:37 | 只看该作者
程序和模拟是分开上的啊!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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