另外定时器计数器1是16位的 建议换成0或者2足矣 另外 最好别用PC端口 PC是烧flash的 用它易出问题
我给你写的,主循环中没用循环语句,因为只显示2位没必要。
//省略宏
uint pp = 0
int time_1s = 0, time_8ms, time
ISR(TIMER2_OVF_vect) //Time2 溢出中断
{
TCNT2 = 0x83
time_8ms = 1
if(time_8ms == 1)
{
timexs_8ms = 0
if(++time >= 125)
{
time_1s = 0
++pp
}
}
}
void Init_T2()
{
TCCR2 = 0x04 //1M晶振 64分频 普通模式 1M/64=15.625K
TCNT2 = 0x83 // (256-130-1)/15.625K= 8ms
TIMSK |= 0x40
}
int main()
{
uchar num,num_1,num_10
DDRA=0xFF
DDRB=0x02
PORTA = 0xff
PORTB = 0xff
Init_T2()
asm("sei")
while(1)
{
num = pp
num_1 = num % 10
num_10 = num / 10
if(num >60)num = 0
else {
PORTA = table[num_1]
PORTB = 0xfe
PORTA = table[num_10]
PORTB = 0xfd
_delay_ms(5)
}
}
#include<reg51.h>#include "intrins.h"
#include "absacc.h"
#define uchar unsigned char
uchar code ledtab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40,0xff}//0-9
unsigned char sec=0,min=0,scanled
unsigned char key=0,mode,time
unsigned char disdat[4]
void dischg()
{
disdat[3]=sec%10
disdat[2]=sec/10
disdat[1]=min
disdat[0]=10
}
void ext0() interrupt 0
{
key++
key%=3
}
void t0isr() interrupt 1 //秒计时
{
TH0=0x3c
TL0=0xb0
time++
if(time==20)
{
time=0
sec++
if(sec>59)
{
sec=0
min++
if(min>9)min=0
}
}
dischg()
}
void t1isr() interrupt 3 //显示
{
TH1=0xec
TL1=0x78
P0=0xff
switch(scanled)
{
case 1:
P2=0x02
P0=~(ledtab[disdat[1]]|0x80)
break
case 2:
P2=0x04
P0=~ledtab[disdat[2]]
break
case 3:
P2=0x08
P0=~ledtab[disdat[3]]
break
default:break
}
scanled++
scanled%=4
}
main()
{
TMOD=0x11
TH0=0x3c
TL0=0xb0
TH1=0xec
TL1=0x78
TR1=1
TR0=0
ET0=1
ET1=1
EX0=1
IT0=1
EA=1
scanled=0
time=0
mode=1
dischg()
while(1)
{
switch(key)
{
case 0:TR0=0break
case 1:TR0=1break
case 2:sec=0min=0break
}
}
}
/*-----------------------------------------------数码管显示,按键控制秒表
中断按键控制,数码管显示,中断0控制计时和停止,中断1清零
------------------------------------------------*/
#include<reg52.h>//包含头文件,一般情况不需要改动,头文件包含特殊功能寄存器的定义
unsigned int second//定义全局变量
bit GoFlag//定义停止,计时标志
#define DataPort P0 //定义数据端口 程序中遇到DataPort 则用P0 替换
sbit LATCH1=P2^2//定义锁存使能端口 段锁存
sbit LATCH2=P2^3// 位锁存
unsigned char code dofly_DuanMa[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}//显示段码值0~9
unsigned char codedofly_WeiMa[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f}//分别对应相应的数码管点亮,即位码
unsigned char TempData[8]//存储显示值的全局变量
void DelayUs2x(unsigned char t)//函数声明
void DelayMs(unsigned char t)
void Display(unsigned char FirstBit,unsigned char Num)
void Init_Timer0(void)
void CLR(void)
/*------------------------------------------------
主函数
------------------------------------------------*/
void main (void)
{
unsigned char num=0
EX0=1//外部中断0开
IT0=1//IT1=0表示边沿触发
EX1=1//外部中断1开
IT1=1//IT1=1表示边沿触发
Init_Timer0()
while (1) //主循环
{
TempData[0]=dofly_DuanMa[second/10]//分解显示信息,如要显示68,则68/10=6 68%10=8
TempData[1]=dofly_DuanMa[second%10]
//主循环中添加其他需要一直工作的程序
}
}
/*------------------------------------------------
显示函数,用于动态扫描数码管
输入参数 FirstBit 表示需要显示的第一位,如赋值2表示从第三个数码管开始显示
如输入0表示从第一个显示。
Num表示需要显示的位数,如需要显示99两位数值则该值输入2
------------------------------------------------*/
void Display(unsigned char FirstBit,unsigned char Num)
{
static unsigned char i=0
DataPort=0 //清空数据,防止有交替重影
LATCH1=1//段锁存
LATCH1=0
DataPort=dofly_WeiMa[i+FirstBit]//取位码
LATCH2=1//位锁存
LATCH2=0
DataPort=TempData[i]//取显示数据,段码
LATCH1=1//段锁存
LATCH1=0
i++
if(i==Num)
i=0
}
/*------------------------------------------------
定时器初始化子程序
------------------------------------------------*/
void Init_Timer0(void)
{
TMOD |= 0x01 //使用模式1,16位定时器,使用"|"符号可以在使用多个定时器时不受影响
//TH0=0x00 //给定初值
//TL0=0x00
EA=1 //总中断打开
ET0=1 //定时器中断打开
TR0=1 //定时器开关打开
}
/*------------------------------------------------
定时器中断子程序
------------------------------------------------*/
void Timer0_isr(void) interrupt 1
{
static unsigned char num
TH0=(65536-20000)/256 //重新赋值 20ms
TL0=(65536-20000)%256
Display(0,8)
if(GoFlag)
{
num++
if(num==5)
second++//秒加1
if(second==10)
second=0
}
}
/*------------------------------------------------
外部中断0程序
------------------------------------------------*/
void ISR_INT0(void) interrupt 0
{
GoFlag=!GoFlag//利用外部中断打开和关闭定时标志 用于开始和停止计时
}
/*------------------------------------------------
外部中断1程序
------------------------------------------------*/
void ISR_INT1(void) interrupt 2
{
if(GoFlag==0)//停止时才可以清零
CLR()
}/*------------------------------------------------
数值清零
------------------------------------------------*/
void CLR(void)
{
second=0 //利用外部中断清零
msecond=0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)