找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4064|回复: 2
收起左侧

51单片机16×16点阵滚动字幕proteus仿真+源程序

[复制链接]
ID:250833 发表于 2018-1-10 14:47 | 显示全部楼层 |阅读模式
51单片机控制的16乘16的点阵汉字滚动仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.jpg
采用4个74hc138芯片驱动

0.png

单片机源程序如下:
  1. #include <reg52.h>

  2. #define int8 unsigned char
  3. #define int16 unsigned int
  4. #define int32 unsigned long

  5. int8 flag;
  6. int8 n;
  7. int8 code table[][32]={
  8.                           {0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00},/* "  " */


  9.                           {0x04,0x28,0x08,0x24,0x32,0x22,0xC2,0x21,0xC2,0x26,0x34,0x38,0x04,0x04,0x08,0x18,0x30,0xF0,0xC0,0x17,0x60,0x10,0x18,0x10,0x0C,0x14,0x06,0x18,0x04,0x10,0x00,0x00},/*"欢",0*/
  10.                           {0x02,0x02,0x04,0x82,0xF8,0x73,0x04,0x20,0x02,0x00,0xE2,0x3F,0x42,0x20,0x82,0x40,0x02,0x40,0xFA,0x3F,0x02,0x20,0x42,0x20,0x22,0x20,0xC2,0x3F,0x02,0x00,0x00,0x00},/*"迎",1*/
  11.                           {0x00,0x01,0x04,0x02,0x1C,0x0C,0xC0,0x3F,0x1C,0xC0,0x02,0x09,0x02,0x16,0x92,0x60,0x4A,0x20,0x82,0x2F,0x02,0x20,0x0E,0x24,0x00,0x22,0x90,0x31,0x0C,0x20,0x00,0x00},/*"您",2*/
  12.                           {0x44,0x10,0x44,0x14,0x88,0x54,0x88,0x54,0xD0,0x5F,0x30,0x50,0x60,0x50,0xFE,0x7F,0x40,0x50,0x20,0x90,0xB0,0x9F,0x98,0x92,0x8C,0x94,0x88,0x34,0x80,0x11,0x00,0x00},/*"乘",3*/
  13.                           {0x82,0x00,0x02,0x01,0x22,0x06,0x22,0x38,0x22,0x04,0x22,0x03,0x22,0x00,0xFE,0xFF,0xA2,0x00,0x22,0x01,0x22,0x02,0x22,0x3C,0x22,0x02,0x02,0x01,0x02,0x00,0x00,0x00},/*"坐",4*/
  14.                           …………
  15. …………限于本文篇幅 余下代码请从51黑下载附件…………
  16.                           {0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}/* "  " */
  17.                       };

  18. void delay(void);
  19. int16 offset;

  20. void main(void)
  21. {
  22.     int8 i;
  23.     int8 *p;
  24.     flag=0x10;
  25.     n=0;
  26.     TMOD=0x01;
  27.     TH0=0xb1;
  28.     TL0=0xe0;
  29.     ET0=1;
  30.     EA=1;
  31.     TR0=1;

  32.     p=&table[0][0];

  33.     while (1)
  34.     {
  35.         for (i=0;i<8;i++)    //显示左半边屏幕
  36.         {
  37.             P0=*(p+offset+2*i);
  38.             P2=i|0x08;    //P2.4=0,P2.3=1 选中U2, 输出扫描码给U6
  39.             delay();

  40.             P0=*(p+offset+2*i+1);
  41.               P2=i|0x10;   //P2.4=1,P2.3=0 选中U3, 输出扫描码给U7
  42.             delay();
  43.         }
  44.         for (i=8;i<16;i++)     //显示右半边屏幕
  45.         {
  46.             P0=*(p+offset+2*i);
  47.              P2=(i-8)|0x20;   //P2.5=1 P2.4=0, P2.3=0 选中U4,输出扫描码U8
  48.             delay();

  49.             P0=*(p+offset+2*i+1);
  50.              P2=(i-8)|0x40;   //P2.6=1 P2.5=0, P2.4=0 选中U5,输出扫描码U9
  51.             delay();
  52.         }
  53.     }
  54. }


  55. void delay(void)
  56. {
  57.     int16 i;
  58.     for (i=0;i<50;i++)
  59.         ;
  60. }


  61. void timer0() interrupt 1 using 3
  62. {
  63.     TF0=0;
  64.     TH0=0xb1;
  65.     TL0=0xe0;
  66.     if (n<10)
  67.     {
  68.     n++;
  69.     }
  70.     else
  71.     {
  72.     offset+=2;
  73.     if (offset>1100)
  74.             offset=0;
  75.         n=0;
  76.     }
  77. }
复制代码

所有资料51hei提供下载:
16×16点阵(滚动显示).rar (71.62 KB, 下载次数: 92)

评分

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

查看全部评分

回复

使用道具 举报

ID:704507 发表于 2020-3-8 16:28 | 显示全部楼层
谢谢分享
回复

使用道具 举报

ID:708904 发表于 2020-4-8 20:10 | 显示全部楼层
想问一下,那个点阵是怎么做出来的
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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