目录
一、数码管的类型
二、数码管的工作原理
1、数码管段选的原理
2、数码管位选的原理
三、数码管的静态显示
1、控制单个数码管
四、数码管的动态显示
五、数码管倒计时程序
数码管可以分为两种类型,共阴极和和共阳极。
共阴极:图上的8个LED灯阴极全部连接在一起并接地。发光条件:引脚为高电平
共阳极:图上的8个LED灯阳极全部连接在同一个电源。发光条件:引脚为低电平。
单个数码管有abcdefg和dp共计8个LED灯。右侧1234分别代表第n个数码管的com口(阴极公共端)。因为连接的是同样的引脚,所以这几个数码管的显示数字是一样的。
从上面的介绍可以知道,单个数码管共8个LED灯。其中这8个灯和比特位的关系如下图:
共阴极引脚为高电平时点亮,低电平熄灭;共阳极则相反。a对应最低位,dp对应最高位。
138译码器有CBA三口,通过此处输出的电平信号转换成二进制范围刚好是0-7,对应于Y0-Y7口对应的8个LED灯。
因为直接使用引脚接通数码管,能量较低,所以增加了74HC245这个芯片。引脚的电平将被当成一种控制信号而不是点灯能量,74HC245根据这个控制信号,使用VCC的能量输出至数码管,形成点灯功能。
让第二个数码管显示数字5。STC89C52RC单片机的数码管是共阴极。
#include
typedef unsigned char uchar;
//uchar display[16]={0XC0,0XF9,0XA4,0XB0,0X99,0X92,
//0X82,0XF8,0X80,0X90,0X88,0X83,0XC6,0XA1,0X86,0X8E};//共阳极
uchar display[]={0x3F, //"0"0x06, //"1"0x5B, //"2"0x4F, //"3"0x66, //"4"0x6D, //"5"0x7D, //"6"0x07, //"7"0x7F, //"8"0x6F, //"9"0x77, //"A"0x7C, //"B"0x39, //"C"0x5E, //"D"0x79, //"E"0x71, //"F"0x76, //"H"0x38, //"L"0x37, //"n"0x3E, //"u"0x73, //"P"0x5C, //"o"0x40, //"-"};//共阴极
void Nixie(uchar Location,uchar num)
{switch(Location)//数码管位选{case 1:P2_4=1;P2_3=1;P2_2=1;break;case 2:P2_4=1;P2_3=1;P2_2=0;break;case 3:P2_4=1;P2_3=0;P2_2=1;break;case 4:P2_4=1;P2_3=0;P2_2=0;break;case 5:P2_4=0;P2_3=1;P2_2=1;break;case 6:P2_4=0;P2_3=1;P2_2=0;break;case 7:P2_4=0;P2_3=0;P2_2=1;break;case 8:P2_4=0;P2_3=0;P2_2=0;break;}P0=display[num];//数码管段选,调用共阴极的显示数组
}
void main()
{Nixie(2,5);//在第二个数码管上显示数字5while(1){}
}
要控制前三个数码管同时输出1、2、3。
#include
typedef unsigned char uchar;
typedef unsigned int uint;
uchar display[]={0x3F, //"0"0x06, //"1"0x5B, //"2"0x4F, //"3"0x66, //"4"0x6D, //"5"0x7D, //"6"0x07, //"7"0x7F, //"8"0x6F, //"9"0x77, //"A"0x7C, //"B"0x39, //"C"0x5E, //"D"0x79, //"E"0x71, //"F"0x76, //"H"0x38, //"L"0x37, //"n"0x3E, //"u"0x73, //"P"0x5C, //"o"0x40, //"-"};//共阴极
//延时1ms函数void delay_1ms(){int i=0;for(i=0;i<123;i++){}}//自定义延时时间函数void delay_ms(uint t){while(t--){delay_1ms();}}
void Nixie(uchar Location,uchar num)
{switch(Location)//数码管位选{case 1:P2_4=1;P2_3=1;P2_2=1;break;case 2:P2_4=1;P2_3=1;P2_2=0;break;case 3:P2_4=1;P2_3=0;P2_2=1;break;case 4:P2_4=1;P2_3=0;P2_2=0;break;case 5:P2_4=0;P2_3=1;P2_2=1;break;case 6:P2_4=0;P2_3=1;P2_2=0;break;case 7:P2_4=0;P2_3=0;P2_2=1;break;case 8:P2_4=0;P2_3=0;P2_2=0;break;}P0=display[num];//数码管段选,调用共阴极的显示数组delay_ms(1);P0=0x00;//不亮
}
void main()
{while(1){Nixie(1,1);//delay_ms(3);//延时肉眼消影Nixie(2,2);//delay_ms(3);Nixie(3,3);//delay_ms(3);}
}
数码管虽然看上去同时显示数字1、2、3,但实际上这三个数码管一直在被循环点亮,我们肉眼分辨不出来这种变化,看上去就是三个数码管常亮。
注意这里有一个消影问题:因为语句是一条一条执行的,例如case2是110,进入case3就要变成101(看代码,语句是一句一句执行的,先变成100,再变成101)所以会造成1、不用的位隐约显示数据2、不用的段隐约有亮度3、本位显示上一位数据。
目标显示123,但实际情况如下图:
解决方法:1、函数内消影(推荐)2、函数外延迟肉眼消影。
让数码管从9倒计时为0,不断循环这一过程。
#include
typedef unsigned char uchar;
typedef unsigned int uint;
uchar display[]={0x3F, //"0"0x06, //"1"0x5B, //"2"0x4F, //"3"0x66, //"4"0x6D, //"5"0x7D, //"6"0x07, //"7"0x7F, //"8"0x6F, //"9"0x77, //"A"0x7C, //"B"0x39, //"C"0x5E, //"D"0x79, //"E"0x71, //"F"0x76, //"H"0x38, //"L"0x37, //"n"0x3E, //"u"0x73, //"P"0x5C, //"o"0x40, //"-"};//共阴极
//延时1ms函数void delay_1ms(){int i=0;for(i=0;i<123;i++){}}//自定义延时时间函数void delay_ms(uint t){while(t--){delay_1ms();}}
void Nixie(uchar Location,uchar num)
{switch(Location)//数码管位选{case 1:P2_4=1;P2_3=1;P2_2=1;break;case 2:P2_4=1;P2_3=1;P2_2=0;break;case 3:P2_4=1;P2_3=0;P2_2=1;break;case 4:P2_4=1;P2_3=0;P2_2=0;break;case 5:P2_4=0;P2_3=1;P2_2=1;break;case 6:P2_4=0;P2_3=1;P2_2=0;break;case 7:P2_4=0;P2_3=0;P2_2=1;break;case 8:P2_4=0;P2_3=0;P2_2=0;break;}P0=display[num];//数码管段选,调用共阴极的显示数组
}
void main()
{while(1){char i=9;for(;i>=0;--i){Nixie(1,i);delay_ms(1000);//让数字停1000ms}}
}
《 符合学习规律的超详细linux实战快速入门》
下一篇:机器学习之朴素贝叶斯分类