标题: 单片机交通信号灯程序如何加入黄灯等待时间内流水灯闪烁?求指导 [打印本页]

作者: 王披风    时间: 2021-9-22 13:51
标题: 单片机交通信号灯程序如何加入黄灯等待时间内流水灯闪烁?求指导
下列程序实现了红绿灯的数码显示及对应的流水灯显示,但是没有实现在黄灯等待时间内流水灯闪烁,求解答一下,尝试过直接在流水灯下边直接加入延时函数,但是数码管进行了闪烁而流水灯没有闪烁求指点一下。图片为使用开发板,附录为单片机原理图。

单片机源程序如下:
#include <REGX52.H>
#define uint unsigned int
#define uchar unsigned char
sbit nsred=P1^0;
sbit nsgreen=P1^1;
sbit nsyellow=P1^2;
sbit ewred=P1^4;
sbit ewgreen=P1^5;
sbit ewyellow=P1^6;
sbit wela=P2^6;
sbit dula=P2^7;
#define nsred() do{nsred=0;nsgreen=1;nsyellow=1;} while(0);
#define nsgreen() do{nsred=1;nsgreen=0;nsyellow=1;} while(0);
#define nsyellow() do{nsred=1;nsgreen=1;nsyellow=0;} while(0);
#define ewred() do{ewred=0;ewgreen=1;ewyellow=1;} while(0);
#define ewgreen() do{ewred=1;ewgreen=0;ewyellow=1;} while(0);
#define ewyellow() do{ewred=1;ewgreen=1;ewyellow=0;} while(0);
#define yeltime 4
#define ewtime 28+yeltime
#define nstime 16+yeltime
uchar t=ewtime;
uchar flag=1;
uchar tt=0;
uchar keyflag=0;
uchar table1[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
uchar table2[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
sbit key2=P3^4;
sbit key3=P3^5;
void delayms(uint xms)
{
        uint i,j;
        for(i=xms;i>0;i--)
        for(j=110;j>0;j--);
}
void display1(uint num1,uint num2)
{
        P0=0xff;
        wela=1;
        P0=table1[num1];
        wela=0;
        
        dula=1;
        P0=table2[0];
        dula=0;
        delayms(3);
        
        P0=0xff;
        wela=1;
        P0=table1[num2];
        wela=0;
        
        dula=1;
        P0=table2[1];
        dula=0;
        delayms(3);
        
}
void display2(uint num3,uint num4)
{
        P0=0xff;
        wela=1;
        P0=table1[num3];
        wela=0;
        
        dula=1;
        P0=table2[4];
        dula=0;
        delayms(3);
        
        P0=0xff;
        wela=1;
        P0=table1[num4];
        wela=0;
        
        dula=1;
        P0=table2[5];
        dula=0;
        delayms(3);
}
void INIT()
{
        TMOD=0x01;
        TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
        ET0=1;
        TR0=1;
}
void keyscan()
{
        if(key2==0)
        {
                delayms(10);
                if(key2==0)
                {
                        keyflag=1;
                }
        }
        if(key3==0)
        {
                delayms(10);
                if(key3==0);
                {
                        flag=1;
                        keyflag=0;
                        t=ewtime;
                }
        }
}
void main()
{        
        INIT();
        EA=1;
        nsgreen=1;
        nsred=1;
        nsyellow=1;
        ewred=1;
        ewgreen=1;
        ewyellow=1;
        while(1)
        {
                keyscan();
                if(flag==1)
                {
                        display1(t/10,t%10);
                        display2(t/10,t%10);
                        nsred();
                        ewgreen();
                        //nsred=0;
                        //ewgreen=0;
                                if(t>4)
                        {
                                ewgreen();
                        }
                        if(t>=0&&t<5) ewyellow();
                        if(t==0)
                        {
                                flag=0;
                                t=nstime;
                        }
                }
               
                if(flag==0)
                {
                        display1(t/10,t%10);
                        display2(t/10,t%10);
                        nsgreen();
                        ewred();
                                if(t>4)
                        {
                                nsgreen();
                        }
                        if(t>=0&&t<5)
                        {
                                nsyellow();
                                ewred();
                        }
                        if(t==0)
                        {
                                flag=1;
                                t=ewtime;
                        }        
                }
               
                if(keyflag==1)
                {
                        dula=1;
                        P0=0xff;
                        dula=0;
                        nsred();
                        ewred();
                        flag=2;
                        
                }
        }
}
void t0()interrupt 1
{
        TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
        tt++;
        if(tt==9)
        {
                tt=0;
                t--;
        }
}


IMG_20210909_145254.jpg (195.13 KB, 下载次数: 65)

IMG_20210909_145254.jpg

TX-1C增强版原理图.pdf

943.37 KB, 下载次数: 1






欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1