注意事项:
1.数码管真值表是共阳还是共阴,需要看你自己所接的原理图定。
2.原理图1处的E1E2E3,你可以接在两个端口上(这样你在代码6.7行就需要把端口赋值给ADDR3和ENLED)也可以像我一样直接接高低电平,就可以不用赋值。
3.原理图2处,我的网络标号是由下而上,显示右边开始第一位,如果由上而下是左边开始第一位。
4.需要显示多少位都是可以修改的,比如显示99或者八位全部使用99999999,更改相关参数就可以。
实验程序:
#include <regx52.h>
sbit ADDR0 = P2^2;
sbit ADDR1 = P2^3;
sbit ADDR2 = P2^4;
//sbit ADDR3 = P2^6; 这两个ADDR3和ENLED需不需要定义就看你的原理图怎么接的
//sbit ENLED = P2^7; 例如我的原理图1处,我的38译码器的E1E2E3已经接好了高低电平,这样你就可以不需要定义。如果没接,接了其他的口就把他定义成几口。
unsigned char code LedChar[] = { 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//共阴数码管显示字符转换表
//如果你的数码管是共阳数码管就换下面这个代码,实验中推荐使用共阳数码管。
//unsigned char code LedChar[] = { 0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};//共阳数码管显示字符转换表
unsigned char LedBuff[6] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};//数码管显示缓冲区,初值0x00确保启动时都不亮,共阴
//unsigned char LedBuff[6] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};//数码管显示缓冲区,初值0x00确保启动时都不亮,共阳
unsigned char i = 0; //动态扫描的索引
unsigned int cnt = 0; //记录T0中断次数
unsigned char flag1s = 0; //1秒定时标志
void main()
{
char j; //循环变量
unsigned long sec = 0; //记录经过的秒数
unsigned char buf[6]; //中间转换缓冲区
EA = 1; //使能总中断
//ENLED = 0; //使能U3 需不需要定义看你上面6,7行有没有定义
//ADDR3 = 1; //因为需要动态改变ADDR0-2的值,所以不需要再初始化了
TMOD = 0x01; //设置T0为模式1
TH0 = 0xFC; //为T0赋初值0xFC67,定时1ms
TL0 = 0x67;
ET0 = 1; //使能T0中断
TR0 = 1; //启动T0
while (1)
{
if (flag1s == 1) //判断1秒定时标志
{
flag1s = 0; //1秒定时标志清零
sec++; //秒计数自加1
//将sec按十进制位从低到高依次提取到buf数组中
buf[0] = sec%10;
buf[1] = sec/10%10;
buf[2] = sec/100%10;
buf[3] = sec/1000%10;
buf[4] = sec/10000%10;
buf[5] = sec/100000%10;
//从最高为开始,遇到0不显示,遇到非0退出循环
for (j=5; j>=1; j--)
{
if (buf[j] == 0)
LedBuff[j] = 0x00; //共阳数码管改0xff
else
break;
}
//将剩余的有效数字位如实转换
for ( ; j>=0; j--) //for()起始未对j操作,j即保持上个循环结束时的值
{
LedBuff[j] = LedChar[buf[j]];
}
}
}
}
/* 定时器0中断服务函数 */
void InterruptTimer0() interrupt 1
{
TH0 = 0xFC; //重新加载初值
TL0 = 0x67;
cnt++; //中断次数计数值加1
if (cnt >= 1000) //中断1000次即1秒
{
cnt = 0; //清零计数值以重新开始下1秒计时
flag1s = 1; //设置1秒定时标志为1
}
//以下代码完成数码管动态扫描刷新
P0 = 0x00; //显示消隐 //共阳数码管改0xff
switch (i)
{
case 0: ADDR2=0; ADDR1=0; ADDR0=0; i++; P0=LedBuff[0]; break;
case 1: ADDR2=0; ADDR1=0; ADDR0=1; i++; P0=LedBuff[1]; break;
case 2: ADDR2=0; ADDR1=1; ADDR0=0; i++; P0=LedBuff[2]; break;
case 3: ADDR2=0; ADDR1=1; ADDR0=1; i++; P0=LedBuff[3]; break;
case 4: ADDR2=1; ADDR1=0; ADDR0=0; i++; P0=LedBuff[4]; break;
case 5: ADDR2=1; ADDR1=0; ADDR0=1; i=0; P0=LedBuff[5]; break;
default: break;
}
}
实验原理图: