本帖最后由 BSFBSAKJFN 于 2017-5-25 15:13 編輯
單片機LED點陣顯示方法與程序代碼 點陣的接法有共陰和共陽兩種(共陽指的是對每一行LED來講是共陽)。file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wpsC1DF.tmp.png
顯示的方法有兩種:
1、逐列掃描方式。如下圖所示,P1口輸出列碼決定哪一列能亮(相當于位碼),P2口輸出行碼(列數據)決定列上哪些LED亮(相當于段碼),能亮的列從左向右掃描完8列(相當于位碼循環移位8次)即顯示出一幀完整的圖像。
2、逐行掃描方式,與逐列掃描調換,即P2口輸出位碼,P1口輸出段碼,掃描完8行顯示出一幀圖。
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wpsC1F0.tmp.jpg
一、行掃描靜態顯示,
用51單片機實現上圖靜態顯示的程序如下:
#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
uchar code TAB[]={0x81,0xFD,0xFD,0xC1,0xBF,0xBF,0xBD,0xC3};
uchar i,t;
delay(uchar t)
{
while (t--)
{;}
}
void main(void)
{
while(1)
{
P2=0x01;
for(i=0;i<8;i++)
{
P1=TAB;
delay(100);
P2=P2<<1|P2>>7;
}
}
}
二、行掃描翻頁顯示
字碼取模方式為逐行
第一次從字碼數組中取出第1~8個數據置于列上,行掃描順序為1~8行,顯示一幀,第二次取第9~16個數據,行掃描順序仍為1~8行,顯示第二幀,第三次取第17~24個數據,……
實現圖顯示效果的程序如下:
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wpsC1F1.tmp.jpg
/*8X8行掃描,翻頁顯示*/
#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
uchar code TAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏
0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF, //L
0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF, //O
0xDD,0xDD,0xDD,0xDD,0xDD,0xEB,0xF7,0xFF, //V
0xC1,0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF, //E
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏
};
uchar i,t;
delay(uchar t)
{
while (t--)
{;}
}
void main(void)
{ uchar N,T;
while(1)
{
for(N=0;N<6;N++) //循環掃描一遍6幀
for(T=0;T<100;T++) //速度
{
P2=0x01;
for(i=0;i<8;i++)
{
P1=TAB[i+8*N];
delay(100);
P2=P2<<1|P2>>7;
}
}
}
}
三、行掃描上下移動顯示。
如果是逐行取字模時,第一次從字碼數組中取出第1~8個數據置于列上,行掃描順序為1~8行,顯示一幀,第二次取第2~9個數據,行掃描順序仍為1~8行,顯示第二幀,……如此便是向上移動。如果將上述的行掃描順序改為8~1行,就是向下移動,但顯示的圖像是倒立的了,為了使得它不倒立,詳細請看程序。另外取模方式不同,就有不同的編程方式。
顯示圖上移效果的程序如下:
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wpsC1F2.tmp.jpg
/*8X8行掃描,上移顯示*/
#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
uchar code TAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏
0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF, //L
0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF, //O
0xDD,0xDD,0xDD,0xDD,0xDD,0xEB,0xF7,0xFF, //V
0xC1,0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF, //E
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏
};
uchar i,t;
delay(uchar t)
{
while (t--)
{;}
}
void main(void)
{ uchar N,T;
while(1)
{
for(N=0;N<40;N++) //循環掃描一遍40幀
for(T=0;T<60;T++) //移動速度
{
P2=0x01;
for(i=0;i<8;i++)
{
P1=TAB[i+N];
delay(100);
P2=P2<<1|P2>>7;
}
}
}
}
顯示圖下移效果的程序如下:
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wpsC203.tmp.jpg
/*8X8行掃描,下移顯示*/
#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
uchar code TAB[]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏
0xFD,0xFD,0xFD,0xFD,0xFD,0xFD,0xC1,0xFF, //L
0xE3,0xDD,0xDD,0xDD,0xDD,0xDD,0xE3,0xFF, //O
0xDD,0xDD,0xDD,0xDD,0xDD,0xEB,0xF7,0xFF, //V
0xC1,0xFD,0xFD,0xC1,0xFD,0xFD,0xC1,0xFF, //E
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, //空屏
};
uchar idata Buffer[48]={0}; //緩存顯示單元
uchar i,t;
delay(uchar t)
{
while (t--)
{;}
}
void main(void)
{
uchar N,T,m,n;
for(m=0;m<6;m++)
for(n=0;n<8;n++)
Buffer[8*m+n]=TAB[7-n+m*8]; //將TAB數組中的數據重新排列
//使得下移字母順序不變
while(1)
{
for(N=0;N<40;N++) //循環掃描一遍6幀
for(T=0;T<70;T++) //速度
{
P2=0x80;
for(i=0;i<8;i++)
{
P1=Buffer[i+N];
delay(100);
P2=P2>>1|P2<<7; //掃描起始行為第一行
}
}
}
} 四、行掃描左右移動顯示。
如果將掃描方式改為列掃描,那么左右移動的程序就容易寫了,但當點陣比較巨大并且硬件已經定下時,改變掃描方式不是好方法,甚至不可能實現。這里是以行掃描為例(逐行取字模),第一次取字碼數組中的第1~8個數據到點陣列輸入端,行碼 掃描1~8行。第二次將第一次的 1~8個數據都循環左(右)移一位,并且將第9個數據的最高位移到第二次數據的最低處,再輸入到列端口,行掃描1~8行。即每次掃描都要把前一次掃描的列碼左移一位。
圖為左移效果,程序如下:
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wpsC204.tmp.jpg
/*8X8行掃描,左移顯示*/
#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
uchar code TAB[]={0xFF,0xF7,0xFB,0x81,0xFB,0xF7,0xFF,0xFF};
uchar i,t,j=0;
delay(uchar t)
{
while (t--)
{;}
}
void main(void)
{ uchar T,Y,Q;
while(1)
{
for(Q=0;Q<8;Q++)
for(T=0;T<100;T++) //速度
{
P2=0x01;
for(i=0;i<8;i++)
{
Y=TAB[i+1]*256+TAB; Y=Y<<(7-Q)|Y>>Q;
P1=Y%256;
delay(60);
P2=P2<<1|P2>>7;
}
}
}
} 僅供參考
file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wpsC205.tmp.jpg
|