西安工业大学毕业设计(论文) TF1 = 0; //d定时器 T1用于数码管的动态刷新
TH1 = 0xD8; //初始化 TL1 = 0xF0;
Flag_Fresh = 1;
Tcounter++;
if(Tcounter>TIME_CYLC)
{ Flag_clac = 1;//周期到,该重新计算转速了 } }
void it_timer0() interrupt 1 /* interrupt address is 0x000b */ {
TF1 = 0; //定时器T0用于单位时间内收到的脉冲数 //要速度不是很快,T0永远不会益处
Flag_Err = 1; //如果速度很高,我们应考虑另外一种测速方法,:脉冲 宽度算转速 }
void main(void) {
Disbuf[0] = 0; //开机时,初始化为0000 Disbuf[1] = 0; Disbuf[2] = 0; Disbuf[3] = 0;
init_timer0(); init_timer1();
while(1) {
if(!P1^0)
{ Delay(10) ; //防按键抖动 if(!P1^0)
{ if(Flag_Fresh)
{ Flag_Fresh = 0;
DisplayFresh();//定时刷新数码管显示 }
if(Flag_clac) { Flag_clac = 0;
ClacSpeed(); //计算转速,并把结果放入数码管缓冲区 Tcounter = 0; //周期定时清零 TH0=TL0 = 0x00;//脉冲计数清零
31
西安工业大学毕业设计(论文)
} }
//在数码管上显示一个四位数 void DisplayFresh() {
P0 |= 0xF0; LED_SEG0 = 0;
LED_DAT = table[Disbuf[0]]; Delay(5);
P0 |= 0xF0; LED_SEG1 = 0;
LED_DAT = table[Disbuf[1]]; Delay(5);
P0 |= 0xF0; LED_SEG2 = 0;
LED_DAT = table[Disbuf[2]]; Delay(5);
P0 |= 0xF0; LED_SEG3 = 0;
LED_DAT = table[Disbuf[3]]; Delay(5); P0 |= 0xF0; }
}
if(Flag_Err) //超量程处理 {
//数码管显示字母‘EEEE’
Disbuf[0] = 0x84; //开机时,初始化为0000 Disbuf[1] = 0x84; Disbuf[2] = 0x84; Disbuf[3] = 0x84; while(1)
{ DisplayFresh();}//不再测速 等待复位i } } }
//计算转速,并把结果放入数码管缓冲区 void ClacSpeed() {uint speed;
32
西安工业大学毕业设计(论文) uint PlusCounter;
PlusCounter = TH0*256 + TL0;
speed = K*(PlusCounter/PLUS_PER);//K是校准系数,如速度不准,调节K的大小
Disbuf[0] = (speed/1000); Disbuf[1] = (speed/100); Disbuf[2] = (speed/10); Disbuf[3] = speed; }
//初始化定时器T1 void init_timer1() {
TMOD= 0xF1; /* GATE0=0; C/T0#=0; M10=0; M00=1; */ TH1= 0xD8; //初始化 TL1= 0xF0;
ET1=1; //允许T1中断 EA=1; //开放中断 TR1=1; //运行T1 }
//延时函数
void Delay(uint ms) {
uchar i; while(ms--)
for(i=0;i<1000;i++); }
//初始化定时器T0 void init_timer0() {
TMOD = 0x50; /* GATE0=0; C/T0#=1; M10=0; M00=1; */ TH0 = 0x00; //初始化 TL0 = 0x00;
ET0=1; //允许T0中断 EA=1; //开放中断 TR0=1; //运行T0 }
33