七(5)LED点阵的纵向移动

  点阵的动画显示,说到底就是对多张图片分别进行取模,使用程序算法巧妙的切换图片,多张图片组合起来就成了一段动画了,我们所看到的动画片、游戏等等,它们的基本原理也都是这样的。 

  上一节我们学了如何在点阵上画一个❤形,有时候我们希望这些显示是动起来的,而不是静止的。对于点阵本身已经没有多少的知识点可以介绍了,主要就是编程算法来解决问题了。比如我们现在要让点阵显示一个 I ❤ U 的动画,首先我们要把这个图形用取模软件画出来看一下,如图 7-10 所示。 

   这张图片共有 40 行,每 8 行组成一张点阵图片,并且每向上移动一行就出现了一张新图片,一共组成了 32 张图片。 

  用一个变量 index 来代表每张图片的起始位置,每次从 index 起始向下数 8 行代表了当前的图片,250ms 改变一张图片,然后不停的动态刷新,这样图片就变成动画了。首先我们要对显示的图片进行横向取模,虽然这是 32 张图片,由于我们每一张图片都是和下一行连续的,所以实际的取模值只需要 40 个字节就可以完成,我们来看看程序。

 
  1. #include <reg52.h>  
  2.   
  3. sbit ADDR0 = P1^0;  
  4. sbit ADDR1 = P1^1;  
  5. sbit ADDR2 = P1^2;  
  6. sbit ADDR3 = P1^3;  
  7. sbit ENLED = P1^4;  
  8.   
  9. unsigned char code image[] = { //图片的字模表  
  10.     0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,  
  11.     0xC3,0xE7,0xE7,0xE7,0xE7,0xE7,0xC3,0xFF,  
  12.     0x99,0x00,0x00,0x00,0x81,0xC3,0xE7,0xFF,  
  13.     0x99,0x99,0x99,0x99,0x99,0x81,0xC3,0xFF,  
  14.     0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF  
  15. };  
  16.   
  17. void main(){  
  18.     EA = 1;  //使能总中断  
  19.     ENLED = 0;  //使能 U4,选择 LED 点阵  
  20.     ADDR3 = 0;  
  21.     TMOD = 0x01; //设置 T0 为模式 1  
  22.     TH0 = 0xFC; //为 T0 赋初值 0xFC67,定时 1ms  
  23.     TL0 = 0x67;  
  24.     ET0 = 1;  //使能 T0 中断  
  25.     TR0 = 1;  //启动 T0  
  26.     while (1);  
  27.     }  
  28.     /* 定时器 0 中断服务函数 */  
  29.     void InterruptTimer0() interrupt 1{  
  30.     static unsigned char i = 0; //动态扫描的索引  
  31.     static unsigned char tmr = 0; //250ms 软件定时器  
  32.     static unsigned char index = 0; //图片刷新索引  
  33.      
  34.     TH0 = 0xFC; //重新加载初值  
  35.     TL0 = 0x67;  
  36.     //以下代码完成 LED 点阵动态扫描刷新  
  37.     P0 = 0xFF;  //显示消隐  
  38.     switch (i){  
  39.         case 0: ADDR2=0; ADDR1=0; ADDR0=0; i++; P0=image[index+0]; break;  
  40.         case 1: ADDR2=0; ADDR1=0; ADDR0=1; i++; P0=image[index+1]; break;  
  41.         case 2: ADDR2=0; ADDR1=1; ADDR0=0; i++; P0=image[index+2]; break;  
  42.         case 3: ADDR2=0; ADDR1=1; ADDR0=1; i++; P0=image[index+3]; break;  
  43.         case 4: ADDR2=1; ADDR1=0; ADDR0=0; i++; P0=image[index+4]; break;  
  44.         case 5: ADDR2=1; ADDR1=0; ADDR0=1; i++; P0=image[index+5]; break;  
  45.         case 6: ADDR2=1; ADDR1=1; ADDR0=0; i++; P0=image[index+6]; break;  
  46.         case 7: ADDR2=1; ADDR1=1; ADDR0=1; i=0; P0=image[index+7]; break;  
  47.         defaultbreak;  
  48.     }  
  49.     //以下代码完成每 250ms 改变一帧图像  
  50.     tmr++;  
  51.     if (tmr >= 250){  //达到 250ms 时改变一次图片索引  
  52.         tmr = 0;  
  53.         index++;  
  54.         if (index >= 32){  //图片索引达到 32 后归零  
  55.            index = 0;  
  56.         }  
  57.     }  
  58. }   

  大家把这个程序下载到单片机上看看效果,一个 I ❤ U 一直往上走动的动画就出现了,现在还有哪位敢说我们工科同学不懂浪漫的?还需要用什么玫瑰花取悦女朋友吗?一点技术含量都没有,要玩就玩点高科技,呵呵。

   当然,别光图开心,学习我们还要继续。往上走动的动画我写出来了,那往下走动的动画,大家就要自己独立完成了,不要偷懒,一定要去写代码调试代码。瞪眼看只能了解知识,而能力是在真正的写代码、调试代码这种实践中培养起来的。

永不止步步 发表于01-28 10:25 浏览65535次
分享到:

已有0条评论

暂时还没有回复哟,快来抢沙发吧

添加一条新评论

只有登录用户才能评论,请先登录注册哦!

话题作者

永不止步步
金币:67410个|学分:308467个
立即注册
畅学电子网,带你进入电子开发学习世界
专业电子工程技术学习交流社区,加入畅学一起充电加油吧!

x

畅学电子网订阅号