标题: 51单片机8*8点阵移动仿真与源码 [打印本页]

作者: 19960601    时间: 2018-2-3 13:58
标题: 51单片机8*8点阵移动仿真与源码
51单片机为主控芯片,74LS595驱动行,74LS138驱动列,实现上下左右的平移,同时可以扩展为16*16的点阵屏

无标题1.png (262.06 KB, 下载次数: 53)

这是程序

这是程序

无标题.png (245.35 KB, 下载次数: 44)

这是proteus仿真

这是proteus仿真

点阵.zip

61.84 KB, 下载次数: 67, 下载积分: 黑币 -5


作者: admin    时间: 2018-2-4 02:13

单片机源程序如下:
  1. #include        "reg51.h"
  2. #include        "intrins.h"
  3. sbit                sck=P2^0;
  4. sbit                rck=P2^2;
  5. sbit                ser=P2^1;
  6. #define                uchar         unsigned char
  7. #define         uint          unsigned int
  8. uchar                dat1[8]={0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07};                         //列数组
  9. uchar       dat2[8]={0x00,0x66,0x99,0x81,0x81,0x42,0x24,0x18};                        //行数组
  10. void sendrowbyte(uchar Val)                                        //74ls595驱动行
  11. {
  12.         uchar i=0;
  13.         sck=1;
  14.         for(i=0;i<8;i++)
  15.         {
  16.                 if(Val&0x80)        ser=1;
  17.                 else                        ser=0;
  18.                 Val<<=1;
  19.                 sck=0;
  20.                 sck=1;
  21.         }       
  22.         rck=0;
  23.         rck=1;
  24. }
  25. void sendcolbyte(uchar Val)                                        //74ls138驱动列
  26. {
  27.         switch(Val)
  28.         {
  29.                 case 0:P3=dat1[0];break;
  30.                 case 1:P3=dat1[1];break;
  31.                 case 2:P3=dat1[2];break;
  32.                 case 3:P3=dat1[3];break;
  33.                 case 4:P3=dat1[4];break;
  34.                 case 5:P3=dat1[5];break;
  35.                 case 6:P3=dat1[6];break;
  36.                 case 7:P3=dat1[7];break;
  37.                 default:                     break;
  38.         }
  39. }
  40. void MOVE_RIGHT(void)                                                  //右移函数
  41. {
  42.         uchar i;
  43.         for(i=0;i<8;i++)
  44.         dat2[i]=_crol_(dat2[i],1);
  45. }
  46. void MOVE_LEFT(void)                                                  //左移函数
  47. {
  48.         uchar i;
  49.         for(i=0;i<8;i++)
  50.         dat2[i]=_cror_(dat2[i],1);
  51. }
  52. void MOVE_DOWN(void)                                                //上移函数
  53. {
  54.         uchar i;
  55.         uchar t=dat1[0];
  56.         for(i=0;i<7;i++)
  57.                 dat1[i]=dat1[i+1];
  58.         dat1[7]=t;
  59. }
  60. void MOVE_UP(void)                                                        //下移函数
  61. {
  62.         uchar i;
  63.         uchar t=dat1[7];
  64.         for(i=7;i>0;i--)
  65.                 dat1[i]=dat1[i-1];
  66.         dat1[0]=t;
  67. }
  68. void TIMER0_init(void)
  69. {
  70.         TMOD=0x01;
  71.         TH0=0xfc;
  72.         TL0=0x66;
  73.         TR0=1;
  74.         EA =1;
  75.         ET0=1;
  76. }
  77. void main(void)
  78. {
  79.         TIMER0_init();
  80.         while(1)
  81.         {
  82.                 ;
  83.         }
  84. }
  85. void TIMER0_Interrupt(void) interrupt 1
  86. {
  87.         static uchar i     =0;
  88.         static uchar kcount=0;
  89.         static uchar kmode =0;
  90.         static uint  tim   =0;
  91.         TH0=0xfc;
  92.         TL0=0x66;
  93.         tim++;
  94.         if(tim==500)                                                        //移动的间隔,为500ms
  95.         {
  96.                 tim=0;
  97.                 if(kcount == 8)                                                //移动的步数,为8的整数倍才会移动的完整
  98.                 {
  99.                         kcount=0;
  100.                         kmode++;
  101.                         if(kmode==4)        kmode=0;
  102.                 }
  103. ……………………

  104. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
一楼



0.png (57.44 KB, 下载次数: 48)

0.png

作者: zx1v    时间: 2018-4-10 18:18
good!




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1