網絡整理 發表於 2020-11-12 14:46:54
led點陣的引腳圖如下:
測量方法:用能把LED點亮的萬用表量,大多數的數字萬用表可以點亮LED,只是非常暗淡,有些用兩隻1.5V電池的指針萬用表可以把LED點得很亮,只用一個1.5V電池的指針萬用表不能點亮LED,其實最簡單的方法是用5V電源,串個1K電阻,就可以判斷清楚LED點陣。也可以用數字表中的二極體檔,直接測結壓降,通常正向時,結壓降會有顯示(此時LED可能會被點亮),反向時,結壓降基本上是無窮大(萬用表測不出來),這種點陣一般是8X8矩陣。
led點陣的應用led點陣的應用
1、在8X8 LED點陣上顯示柱形,讓其先從左到右平滑移動三次,其次從右到左平滑移動三次,再次從上到下平滑移動三次,最後從下到上平滑移動三次,如此循環下去。
分析:此任務是比較簡單的,最基礎的LED點陣顯示應用。只需設置顯示的起始地址(即起始狀態),列出LED行掃描、列掃描的順序輸出,再設置一個延時即可循環顯示。
源程序:
#include 《AT89X52.H》
unsigned char code taba[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//行掃描顯示編碼
unsigned char codetabb[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//列掃描顯示編碼
void delay(void)//設置延時
{
unsigned char i,j;
for(i=10;i》0;i--)
for(j=248;j》0;j--);
}
void delay1(void)
{
unsigned char i,j,k;
for(k=10;k》0;k--)
for(i=20;i》0;i--)
for(j=248;j》0;j--);
}
void main(void)
{
unsigned char i,j;
while(1)
{
for(j=0;j《3;j++)//從左向右三次
{
for(i=0;i《8;i++)
{
P3=taba;
P1=0xff;
delay1();
}
}
for(j=0;j《3;j++)//從右向左三次
{
for(i=0;i《8;i++)
{
P3=taba[7-i];
P1=0xff;
delay1();
}
}
for(j=0;j《3;j++)//從上向下三次
{
for(i=0;i《8;i++)
{
P3=0x00;
P1=tabb[7-i];
delay1();
}
}
for(j=0;j《3;j++)//從下向上三次
{
for(i=0;i《8;i++)
{
P3=0x00;
P1=tabb;
delay1();
}
}
}
}
2、 數字0-9點陣循環顯示
分析:重點是數字0-9點陣顯示代碼的形成:
如下圖所示,假設顯示數字「0」
1 2 3 4 5 6 7 8
00 00 3E 41 41 41 3E00
因此,形成的列代碼為 00H,00H,3EH,41H,41H,3EH,00H,00H;只要把這些代碼分別送到相應的列線上面,即可實現「0」的數字顯示。
同理,其他數字的顯示代碼可以由上可得。
實驗程序框圖:
源程序
#include 《AT89X52.H》
unsigned char codetab[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
unsigned char codedigittab[10][8]={{0x00,0x00,0x3e,0x41,0x41,0x41,0x3e,0x00}, //0
{0x00,0x00,0x00,0x00,0x21,0x7f,0x01,0x00}, //1
{0x00,0x00,0x27,0x45,0x45,0x45,0x39,0x00}, //2
{0x00,0x00,0x22,0x49,0x49,0x49,0x36,0x00}, //3
{0x00,0x00,0x0c,0x14,0x24,0x7f,0x04,0x00}, //4
{0x00,0x00,0x72,0x51,0x51,0x51,0x4e,0x00}, //5
{0x00,0x00,0x3e,0x49,0x49,0x49,0x26,0x00}, //6
{0x00,0x00,0x40,0x40,0x40,0x4f,0x70,0x00}, //7
{0x00,0x00,0x36,0x49,0x49,0x49,0x36,0x00}, //8
{0x00,0x00,0x32,0x49,0x49,0x49,0x3e,0x00} //9
};
unsigned int timecount;
unsigned char cnta;
unsigned char cntb;
void main(void)
{
TMOD=0x01;//啟用定時器方式1
TH0=(65536-3000)/256;//定時3ms
TL0=(65536-3000)%256;
TR0=1;
ET0=1;
EA=1;
while(1)
{;
}
}
void t0(void) interrupt 1 using 0
{
TH0=(65536-3000)/256;
TL0=(65536-3000)%256;
P3=tab[cnta];
P1=digittab[cntb][cnta];
cnta++;
if(cnta==8)
{
cnta=0;
}
timecount++;
if(timecount==333)
{
timecount=0;
cntb++;
if(cntb==10)
{
cntb=0;
}
}
}
責任編輯:YYX
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容圖片侵權或者其他問題,請聯繫本站作侵刪。 侵權投訴