找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4352|回复: 0
收起左侧

16*16点阵89c52单片机程序与仿真原理图

[复制链接]
ID:212000 发表于 2017-12-16 23:05 | 显示全部楼层 |阅读模式
之前画的板子早到手了,程序写好也能烧,使用正常,芯片用的是STC15F2K60S2,52的增强版,程序通用但有略微不同。系统性学了一遍51后又回头把程序改的更规范一点,程序里有注释,protuse的源文件看不了的话可以找我的第一篇帖子,里面也有原理图,不过有略微改动,以程序里的定义为准。
可以实现横向滚屏,用取模软件按图设置选项取模就好,滚屏速度按照程序里的提示改就好。

实物图:

实物图

实物图


取模软件的设置如下:
QQ截图20171216230354.png

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.jpg

单片机源程序如下:
  1. #include <reg51.h>
  2. #include<intrins.h>
  3. typedef unsigned int u16;
  4. typedef unsigned char u8;

  5. #define CS P1                    //位选

  6. sbit IO_1  =P0^0;                 //数据发送
  7. sbit CLK_1 =P0^1;            //移位时钟
  8. sbit Sent_1=P0^2;           //并行发送时钟

  9. sbit IO_2  =P0^3;
  10. sbit CLK_2 =P0^4;
  11. sbit Sent_2=P0^5;

  12. void dispiay();

  13. u8 code ledduan[]={
  14. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  15. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,

  16. 0x20,0x00,0x38,0x00,0x18,0x3E,0xEA,0x3E,0xEE,0x02,0xAC,0x02,0xA8,0x02,0xAF,0xFF,
  17. 0xAF,0xFF,0xA8,0x02,0xAC,0x12,0xEE,0x32,0xEA,0x3E,0x28,0x1E,0x38,0x00,0x18,0x00,/*"常",0*/

  18. 0x00,0x81,0xE0,0xC1,0xE0,0x70,0xFF,0x3F,0xFF,0x0F,0x20,0x00,0xE0,0x00,0xC0,0x00,
  19. 0xFE,0x3F,0xFE,0x3F,0x20,0x00,0xE0,0x00,0xC0,0x00,0xFF,0xFF,0xFF,0xFF,0x00,0x00,/*"州",1*/

  20. 0x00,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0xFC,0x3F,
  21. 0xFC,0x3F,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x00,0x20,/*"工",2*/

  22. 0x40,0x04,0x70,0x04,0x31,0x04,0x97,0x04,0x96,0x04,0x90,0x44,0x91,0xC4,0x97,0xFE,
  23. 0x96,0x7E,0x90,0x07,0x98,0x05,0x9C,0x04,0x17,0x04,0x53,0x04,0x70,0x04,0x30,0x04,/*"学",3*/

  24. 0x00,0x00,0xFE,0xFF,0xFE,0xFF,0x7A,0x0C,0xDE,0x0F,0x96,0x87,0x1C,0xC1,0x2C,0x71,
  25. 0x24,0x3F,0x25,0x0F,0x27,0x01,0x26,0x3F,0x24,0x7F,0x34,0x41,0x1C,0x71,0x0C,0x71,/*"院",4*/


  26. 0xF0,0x01,0xF8,0x03,0xFC,0x0F,0xFC,0x1F,0xFC,0x3F,0xF8,0x7F,0xF8,0x7F,0xF0,0xFF,
  27. 0xF0,0xFF,0xF8,0x7F,0xF8,0x7F,0xFC,0x3F,0xFC,0x1F,0xFC,0x0F,0xF8,0x03,0xF0,0x01,//爱心

  28. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  29. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,};

  30. u8 ledwei[]={
  31.                         0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
  32.                         0x08,0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F
  33.                         };


  34. void main()
  35. {        
  36.         CS=0;

  37.         while(1)
  38.         {        
  39.                 dispiay();
  40.         }
  41. }

  42. void sendby1(unsigned char dat)
  43. {
  44.          u8 mask;

  45.          CLK_1=0;
  46.          Sent_1=0;

  47.          for (mask=0x80;mask!=0;mask>>=1)
  48.          {
  49.                  if((mask&dat)!=0)
  50.                         IO_1=1;
  51.                 else
  52.                         IO_1=0;

  53.                  CLK_1=1;
  54.                  _nop_();
  55.                 _nop_();
  56.                  CLK_1=0;
  57.           }
  58.           Sent_1=1;
  59.           _nop_();
  60.       _nop_();
  61.           Sent_1=0;
  62. }

  63. void sendby2(unsigned char dat)
  64. {
  65.          u8 mask;

  66.          CLK_2=0;
  67.          Sent_2=0;

  68.          for (mask=0x80;mask!=0;mask>>=1)
  69.          {
  70.                  if((mask&dat)!=0)
  71.                         IO_2=1;
  72.                 else
  73.                         IO_2=0;

  74.                  CLK_2=1;                   //时钟脉冲,移位
  75.                  _nop_();
  76.                 _nop_();
  77.                  CLK_2=0;
  78.           }
  79.           Sent_2=1;                           //8位串行发送完毕,并行输出时钟输出
  80.           _nop_();
  81.       _nop_();
  82.           Sent_2=0;
  83. }

  84. void dispiay()
  85. {
  86.         static u8 cont=0;
  87.         static u16 incres=0;
  88.         u8 i=0;
  89.         u8 index=0;

  90.         for(i=0;i<16;i++)           //发送一帧图像
  91.         {        
  92.                 sendby1(0x00);
  93.                 sendby2(0x00);

  94.                 CS=ledwei[i];

  95.                 sendby1(ledduan[index+incres]);
  96. ……………………

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

所有资料51hei提供下载:
16点阵滚屏.zip (2.93 MB, 下载次数: 28)

评分

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

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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