动态数码管显示原理
-
显示原理
动态数码管与静态数码管的实现方法差不多,首先是位选,即让哪一个数码管工作。其次是段选,让工作的数码管显示特定数字。单片机的代码是一个一个执行的,之所以可以显示的效果不同,是因为延时不同。延时长,会看到四个数码管依次显示1、2、3、4数字。延时短,会看到“静态”的1、2、3、4。
但并不是静态的,因为其时间达到了微秒级,人眼不能分辨频率,造成的视觉暂留。
-
效果图展示
与上图比较,下面的这张图可以看到一些不应亮的LED还发这微光,这是因为没有进行消隐导致的,我们可以在程序中清零,令P0=0xff(共阴极为P0=0x00,0x表示16进制,ff表示令一个数码管的八个led全为高电平1,可想一下为什么是1,而不是0)
- 开源代码
#include<reg51.h>
#include<intrins.h>
//定义变量
typedef unsigned char u8;
typedef unsigned int u16;
//共阳数码管编码表
u8 code smaguan[16] ={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,
0xc6,0xa1,0x86,0x8e};
//数码管的使能端
sbit p20=P2^0;
sbit p21=P2^1;
sbit p22=P2^2;
sbit p23=P2^3;
//延时程序
void delay (u16 i)
{
while(i--);
}
void display()
{
u8 i;
for (i=1;i<5;i++)
{
switch(i) // 段选
{
case(1):
p20=0;p21=1;p22=1;p23=1;break; //第1个数码管亮
case(2):
p20=1;p21=0;p22=1;p23=1;break; //第2个数码管亮
case(3):
p20=1;p21=1;p22=0;p23=1;break; //第3个数码管亮
case(4):
p20=1;p21=1;p22=1;p23=0;break; //第4个数码管亮
}
P0=smaguan[i]; //位选
delay(100);
P0=0xff;// 消影
}
}
// 在主程序中调用display自定义函数
void main()
{
while(1)
{
display();
}
}