标题:
单片机交通灯仿真程序 具有夜间模式
[打印本页]
作者:
小萌新51
时间:
2021-1-17 16:15
标题:
单片机交通灯仿真程序 具有夜间模式
捕获.PNG
(131.08 KB, 下载次数: 55)
下载附件
2021-1-17 16:13 上传
proteus 仿真,具有夜间模式
单片机源程序如下:
#include <reg52.h>
#define uchar unsigned char
#define uint unsigned int
//东西 红黄绿
sbit RED_A=P0^0;
sbit YELLOW_A=P0^1;
sbit GREEN_A=P0^2;
//南北 红黄绿
sbit RED_B=P0^3;
sbit YELLOW_B=P0^4;
sbit GREEN_B=P0^5;
//加减按键
sbit k1=P3^0;
sbit k2=P3^1;
//变量
uchar Flash_Count = 0,scount=0,flag_mode=1,time_flag=0;
uchar GT1=8,YT1=2,RT1=6;
uchar GT2=8,YT2=2,RT2=6;
//数码管0-13
uchar code DSY_CODE[]=
{
0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xC6,0xA1
};
//也是函数
void DelayMS(uint x)
{
uchar t;
while(x--)
{
for(t=120;t>0;t--);
}
}
//定时器初始化
void time_init()
{
TMOD=0X01;
TH0=(65536-10000)/256;
TL0=(65536-10000)%256;
ET0=1;
EA=1;
TR0=1;//定时器开
IT0=1;//中断0
EX0=1;
IT1=1;//中断1
EX1=1;
}
//交通灯处理函数
void Traffic_lignt()
{
if(flag_mode%2) //默认白天
{
if(scount>GT1+YT1+RT1) //东西
scount=0;
if(scount<GT1) //绿灯
{
P2=DSY_CODE[GT1-scount]; //数码管显示时间
RED_A=1;
YELLOW_A=1;
GREEN_A=0;
}
else if(scount<GT1+YT1) //黄灯
{
P2=DSY_CODE[GT1+YT1-scount];//数码管显示时间
RED_A=1;
YELLOW_A=0;
GREEN_A=1;
}
else if(scount<GT1+YT1+RT1) //红点
{
P2=DSY_CODE[GT1+YT1+RT1-scount];//数码管显示时间
RED_A=0;
YELLOW_A=1;
GREEN_A=1;
}
//南北
if(scount<RT2) //红灯
{
P1=DSY_CODE[RT2-scount];//数码管显示时间
RED_B=0;
YELLOW_B=1;
GREEN_B=1;
}
else if(scount<RT2+GT2) //绿灯
{
P1=DSY_CODE[RT2+GT2-scount];//数码管显示时间
RED_B=1;
YELLOW_B=1;
GREEN_B=0;
}
else if(scount<RT2+GT2+YT2)//黄灯
{
P1=DSY_CODE[RT2+GT2+YT2-scount];//数码管显示时间
RED_B=1;
YELLOW_B=0;
GREEN_B=1;
}
}
else //晚上 黄灯闪烁
{
RED_A=RED_B=1;
YELLOW_A=YELLOW_B=0;
GREEN_A=GREEN_B=1;
DelayMS(500);
RED_A=RED_B=1;
YELLOW_A=YELLOW_B=1;
GREEN_A=GREEN_B=1;
DelayMS(500);
}
}
void key_pose() //按键处理
{
if(time_flag==1) //GT1
{
if(k1==0)
{
DelayMS(5);
if(k1==0)
{
GT1++; //时间+
}
while(!k1);
}
if(k2==0)
{
DelayMS(5);
if(k2==0)
{
GT1--; //时间-
}
while(!k2);
}
if(GT1>=9) //限制时间
GT1=9;
if(GT1<=3)
GT1=3;
RED_B=1;
YELLOW_B=1;
GREEN_B=1;
P1=0XFF;
P2=DSY_CODE[GT1];//数码管显示时间
RED_A=1;
YELLOW_A=1;
GREEN_A=0;
GT2=RT1-YT1;
YT2=YT1;
RT2=GT1+YT1;
}
else if(time_flag==2) //RT1
{
if(k1==0)
{
DelayMS(5);
if(k1==0)
{
RT1++; //时间+
}
while(!k1);
}
if(k2==0)
{
DelayMS(5);
if(k2==0)
{
RT1--;//时间-
}
while(!k2);
}
if(RT1>=9) //限制时间
RT1=9;
if(RT1<=3)
RT1=3;
P2=DSY_CODE[RT1];//数码管显示时间
RED_A=0;
YELLOW_A=1;
GREEN_A=1;
//东西南北时间处理
GT2=RT1-YT1;
YT2=YT1;
RT2=GT1+YT1;
}
}
void main()
{
time_init();//定时器初始化
GT2=RT1-YT1;//东西南北时间处理
YT2=YT1;
RT2=GT1+YT1;
P1=P2=0XFF;
/*主函数*/
while(1)
{
if(time_flag==0)
Traffic_lignt(); //交通灯处理函数
key_pose(); //按键处理
}
}
//定时器0服务函数
void tim0() interrupt 1
{
static uchar i;
TH0=(65536-10000)/256;
TL0=(65536-10000)%256;
i++;
if(i==100) //时间1S
{
scount++;
i=0;
}
}
//中断0服务函数 模式设置
void init0() interrupt 0
{
flag_mode++;
P1=P2=0XFF;
if(flag_mode%2) //默认白天
{
TR0=1;
scount=0;
}
else
TR0=0;
}
//中断1服务函数 时间设置
void init1() interrupt 2
{
time_flag++; //时间选择
P1=0XFF;
RED_B=1;
YELLOW_B=1;
GREEN_B=1;
if(time_flag>=3) //
{
time_flag=0;
TR0=1;
scount=0;
}
else
{
TR0=0;
}
}
复制代码
所有资料51hei提供下载:
05 LED模拟交通灯.zip
(2.84 MB, 下载次数: 35)
2021-1-17 16:15 上传
点击文件名下载附件
下载积分: 黑币 -5
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1