找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4841|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

16*16點陣89c52單片機程序與仿真原理圖

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:212000 發(fā)表于 2017-12-16 23:05 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
之前畫的板子早到手了,程序?qū)懞靡材軣褂谜,芯片用的是STC15F2K60S2,52的增強版,程序通用但有略微不同。系統(tǒng)性學(xué)了一遍51后又回頭把程序改的更規(guī)范一點,程序里有注釋,protuse的源文件看不了的話可以找我的第一篇帖子,里面也有原理圖,不過有略微改動,以程序里的定義為準(zhǔn)。
可以實現(xiàn)橫向滾屏,用取模軟件按圖設(shè)置選項取模就好,滾屏速度按照程序里的提示改就好。

實物圖:


取模軟件的設(shè)置如下:


仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  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;                 //數(shù)據(jù)發(fā)送
  7. sbit CLK_1 =P0^1;            //移位時鐘
  8. sbit Sent_1=P0^2;           //并行發(fā)送時鐘

  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,/*"學(xué)",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位串行發(fā)送完畢,并行輸出時鐘輸出
  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++)           //發(fā)送一幀圖像
  91.         {        
  92.                 sendby1(0x00);
  93.                 sendby2(0x00);

  94.                 CS=ledwei[i];

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

  97. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復(fù)制代碼


所有資料51hei提供下載:
16點陣滾屏.zip (2.93 MB, 下載次數(shù): 28)




評分

參與人數(shù) 1黑幣 +100 收起 理由
admin + 100 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏2 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表