找回密码
 立即注册

QQ登录

只需一步,快速开始

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

16X16RGB点阵仿真和程序(上下移、帘入帘出、左右移等效果)

[复制链接]
跳转到指定楼层
楼主
带RGB(红绿蓝)的16X16点阵仿真图如下:


16X16RGB点阵的单片机源程序如下:
  1. /*--------------------------------------
  2.         多个16*16LED显示演示程序
  3.          MCU AT89C52  XAL 24MHz
  4. --------------------------------------*/
  5. //以下程序能实现多个16*16LED屏的多个字符显示,显示方式有整行上移、帘入帘出、左移、右移//
  6. #include "reg52.h"
  7. #define BLKN 6          //列锁存器数(=LED显示字数*2)
  8. #define TOTAL 102        //待显示字个数,本例共20个
  9. #define TOTAL0 99
  10. #define TOTAL1 96        
  11. #define TOTAL2 33
  12. #define TOTAL3 128
  13. #define TOTAL4 15
  14. #define TOTAL5 84
  15. #define TOTAL6 54

  16. #define CONIO P1        //显示控制口
  17. sbit G=CONIO^7;         //CONIO.7为154译码器显示允许控制信号端口,0时输出,1时输出全为高阻态.
  18. sbit CLK=CONIO^6;       //CONIO.6为595输出锁存器时钟信号端,1时输出数据,从1到0时锁存输出数据.
  19. sbit SCLR=CONIO^5;      //CONIO.5为595移位寄存器清零口,平时为1,为0时,输出全为0.
  20. unsigned char idata dispram[(BLKN/2)*32]={0}; //显示区缓存,四字共4*32单元
  21. //
  22. //**************45度No.1字模表******************//
  23. unsigned char code Bmp[][32]={

  24. 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
  25. …………限于本文篇幅 余下代码请从51黑下载附件…………
  26. 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0x00,0x00,0x66,0x64,0x99,0x99,0x66,0x66,0x99,0x99}//16第四水流

  27. };


  28. //**************笑脸字模表******************//
  29. unsigned char code Bmp3[][32]={

  30. {0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
  31. …………限于本文篇幅 余下代码请从51黑下载附件…………
  32. 0xFE,0x00,0xFE,0xC0,0xFC,0xF0,0xFC,0xFC,0xF8,0xFE,0xF8,0xFF,0xF0,0xFF,0xE0,0xFF},//5红绿蓝
  33. };


  34. //**************风扇4字模表******************//
  35. unsigned char code Bmp8[][32]={

  36. {0x1F,0xF8,0x0F,0xF0,0x07,0xE0,0x83,0xC1,0xC1,0x83,0xE1,0x87,0xF1,0x0F,0xFC,0x7F,
  37. …………限于本文篇幅 余下代码请从51黑下载附件…………
  38. 0xFE,0x00,0xFE,0xC0,0xFC,0xF0,0xFC,0xFC,0xF8,0xFE,0xF8,0xFF,0xF0,0xFF,0xE0,0xFF},//5一到七

  39. };


  40. //**************向上流动字体字模表******************//
  41. unsigned char code Bmp9[][32]={

  42. {0xFF,0x7F,0xFF,0x7F,0x03,0x7F,0xFA,0x01,0x7A,0xFB,0xB5,0xB7,0xD7,0xBF,0xEF,0xBF,
  43. …………限于本文篇幅 余下代码请从51黑下载附件…………
  44. 0x6F,0xED,0x67,0xCD,0xB3,0x9B,0xB8,0x3B,0xDF,0xF7,0xE7,0xCF,0xF8,0x3F,0xFF,0xFF}//:)28

  45. };

  46. //**************内帘出心型图字模表******************//
  47. unsigned char code Bmp10[][32]={

  48. 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
  49. …………限于本文篇幅 余下代码请从51黑下载附件…………
  50. 0xF0,0x0F,0xF8,0x1F,0xFC,0x3F,0xFE,0x7F,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,//红
  51. 0xFF,0xFF,0xC7,0xE3,0x81,0x81,0x0C,0x30,0x1E,0x78,0x3F,0xFC,0x3F,0xFC,0x1F,0xF8,
  52. 0x8F,0xF1,0xC7,0xE3,0xE3,0xC7,0xF1,0x8F,0xF8,0x1F,0xFC,0x3F,0xFE,0x7F,0xFF,0xFF,//绿蓝
  53. 0xFF,0xFF,0xC7,0xE3,0x81,0x81,0x0C,0x30,0x1E,0x78,0x3F,0xFC,0x3F,0xFC,0x1F,0xF8,
  54. 0x8F,0xF1,0xC7,0xE3,0xE3,0xC7,0xF1,0x8F,0xF8,0x1F,0xFC,0x3F,0xFE,0x7F,0xFF,0xFF,//绿蓝

  55. };


  56. //
  57. /***********延时函数(约1毫秒)************/
  58. void delay(unsigned int dt)
  59. {
  60. register unsigned char bt;
  61. for (; dt; dt--)
  62.   for (bt=0; bt<255; bt++);
  63. }
  64. //
  65. /*****************主函数 *********************/
  66. void main(void)
  67. {
  68. register unsigned char i,j,k,l,q,w,a;
  69. //初始化
  70. SCON  = 0x00;              //串口工作模式0:移位寄存器方式
  71. TMOD = 0x01;               //定时器T0工作方式1:16位方式
  72. TR0 = 1;                   //启动定时器T0
  73. CONIO = 0x3f;                 //CONIO端口初值
  74. IE = 0x82;                 //允许定时器T0中断
  75. //
  76. while (1)
  77. {
  78. //初始化黑屏
  79.   for (i=0;i<32;i++)      
  80.     {
  81.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=0xff;}   
  82.     }                     
  83. delay(1000);


  84. //45度显示No.1
  85. for (w=0;w<TOTAL*2/BLKN;w++)
  86. {
  87. for (i=0;i<32;i++)      
  88.     {
  89.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp[q+w*BLKN/2][i];}     
  90.     }                     
  91. delay(150);
  92. }
  93. //45度显示No.1
  94. for (w=0;w<TOTAL0*2/BLKN;w++)
  95. {
  96. for (i=0;i<32;i++)      
  97.     {
  98.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp0[q+w*BLKN/2][i];}     
  99.     }                     
  100. delay(150);
  101. }
  102. delay(1000);

  103. //显示海豚1
  104. for (w=0;w<TOTAL1*2/BLKN;w++)
  105. {
  106. for (i=0;i<32;i++)      
  107.     {
  108.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp1[q+w*BLKN/2][i];}     
  109.     }                     
  110. delay(150);
  111. }
  112. //显示海豚2
  113. for (w=0;w<TOTAL1*2/BLKN;w++)
  114. {
  115. for (i=0;i<32;i++)      
  116.     {
  117.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp2[q+w*BLKN/2][i];}     
  118.     }                     
  119. delay(150);
  120. }
  121. delay(1000);

  122. //显示笑脸
  123. for (a=0;a<3;a++)
  124. {
  125. for (w=0;w<TOTAL2*2/BLKN;w++)
  126. {
  127.   for (i=0;i<32;i++)      
  128.     {
  129.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp3[q+w*BLKN/2][i];}     
  130.     }                     
  131.     delay(250);
  132. }
  133. }
  134. delay(1000);

  135. //外帘入图案
  136. for (w=0;w<TOTAL3*2/BLKN;w++)
  137. {
  138. for (i=0;i<32;i++)      
  139.     {
  140.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp4[q+w*BLKN/2][i];}     
  141.     }                     
  142. delay(200);
  143. }
  144. delay(1000);

  145. //显示内帘出图案
  146. for (w=0;w<TOTAL6*2/BLKN;w++)
  147. {
  148.   for (i=0;i<32;i++)      
  149.     {
  150.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp10[q+w*BLKN/2][i];}     
  151.     }                     
  152. delay(150);
  153. }
  154. delay(1000);

  155. //显示风扇1
  156. for (a=0;a<3;a++)
  157. {
  158. for (w=0;w<TOTAL4*2/BLKN;w++)
  159. {
  160.   for (i=0;i<32;i++)      
  161.     {
  162.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp5[q+w*BLKN/2][i];}     
  163.     }                     
  164. delay(120);
  165. }
  166. }
  167. //显示风扇2
  168. for (a=0;a<3;a++)
  169. {
  170. for (w=0;w<TOTAL4*2/BLKN;w++)
  171. {
  172.   for (i=0;i<32;i++)      
  173.     {
  174.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp6[q+w*BLKN/2][i];}     
  175.     }                     
  176. delay(120);
  177. }
  178. }
  179. //显示风扇3
  180. for (a=0;a<3;a++)
  181. {
  182. for (w=0;w<TOTAL4*2/BLKN;w++)
  183. {
  184.   for (i=0;i<32;i++)      
  185.     {
  186.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp7[q+w*BLKN/2][i];}     
  187.     }                     
  188. delay(120);
  189. }
  190. }
  191. //显示风扇4
  192. for (a=0;a<3;a++)
  193. {
  194. for (w=0;w<TOTAL4*2/BLKN;w++)
  195. {
  196.   for (i=0;i<32;i++)      
  197.     {
  198.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=Bmp8[q+w*BLKN/2][i];}     
  199.     }                     
  200. delay(120);
  201. }
  202. }




  203. //初始化黑屏
  204.   for (i=0;i<32;i++)      
  205.     {
  206.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=0xff;}   
  207.     }        
  208. //向上移动汉字
  209.   for (i=0; i<TOTAL5*2/BLKN; i++)      
  210.     {
  211.     for (j=0; j<16; j++)
  212.       {
  213.       for (k=0; k<15; k++)
  214.         {
  215.          for(q=0;q<BLKN/2;q++)
  216.          {dispram[k*2+q*32] = dispram[(k+1)*2+q*32];dispram[k*2+1+q*32] = dispram[(k+1)*2+1+q*32];}
  217.         }
  218.       for(q=0;q<BLKN/2;q++)
  219.         {dispram[30+q*32] = Bmp9[q+i*BLKN/2][j*2];dispram[31+q*32] = Bmp9[q+i*BLKN/2][j*2+1];}
  220.       delay(80);
  221.       }
  222.     }   
  223.   delay(1000);

  224. //卷帘出黑屏
  225.   for (i=0;i<32;i++)      
  226.     {
  227.     for(q=0;q<BLKN/2;q++) {dispram[i+q*32]=0xff;}
  228.       if (i%2) delay(100);
  229.     }                     
  230. delay(1000);


  231. }
  232. }
  233. //主函数结束
  234. //
  235. /**********显示屏扫描(定时器T0中断)函数**********/
  236. void leddisplay(void) interrupt 1 using 1
  237. {
  238. register unsigned char m, n=BLKN;
  239. TH0 = 0xFc;                //设定显示屏刷新率每秒62.5帧(16毫秒每帧)
  240. TL0 = 0x18;
  241. m = CONIO;                 //读取当前显示的行号
  242. m = ++m & 0x0f;            //行号加1,屏蔽高4位
  243. do {
  244.    n--;
  245.    SBUF = dispram[m*2+(n/2)*30 + n]; //送显示数据
  246.    while (!TI); TI = 0;
  247.    }while (n);             //完成一行数据的发送
  248. G = 1;                     //消隐(关闭显示)
  249. CONIO &= 0xf0;             //行号端口清○
  250. CLK=1;                     //显示数据打入输出锁存器
  251. CONIO |= m;                //写入行号
  252. CLK=0;                     //锁存显示数据
  253. G = 0;                     //打开显示
  254. }
  255. //
复制代码

所有资料51hei提供下载:
16X16RGB 仿真和程序.rar (149.31 KB, 下载次数: 89)


评分

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

查看全部评分

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

使用道具 举报

沙发
ID:88606 发表于 2017-8-28 11:58 | 只看该作者
proreus8.6版本仿真不正常!
回复

使用道具 举报

板凳
ID:140489 发表于 2018-4-9 16:04 | 只看该作者
仿真不正常。点阵全亮
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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