給你修正了2處錯誤,見紅色字體部分,我在51hei-5開發(fā)板上已經(jīng)可以正常運(yùn)行,這其實就是個動態(tài)掃描的慢動作,也就是靜態(tài)顯示,如果要改為動態(tài)掃描顯示連續(xù)的123456, 只需加快速度,加入消隱部分 即可.
#include<reg52.h> #include<intrins.h>//參數(shù)左移頭文件 #define uint unsigned int #define uchar unsigned char uchar temp,aa,numdu,numwe; sbit dula=P2^6;//定義dula sbit wela=P2^7;//定義wela uchar code table[]={ 0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71};//數(shù)給的格試uchar code table[]={}在{}中要寫入數(shù)據(jù) uchar code tablewe[]={ 0xfe,0xfd,0xfb,0xf7,0xef,0xdf};
void main() { numdu=0; numwe=0; aa=0; TMOD=0x01;//對TMOD付值也可寫:TMOD=1; TH0=(65536-50000)/256;//THO初值,"/"為求莫,(65536-50000)/256放到高8位中 TL0=(65536-50000)%256;//HO初值,"*"為求余,(65536-50000)%256放到低8位中 EA=1;//開總中斷 ET0=1;//開定時器中斷 TR0=1;//啟動定時器 /*定時器/計數(shù)器設(shè)置流程 1對TMOD賦值,以確定T0及T1的工作方式; 2計算初值,并將其值寫入TH0,TL0或TH1,TL1中; 3中斷方式時,則對IE賦值,開放中斷; 4致TR0或TR1置位,啟動定時/計數(shù)器定時或計數(shù) */ while(1) { if(aa==20) //原來是錯誤的,你用的賦值符號應(yīng)該要用 == 號 { numdu++; if(numdu==7) numdu=1; P0=table[numdu]; //送段 dula=1; dula=0; P0=tablewe[numwe]; //送位 wela=1; wela=0;
numwe++; if(numwe==6) numwe=0;
aa=0; //你原來的程序沒有置0 } } } void timer0() interrupt 1 { TH0=(65536-50000)/256; TL0=(65536-50000)%256; aa++; }
[此貼子已經(jīng)被作者于2010-8-10 17:24:28編輯過]
|