Ps:
使用的是51单片机, 晶振为11.0592M的, 时间选择5ms。
这篇博客好像是第一篇单片机博客诶~。
算法:
简单的计时器应用, 最开始 根据 2^16 - (t - f)/12 计算得到值, 将其转换为16进制 (注意:单位的改变, 例如晶振要乘上 10e6 时间 要转换为秒s 乘上 10e-3)
由此可以得到 TH0/TL0的值。
例如:
设计的是5ms, 则 算式为 2^16 - (5 * 10^-3 - 11.0592 * 10^6) / 12; 转换为16进制 为DC00; 所以 TH0 = 0XDC __ TL0 = 0X00;
显示:
拆字什么的 就不说了~~, 反正就是 分和秒 对 10取余 和 整除。
下面函数中的 counter 和 second 分别对应 秒和分。
Hint:
老师说, 最好在 tmp=counter%4; 前 加上 if(changed == 1)执行拆字显示, 然后再将执行空语句 如此循环。 但还是不怎么明白为什么。 好像是说 保护 IO 之类的~~~~
#include #define uchar unsigned char uchar counter=0,tmp,second=0,minute=0, changed = 1; main() { //TMOD=0X21; //设置TMOD寄存器 TMOD=0X01; //设置TMOD寄存器 TH0=0xDc; //装初值 TL0=0x00; //TH1=0XFD; //TL1=0; //TR1=1; //SCON=0X50; EA=1; //开 中断 ET0=1; TR0=1; while(1) { char a[10] = {0xc0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90}; //拆字 //显示 tmp=counter%4; switch(tmp) { case 0:{ P2 = 0x7f; P0 = a[second%10]; } break; case 1:{ P2 = 0xbf; P0 = a[second/10]; } break; case 2: { P2 = 0xdf; P0 = a[minute%10]; } break; case 3: { P2 = 0xef; P0 = a[minute/10]; } break; } } /* if(j==2) { j=0; P2=~P2; } */ } void zhongduan()interrupt 1 { TH0=0xee; //装初值 TL0=0x00; TF0=0; TR0=1; /* i++; if(i>=5) { i=0; //SBUF=j; //while(!TI); //TI=0; j++; } */ counter++; if(counter==200) { counter=0; second++; if(second==60) { second=0; minute++; } } }
上一篇:51单片机复习:8*8led点阵
下一篇:单片机 简单时钟
推荐阅读最新更新时间:2024-11-10 21:38
设计资源 培训 开发板 精华推荐
- 基于 ICL8810 的 43 W 高功率因数恒压输出反激式转换器
- 1A,60V Vin,基于LED6000的降压LED驱动器板
- L6234 三相电机驱动器应用说明
- REF193 精密微功耗、低压差电压基准的典型应用
- DC1190A-A、LTC2366 演示板、12 位、3Msps SAR ADC
- EVAL-AD5758SDZ,用于评估具有动态功率控制和 HART 连接功能的 AD5758 单通道、16 位电流和电压输出 DAC 的评估板
- AM1G-4807DZ ±7.2V 1 瓦 DC-DC 转换器的典型应用
- PCM1754解码板
- 使用 LT3013 5V、250mA 电源的设计电路提供 PWRGD 标志
- 具有 1.25% 参考和可调滞后的 MIC841LYC5 比较器的典型应用