按照我的开发板,共阴极数码管共8个,也就是说,只能显示8位数字,0-99999999,当显示的数字不足8位时,需要将不显示的数码管熄灭即消隐,代码原理就是将存储显示值的数组变量中,不显示的位在P1口输出0(熄灭),以下显示0-9999四位有效数字为例,从第2位数码管开始,显示最多4位有效数字:
#include<reg52.h>
sbit LATCH1=P2^2;//段锁存
sbit LATCH2=P2^3;//位锁存
unsigned char code DuanMa[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};// 显示段码值0~9
unsigned char code WeiMa[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//分别对应相应的数码管点亮,即位码
unsigned char TempData[8]; //存储显示值的全局变量
void Delay(unsigned int t); //函数声明
void Display(unsigned char FirstBit,unsigned char Num);
main()
{
unsigned int num;
unsigned int j;
while(1)
{
j++;
if(j==10) //检测当前数值显示了一小段时间后,需要显示的数值加1,实现数据显示的变化
{
j=0;
num++;
if(num==10000)//用于显示0~9999
num=0;
}
if(num<1000) //如果小于1000则千位不显示
TempData[0]=0;
else
TempData[0]=DuanMa[num/1000]; //显示千位
if(num<100) //如果小于100则百位也不显示
TempData[1]=0;
else
TempData[1]=DuanMa[(num%1000)/100];// 显示百位
if(num<10) //如果小于10则十位都不显示
TempData[2]=0;
else
TempData[2]=DuanMa[((num%1000)%100)/10];// 显示十位
TempData[3]=DuanMa[((num%1000)%100)%10]; // 显示个位
Display(2,4);
}
}
void Delay(unsigned int t)
{
while(--t);
}
void Display(unsigned char FirstBit,unsigned char Num)
{
unsigned char i;
for(i=0;i<Num;i++)
{
P1=0; //清空数据,防止有交替重影
LATCH1=1; //段锁存
LATCH1=0;
P1=WeiMa[i+FirstBit]; //取位码
LATCH2=1; //位锁存
LATCH2=0;
P1=TempData[i]; //取显示数据,段码
LATCH1=1; //段锁存
LATCH1=0;
Delay(200); // 扫描间隙延时,时间太长会闪烁,太短会造成重影
}
}