定时器
一、将交通灯实验中数码管倒计时1s改为定时器实现
这个代码感觉逻辑上没问题,实际仿真出来倒计时的1s感觉要比实际的慢,可能是由于单片机执行语句时也需要耗费时间
实验仿真图如下
代码如下(示例):
#include <reg51.h>
#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
uchar code a[]={0x6f,0x7f,0x07,0x7d,0x6d,0x66,0x4f,0x5b,0x06,0x3f};
sbit red1=P2^0;
sbit green1=P2^1;
sbit red2=P2^5;
sbit green2=P2^6;
sbit yellow=P2^7;
char i=0;
void delay1s()
{
uchar j;
j=i;
while(i<=20)
{;}
i=0;
}
void delay500ms()
{
uchar j;
j=i;
while(i<=10)
{;}
i=0;
}
void timer_init()
{
TMOD =0x10;
TH1= 0x3c;
TL1=0xb0;
EA=1;
ET1=1;
TR1=1;
}
void main()
{
uchar j;
timer_init();
EX0=1;
IT0=1;
PT1=1;
while(1)
{
for(j=6;j<=9;j++)
{
red1=0;green1=1;red2=0;green2=1;yellow=1;
delay1s();
P0=a[j];
}
for(j=0;j<=9;j++)
{
red1=0;green1=1;red2=1;green2=0;yellow=1;
delay1s();
P0=a[j];
}
for(j=6;j<=9;j++)
{
red1=0;green1=1;red2=1;green2=1;yellow=0;
delay500ms();
yellow=1;
delay500ms();
P0=a[j];
}
for(j=0;j<=9;j++)
{
red1=1;green1=0;red2=0;green2=1;yellow=1;
delay1s();
P0=a[j];
}
for(j=6;j<=9;j++)
{
red1=1;green1=1;red2=0;green2=1;yellow=0;
delay500ms();
yellow=1;
delay500ms();
P0=a[j];
}
for(j=0;j<=9;j++)
{
red1=0;green1=1;red2=1;green2=0;yellow=1;
delay1s();
P0=a[j];
} }
}
void timer1() interrupt 3
{
TH1= 0x3c;
TL1=0xb0;
i++;
}
void int0() interrupt 0
{
uchar j;
EX0=0;
P2=0xde;
for(j=0;j<=9;j++)
{
P0=a[j];
delay1s();
EX0=1;
}
}
二、引入矩阵键盘,可以对路口红绿灯变换时间进行设置
按下连接中断的按键K3进行时间设置,把交通灯中可以更改时间的部分写为一个带参数的函数,按下不同的开关进行时间设置,不是很完善。
仿真原理图
代码如下(示例):
#include <reg51.h>
#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
sbit L1=P1^0;
sbit L2=P1^1;
sbit L3=P1^2;
sbit L4=P1^3;
uchar code a[]={0x6f,0x7f,0x07,0x7d,0x6d,0x66,0x4f,0x5b,0x06,0x3f};
char i=0;
uchar n;
void anniu();
void delay1s()
{
while(i<=20)
{;}
i=0;
}
void delay500ms()
{
uchar j;
j=i;
while(i<=10)
{;}
i=0;
}
void timer_init()
{
TMOD =0x10;
TH1= 0x3c;
TL1=0xb0;
EA=1;
ET1=1;
TR1=1;
}
void deng(n);
void main()
{
uchar j;
timer_init();
EX0=1;
IT0=1;
PT1=1;
while(1){
for(j=6;j<=9;j++)
{
P2=0xde;
delay1s();
P1=a[j];
}
deng(0);}
}
void deng(n)
{
uchar j;
for(j=n;j<=9;j++)
{
P2=0xbe;
delay1s();
P1=a[j];
}
for(j=6;j<=9;j++)
{
P2=0x7e;
delay500ms();
P2=0xfe;
delay500ms();
P1=a[j];
}
for(j=n;j<=9;j++)
{
P2=0xdd;
delay1s();
P1=a[j];
}
for(j=6;j<=9;j++)
{
P2=0x5f;
delay500ms();
P2=0xdf;
delay500ms();
P1=a[j];
}
for(j=n;j<=9;j++)
{
P2=0xbe;
delay1s();
P1=a[j];
}
}
void timer1() interrupt 3
{
TH1= 0x3c;
TL1=0xb0;
i++;
}
void int0() interrupt 0
{
uchar temp;
do{
P0=0xff;
temp=P0;
P1=0x3f;
switch(temp)
{
case 254: deng(1);break;
case 253: deng(2);break;
case 251: deng(3);break;
case 247: deng(4);break;
case 239: deng(5);break;
case 223: deng(6);break;
case 191: deng(7);break;
case 127: deng(8);break;
}
}
while(1);
}
|