SuperHeroMario 2016-05-15 02:34 采纳率: 66.7%
浏览 3311

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条回答 默认 最新

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog