微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > MCU和单片机设计讨论 > 数码管的miao1的亮度比其他几位的亮度都要亮,其他几位亮度抖一样,求大神解答,不知到为什么?

数码管的miao1的亮度比其他几位的亮度都要亮,其他几位亮度抖一样,求大神解答,不知到为什么?

时间:10-02 整理:3721RD 点击:
#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
#define ulong unsigned long int
uchar aa;
long int temp;
sbit dula=P2^6;
sbit wela=P2^7;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f};
void display(long int i);
void delay(uint z);
void init();
void main()
{       
        init();
        while(1)
        {
                if(TF0==1)
                {
                TF0=0;
                TH0=0x4c;
                TL0=0x00;
                aa++;
                }
                if(aa==1)
                  {
                        aa=0;
                        temp++;
                        }
                        if(temp==86400)
                        temp=0;
                        display(temp);
        }
        }
void delay(uint z)
{
        uint x,y;
        for(x=z;x>0;x--)
                for(y=80;y>0;y--);
}
void display(long int i)
{
                long int shi1,shi0,fen1,fen0,miao1,miao0;
                shi1=i/3600/10;
                shi0=i/3600-(shi1*10);
                fen1=i%3600/60/10;
                fen0=i%3600/60-(fen1*10);
                miao1=i%3600%60/10;
                miao0=i%3600%60-(miao1*10);
              dula=1;
                P0=table[shi1];
                dula=0;
                P0=0xff;
                wela=1;
                P0=0xfe;
                wela=0;
                delay(3);
                dula=1;
                P0=table[shi0];
                dula=0;
                P0=0xff;
                wela=1;
                P0=0xfd;
                wela=0;
                delay(3);
                dula=1;
                P0=0x40;
                dula=0;
                P0=0xff;
                wela=1;
                P0=0xfb;
                wela=0;
                delay(3);
               
                dula=1;
                P0=table[fen1];
                dula=0;
                P0=0xff;
                wela=1;
                P0=0xf7;
                wela=0;
                delay(3);
               
                dula=1;
                P0=table[fen0];
                dula=0;
                P0=0xff;
                wela=1;
                P0=0xef;
                wela=0;
                delay(3);
                dula=1;
                P0=0x40;
                dula=0;
                P0=0xff;
                wela=1;
                P0=0xdf;
                wela=0;
                delay(3);
                               
                dula=1;
                P0=table[miao1];
                dula=0;
                P0=0xff;
                wela=1;
                P0=0xbf;
                wela=0;
                delay(3);
               
                dula=1;
                P0=table[miao0];
                dula=0;
                P0=0xff;
                wela=1;
                P0=0x7f;
                wela=0;
                delay(1);
}
void init()
{       
        TMOD=0x01;
        TH0=0x4c;
        TL0=0x00;
        TR0=1;
        temp=65520;
       
}

那说明秒的等待时间比较长了啊

我改了delay的值还是不能解决问题

不要用io口驱动,改用三极管

我是在开发板上写的程序

但我改了秒的delay值,好像没什么改变呀!

这个我很有经验                      1002925094                  

你用的什么单片机?这是完整的程序吗?感觉这种写法不好懂,建议换一种实现这个功能的程序写法,还有,你在主程序里调用定时器,但我好象没看到你的程序里有定时器中断程序。

你好,我没用EA我用TF检测的我这是完整的程序,我用的是清翔51单片机其他写法我写了,但我故意用这种写法的,老师说要举一反三。

我的问题,我弄好了,欢迎指教,如果有什么更好的方法,麻烦在下面评论我会改正的,初学者还请大神们不吝赐教,谢谢各位!
#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
uchar aa;
sbit k1=P3^0;
sbit k2=P3^1;
sbit k3=P3^2;
sbit k4=P3^3;
long int temp;
sbit dula=P2^6;
sbit wela=P2^7;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f};
void display(long int i);
void delay(uint z);
void init();
void main()
{       
        init();
        while(1)
        {
                if(TF0==1)
                {
                TF0=0;
                TH0=0x4c;
                TL0=0x00;
                aa++;
                }
                 if(aa==20)
                  {
                        aa=0;
                        temp++;
                        }
                        if(temp==86400)
                        temp=0;
                        display(temp);
                        if(k1==0)
                        {
                        delay(5);
                        if(k1==0)
                        {
                        temp=temp+60;
                        if(temp>=86400)
                        {
                        temp=0;
                        }
                        while(!k1)
                        {
                        if(TF0==1)
                {
                TF0=0;
                TH0=0x4c;
                TL0=0x00;
                aa++;
                }
                 if(aa==20)
                  {
                        aa=0;
                        temp++;
                        }
                        if(temp==86400)
                        temp=0;
                        display(temp);
                        }
                        }
                        }
                       
                        if(k2==0)
                        {
                        delay(5);
                        if(k2==0)
                        {
                        temp=temp-60;
                        if(temp<0)
                        {
                        temp=0;
                        }
                        while(!k2)
                        {
                        if(TF0==1)
                {
                TF0=0;
                TH0=0x4c;
                TL0=0x00;
                aa++;
                }
                 if(aa==20)
                  {
                        aa=0;
                        temp++;
                        }
                        if(temp==86400)
                        temp=0;
                        display(temp);
                        }
                        }
                        }
                        if(k3==0)
                        {
                        delay(5);
                        if(k3==0)
                        {
                        temp=temp+3600;
                        if(temp>=86400)
                        {
                        temp=0;
                        }
                        while(!k3)
                        {
                        if(TF0==1)
                {
                TF0=0;
                TH0=0x4c;
                TL0=0x00;
                aa++;
                }
                 if(aa==20)
                  {
                        aa=0;
                        temp++;
                        }
                        if(temp==86400)
                        temp=0;
                        display(temp);
                        }
                        }
                        }
                        if(k4==0)
                        {
                        delay(5);
                        if(k4==0)
                        {
                        temp=temp-3600;
                        if(temp<0)
                        {
                        temp=0;
                        }
                        while(!k4)
                        {
                        if(TF0==1)
                {
                TF0=0;
                TH0=0x4c;
                TL0=0x00;
                aa++;
                }
                 if(aa==20)
                  {
                        aa=0;
                        temp++;
                        }
                        if(temp==86400)
                        temp=0;
                        display(temp);
                        }
                        }
                        }

        }
        }
void delay(uint z)
{
        uint x,y;
        for(x=z;x>0;x--)
                for(y=114;y>0;y--);
}
void display(long int i)
{
                long int shi1,shi0,fen1,fen0,miao1,miao0;
                shi1=i/3600/10;
                shi0=i/3600-(shi1*10);
                fen1=i%3600/60/10;
                fen0=i%3600/60-(fen1*10);
                miao1=i%3600%60/10;
                miao0=i%3600%60-(miao1*10);

              P0=0xfe;
                wela=1;
                wela=0;
                P0=table[shi1];
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
                P0=0xfd;
                wela=1;
                wela=0;
                P0=table[shi0];
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
                P0=0xfb;
                wela=1;
                wela=0;
                P0=0x40;
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
               
                P0=0xf7;
                wela=1;
                wela=0;
                P0=table[fen1];
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
               
               
                P0=0xef;
                wela=1;
                wela=0;
                P0=table[fen0];
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
                P0=0xdf;
                wela=1;
                wela=0;
                P0=0x40;
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
                               
                P0=0xbf;
                wela=1;
                wela=0;
                P0=table[miao1];
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
               
               
                P0=0x7f;
                wela=1;
                wela=0;
                P0=table[miao0];
                dula=1;
                dula=0;
                delay(2);
                P0=0x00;
                dula=1;
                dula=0;
}
void init()
{       
        TMOD=0x01;
        TH0=0x4c;
        TL0=0x00;
        TR0=1;
        temp=43200;
       
}

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top