LED数码管:由多个发光二极管封装在一起组成的“8”字型显示器。
我使用的数码管采用共阴极连接。
如果让第三个位置显示1,那么先选中第三个位置,选中COM端LED6,给0,其他7个端给1。
b,c给1,剩下5个给0。
双向数据缓冲器(74HC245):
作用是提高驱动能力(内部置有电源)。
OE通常表示"Output Enable",也可以称为输出使能。
LE通常表示"Latch Enable",也可以称为锁存使能。
OE(使能,接地时工作);DIR(direction,控制A到B,或者B到A);
跳线帽:我的是GND、OE、VCC
3和2短接。
DIR接高电平,那么A到B(图中直接接的是VCC,不是OE)。
又叫38线译码器,作用是将这8个端口用三个端口控制(P22、P23、P24)。其中4、5、6为使能端。
C B A Y
0 0 0 0
1 0 1 5
第一个对应Y0有效(因为上面有一横,所以表示低电平有效),第二个对应Y5有效。
任一数码管显示数字(静态)
#include <REGX52.H>
//数码管段码表
unsigned char NixieTable[]={0x3F,0x06,0x5B,
0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};//0011 1111,0000 0110
//数码管显示子函数
void Nixie(unsigned char Location,Number)
{
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=NixieTable[Number]; //段码输出
}
void main()
{
Nixie(2,1); //在数码管的第2位置显示1
while(1)
{
}
}
为什么高电平驱动能力弱?
51单片机的高电平驱动能力较弱主要是由以下几个因素造成的:
1. I/O引脚设计:51单片机的I/O引脚大多采用的是MOS结构来实现,它主要由P型MOS管和N型MOS管组成。在输出高电平时,P型MOS管的漏源电流会经过N型MOS管来驱动外部负载,这导致了输出高电平驱动能力的限制。
2. 工作电压:51单片机的工作电压通常为5V,而现代的逻辑门电平一般为3.3V或更低。当51单片机的I/O引脚输出高电平时,由于电压差异,可能无法直接驱动低电平电压要求较高的外部设备。
3. 输出电流限制:51单片机的I/O引脚输出电流有限,通常在几mA的范围内。这限制了其驱动能力,特别是在需要较大电流的外部负载情况下。
由于上述限制,如果需要驱动较高电平电压要求或较大电流的外部设备,可能需要使用外部放大器、电平转换器或电流放大器等辅助电路来增强驱动能力。此外,当需要高电平驱动能力较强的应用时,考虑选择其他型号的单片机或其他器件可能更为适合。
显示两位以上的数字(动态)
因为在上一个段选到下一个位选的过程中会出现数据串位,所以需要消影。
在段选完成后进行清零。
#include <REGX52.H>
//数码管段码表
unsigned char NixieTable[]={0x3F,0x06,0x5B,
0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
//延时子函数
void Delay(unsigned int xms)
{
unsigned char i, j;
while(xms--)
{
i = 2;
j = 239;
do
{
while (--j);
} while (--i);
}
}
//数码管显示子函数
void Nixie(unsigned char Location,Number)
{
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=NixieTable[Number]; //段码输出
Delay(1); //显示一段时间
P0=0x00; //段码清0,消影
}
void main()
{
while(1)
{
Nixie(1,1); //在数码管的第1位置显示1
// Delay(20);
Nixie(2,2); //在数码管的第2位置显示2
// Delay(20);
Nixie(3,3); //在数码管的第3位置显示3
// Delay(20);
}
}