之前畫的板子早到手了,程序?qū)懞靡材軣褂谜,芯片用的是STC15F2K60S2,52的增強版,程序通用但有略微不同。系統(tǒng)性學(xué)了一遍51后又回頭把程序改的更規(guī)范一點,程序里有注釋,protuse的源文件看不了的話可以找我的第一篇帖子,里面也有原理圖,不過有略微改動,以程序里的定義為準(zhǔn)。
可以實現(xiàn)橫向滾屏,用取模軟件按圖設(shè)置選項取模就好,滾屏速度按照程序里的提示改就好。
實物圖:
1513435921996.jpg (3.06 MB, 下載次數(shù): 45)
下載附件
實物圖
2017-12-16 22:56 上傳
取模軟件的設(shè)置如下:
QQ截圖20171216230354.png (60.03 KB, 下載次數(shù): 57)
下載附件
2017-12-16 23:04 上傳
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
0.jpg (160.57 KB, 下載次數(shù): 49)
下載附件
2017-12-16 23:23 上傳
單片機源程序如下:
- #include <reg51.h>
- #include<intrins.h>
- typedef unsigned int u16;
- typedef unsigned char u8;
- #define CS P1 //位選
- sbit IO_1 =P0^0; //數(shù)據(jù)發(fā)送
- sbit CLK_1 =P0^1; //移位時鐘
- sbit Sent_1=P0^2; //并行發(fā)送時鐘
- sbit IO_2 =P0^3;
- sbit CLK_2 =P0^4;
- sbit Sent_2=P0^5;
- void dispiay();
- u8 code ledduan[]={
- 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
- 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
- 0x20,0x00,0x38,0x00,0x18,0x3E,0xEA,0x3E,0xEE,0x02,0xAC,0x02,0xA8,0x02,0xAF,0xFF,
- 0xAF,0xFF,0xA8,0x02,0xAC,0x12,0xEE,0x32,0xEA,0x3E,0x28,0x1E,0x38,0x00,0x18,0x00,/*"常",0*/
- 0x00,0x81,0xE0,0xC1,0xE0,0x70,0xFF,0x3F,0xFF,0x0F,0x20,0x00,0xE0,0x00,0xC0,0x00,
- 0xFE,0x3F,0xFE,0x3F,0x20,0x00,0xE0,0x00,0xC0,0x00,0xFF,0xFF,0xFF,0xFF,0x00,0x00,/*"州",1*/
- 0x00,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0xFC,0x3F,
- 0xFC,0x3F,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x04,0x20,0x00,0x20,/*"工",2*/
- 0x40,0x04,0x70,0x04,0x31,0x04,0x97,0x04,0x96,0x04,0x90,0x44,0x91,0xC4,0x97,0xFE,
- 0x96,0x7E,0x90,0x07,0x98,0x05,0x9C,0x04,0x17,0x04,0x53,0x04,0x70,0x04,0x30,0x04,/*"學(xué)",3*/
- 0x00,0x00,0xFE,0xFF,0xFE,0xFF,0x7A,0x0C,0xDE,0x0F,0x96,0x87,0x1C,0xC1,0x2C,0x71,
- 0x24,0x3F,0x25,0x0F,0x27,0x01,0x26,0x3F,0x24,0x7F,0x34,0x41,0x1C,0x71,0x0C,0x71,/*"院",4*/
- 0xF0,0x01,0xF8,0x03,0xFC,0x0F,0xFC,0x1F,0xFC,0x3F,0xF8,0x7F,0xF8,0x7F,0xF0,0xFF,
- 0xF0,0xFF,0xF8,0x7F,0xF8,0x7F,0xFC,0x3F,0xFC,0x1F,0xFC,0x0F,0xF8,0x03,0xF0,0x01,//愛心
- 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
- 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,};
- u8 ledwei[]={
- 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
- 0x08,0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F
- };
- void main()
- {
- CS=0;
- while(1)
- {
- dispiay();
- }
- }
- void sendby1(unsigned char dat)
- {
- u8 mask;
- CLK_1=0;
- Sent_1=0;
- for (mask=0x80;mask!=0;mask>>=1)
- {
- if((mask&dat)!=0)
- IO_1=1;
- else
- IO_1=0;
- CLK_1=1;
- _nop_();
- _nop_();
- CLK_1=0;
- }
- Sent_1=1;
- _nop_();
- _nop_();
- Sent_1=0;
- }
- void sendby2(unsigned char dat)
- {
- u8 mask;
- CLK_2=0;
- Sent_2=0;
- for (mask=0x80;mask!=0;mask>>=1)
- {
- if((mask&dat)!=0)
- IO_2=1;
- else
- IO_2=0;
- CLK_2=1; //時鐘脈沖,移位
- _nop_();
- _nop_();
- CLK_2=0;
- }
- Sent_2=1; //8位串行發(fā)送完畢,并行輸出時鐘輸出
- _nop_();
- _nop_();
- Sent_2=0;
- }
- void dispiay()
- {
- static u8 cont=0;
- static u16 incres=0;
- u8 i=0;
- u8 index=0;
- for(i=0;i<16;i++) //發(fā)送一幀圖像
- {
- sendby1(0x00);
- sendby2(0x00);
- CS=ledwei[i];
- sendby1(ledduan[index+incres]);
- ……………………
- …………限于本文篇幅 余下代碼請從51黑下載附件…………
復(fù)制代碼
0.jpg (13.39 KB, 下載次數(shù): 62)
下載附件
2017-12-16 23:23 上傳
所有資料51hei提供下載:
16點陣滾屏.zip
(2.93 MB, 下載次數(shù): 28)
2017-12-16 22:57 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
|