現在我們讓4位數碼管顯示4位數字,這里用的動態掃描法。這里說一個這個寫這個程序要注意的地方:
本文引用地址:http://www.104case.com/article/201611/319948.htm1 動態描的循序。首先是將數據送入段選端,再打開要顯示位的位選端,再延時,最后就是開閉所有的位選端。這個如果沒有處理好很容易出現鬼影。
2 延時。我這里是延時5ms。看了下延時效果還不錯。
關鍵是理解動態掃描的思想:我們先點亮第一位數碼管,亮5ms.再點亮第二位數碼管,亮5ms.這時第一位是不亮的,如此循環下去。因為人眼5ms反映不過來,看上去就是4位數碼管都是亮的。
比較簡陋的源程序:
#include <avr/io.h> //IO口頭文件調用
#include
#define uchar unsigned char //申明
#define uint unsigned int
uchar reg[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff}; //8位數碼管字型編碼表
int main(void)
{
DDRB = 0xff; //這兩行表示設制IO寄存器為輸出
DDRC = 0xff;
while(1)
{
PORTC = reg[0]; //送數據到第一位數碼管
PORTB = 0xfe; //打開第一位數碼管位選端
_delay_ms(5); //延時5MS
PORTB = 0xff; //關閉第一位數碼管位選端
PORTC = reg[5];
PORTB = 0xfd;
_delay_ms(5);
PORTB = 0xff;
PORTC = reg[1];
PORTB = 0xfb;
_delay_ms(5);
PORTB = 0xff;
PORTC = reg[0];
PORTB = 0xf7;
_delay_ms(5);
PORTB = 0xff;
}
}
評論