找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1894|回复: 0
收起左侧

单片机交通信号灯程序如何加入黄灯等待时间内流水灯闪烁?求指导

[复制链接]
ID:961087 发表于 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

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

943.37 KB, 下载次数: 1

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表