基于51单片机的交通灯仿真

基于51单片机的交通灯仿真

原理图

①放置芯片和元件
②开始放置元件
③画总线和放置电源
④连接元件
在这里插入图片描述

代码源程序

1.建立一个项目
①打开Keil uVision,点击Project,找到New uVision Project,点击它
②给建立的项目取一个名字
在这里插入图片描述
③选择项目需要使用的芯片,选择完成后,点击OK(该实验要用到的芯片是AT89C51)
在这里插入图片描述
④出现一个对话框,选择否,一个项目就建立完成,就可以开始代码的编写
2.LED的代码
选择file,new,输入代码

#include<reg52.h>
typedef unsigned char uchar;
typedef unsigned int uint;

#define count 50000
#define TH_0 (65536-count)/256
#define TL_0 (65536-count)%256

sbit ew_led_r=P3^0;
sbit ew_led_y=P3^1;
sbit ew_led_g=P3^2;

sbit ns_led_r=P3^3;
sbit ns_led_y=P3^4;
sbit ns_led_g=P3^5;

sbit bit_0=P2^0;
sbit bit_1=P2^1;

sbit k1=P2^2;
sbit k2=P2^3;
sbit k3=P2^4;
sbit k4=P2^5;

uchar code duanxuan[]={
   0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};

uchar sec=30;
uchar flag=1;
uchar temp=30;

void delay(uint iii)
{
   
	while(iii--);
}
void display()
{
   
	if(flag==1||flag==2)	//状态1和状态2,东西比南北少2秒
	{
   
		bit_0=0;bit_1=1;
	
		P0=duanxuan[sec%10];
		delay(100);P0=0x00;
		if(sec>2)
		{
   
			P1=duanxuan[(sec-2)%10];
			delay(200);P1=0x00;
		}
		else
		{
   
			P1=duanxuan[sec%10];
			delay(200);P1=0x00;
		}
	
		bit_0=1
  • 9
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值