51单片机交通灯的proteus仿真怎么弄

这是我的代码和原理图,目的要求是点亮发光二极管同时数码管计数一段时间,然后换别的二极管亮再计数,程序不知道哪里错了,一运行数码管和发光二极管就不能按要求工作

#include
#define uchar unsigned char
#define uint unsigned int
sbit dula=P2^6;
sbit wela=P2^7;
sbit dx_hong=P0^0;
sbit dx_huang=P0^1;
sbit dx_lv=P0^2;
sbit nb_hong=P0^3;
sbit nb_huang=P0^4;
sbit nb_lv=P0^5;
uchar a,shi,ge,num1,num2,num3,num4,num5,num6;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void delayms(uint xms)
{
uint i,j;
for(i=xms;i>0;i--)
for(j=110;j>0;j--);
}
void display(uchar shi,uchar ge)
{
wela=1;
P2=0xfe;
wela=0;
P1=0xff;
dula=1;
P1=table[shi];
dula=0;
delayms(5);

wela=1;
P2=0xfd;
wela=0;
P1=0xff;
dula=1;
P1=table[ge];
dula=0;
delayms(5);

}
void djs(uchar xs)
{
if(num2>xs)
{
num2=0;
}
shi=(xs-num2)/10;
ge=(xs-num2)%10;
display(shi,ge);
}
void init()
{
TMOD=0x11;
TH0=(65536-45872)/256;
TL0=(65536-45872)%256;
EA=1;
ET0=1;
TR0=1;

}
void main()
{

while(1)
{
    init();

    dx_hong=0;
    dx_huang=1;
    dx_lv=1;
    nb_hong=1;
    nb_huang=1;
    nb_lv=0;
    djs(60);

    dx_hong=1;
    dx_huang=0;
    dx_lv=1;
    nb_hong=1;
    nb_huang=0;
    nb_lv=1;
    djs(30);

    dx_hong=1;
    dx_huang=1;
    dx_lv=0;
    nb_hong=0;
    nb_huang=1;
    nb_lv=1;
    djs(60);

    dx_hong=1;
    dx_huang=0;
    dx_lv=1;
    nb_hong=1;
    nb_huang=0;
    nb_lv=1;
    djs(30);
}

}
void T0_time()interrupt 1
{
TH0=(65536-45872)/256;
TL0=(65536-45872)%256;
num1++;
if(num1==20)
{
num1=0;
num2++;

}
}

图片说明

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐