目录
一:动态数码管模块
1:介绍
2:共阴极和共阳极
A:共阴极
B:共阳极
C:转化表
3:74HC138译码器
4:74HC138译码器控制动态数码管(位选)
5:数码管显示完整代码
6:74HC573锁存器
A:基本点
B:原理图介绍
c:74HC573控制数码管代码
二:矩阵按键模块
1:介绍
2:原理图
3:矩阵按键代码
一:动态数码管模块
1:介绍
LED数码管:数码管是一种简单、廉价的显示器,是由多个发光二极管封装在一起组成“8”字型的器件;
我们的51单片机的1个数码管就相当于由8个发光二极管封装在一起, 所以我们只需要控制8个发光二极管封就可以实现数码管的显示,这款单片机是共阴极连接
数码管扫描(输出扫描) 原理:显示第1位→显示第2位→显示第3位→……,然后快速循环这个过程,最终实现所有数码管同时显示的效果,节省I/O口
2:共阴极和共阳极
我们这款单片机是共阴极所以我们主要介绍共阳极连接
A:共阴极
1.LED共阴极是指LED灯中的二极管的阴极有一个共同的接点,并且该接点连接在GND端,即处于低电平状态。 我们只需要给它一个高电频(1)就可以点亮他
从高位到低位读取
eg:让第一个数码管显示0
数码管段码表对应的0,1,2,3,4,5,6,7,8,9
unsigned char NixieTable[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
B:共阳极
LED共阳极是指LED灯中的二极管的阳极有一个共同的接点,并且该接点连接在VCC端,即处于高电平状态。 我们只需要给它一个低电频(0)就可以点亮他
数码管段码表对应的0,1,2,3,4,5,6,7,8,9
unsigned char LED7Code[] = {0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82,
0xf8, 0x80, 0x90};
C:转化表
3:74HC138译码器
3个io口控制8位,因为单片机上面的资源有限
通过A0~A2数据的输入来控制Y0~Y7数据的输出;实现 3个io口控制8位,(位选)
4:74HC138译码器控制动态数码管(位选)
eg:点亮LED8
EDL1对应的是Y7的输出端口,所以只需要控制A,B,C输出Y7即可
从高位到低位读和写; (只需要将二进制转化位10进制的7即可)
P2_4=1;P2_3=1;P2_2=1;//二进制111转化十机制为:7,输出Y7;当用户选择1时点亮LED8
5:数码管显示完整代码
#include <REGX52.H>
unsigned char NixieTable[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
//延时函数的声明
void Delay(unsigned int xms);
/**
* @brief 数码管的选择和读取
* @param Location:选择那一个数码管; Number:选择显示那个数字(0~9)
* @retval 无
*/
void Nixie(unsigned char Location,Number)
{
switch (Location)
{
case 1:P2_4=1;P2_3=1;P2_2=1;break;//二进制111转化十机制为:7,当用户选择1时点亮LED8
case 2:P2_4=1;P2_3=1;P2_2=0;break;//二进制110转化十机制为:6,当用户选择2时点亮LED7
case 3:P2_4=1;P2_3=0;P2_2=1;break;//二进制101转化十机制为:5,当用户选择3时点亮LED6
case 4:P2_4=1;P2_3=0;P2_2=0;break;//二进制100转化十机制为:4,当用户选择4时点亮LED5
case 5:P2_4=0;P2_3=1;P2_2=1;break;//二进制11(高位补零)转化十机制为:3,当用户选择5时点亮LED4
case 6:P2_4=0;P2_3=1;P2_2=0;break;//二进制10(高位补零)转化十机制为:2,当用户选择6时点亮LED3
case 7:P2_4=0;P2_3=0;P2_2=1;break;//二进制1(高位补零)转化十机制为:1,当用户选择7时点亮LED2
case 8:P2_4=0;P2_3=0;P2_2=0;break;//二进制0(高位补零)转化十机制为:0,当用户选择3时点亮LED1
}
P0=NixieTable[Number]; //段码输出
Delay(1); //显示一段时间
P0=0x00; //段码清0,消影
}
void Delay(unsigned int xms)
{
unsigned char i, j;
while(xms--)
{
i = 2;
j = 239;
do
{
while (--j);
} while (--i);
}
}
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);
}
}
6:74HC573锁存器
A:基本点
74HC573是拥有八路输出的透明锁存器,输出为三态门,是一种高性能硅栅CMOS器件。如图,OE为三态允许控制端(低电平有效),通常叫做输出使能端。1D--8D为数据输入端;1Q--8Q为数据输出端:LE为锁存允许端,或锁存控制端。图为74HC573的真值表,真值表中字母代码含义如下:H-高电平,L一低电平;X一任意电平,Z一高阻态,也就是既不是高电平也不是低电平,而它的电平状态由与相连的其他电气状态决定,Q0一上次的电平状态。
A:OE为片选段,低电平有效当,其为低电平时锁存器正常OE为低电平时,LE控制锁存器的状态
B:LE=1 时 输入D=输出的Q
C:LE=0 时 输出的nochange,与所上一次相同
D: 段选锁存:控制该数码管显示的内容 位选锁存:控制那一路数码管显示。
B:原理图介绍
公阴极数码管段选:
unsigned char NixieTable[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
公阴极数码管位选:
共阴数码管的每一位(WEI1,WEI2,WEI3…)都是公共的阴极,只有输入低电平的时候才会被点亮,所以位选的时候被选中的位必须是低电平。
eg:选择WE1 为:PO=0xfe (从高位到低位开始写)
unsigned char table[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
//位选的8个数码管
c:74HC573控制数码管代码
#include <REGX52.H>
sbit dula=P2^6; //段选:选择输出的内容
sbit wela=P2^7; //位选:选择输出数码管的位置
//段选:0~9
unsigned char NixieTable[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
//位选:1~8个数码管
unsigned char table[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
//延时子函数
void Delay(unsigned int xms)
{
unsigned char i, j;
while(xms--)
{
i = 2;
j = 239;
do
{
while (--j);
} while (--i);
}
}
//74HC573芯片控制的数码管
//Location:位选选择哪一个数码管;Number段选:选择输出的内容
void Nixie(unsigned char Location,Number)
{
switch (Location)
{
case 1:P0=table[Location-1];wela=1;wela=0;break;
case 2:P0=table[Location-1];wela=1;wela=0;break;
case 3:P0=table[Location-1];wela=1;wela=0;break;
case 4:P0=table[Location-1];wela=1;wela=0;break;
case 5:P0=table[Location-1];wela=1;wela=0;break;
case 6:P0=table[Location-1];wela=1;wela=0;break;
case 7:P0=table[Location-1];wela=1;wela=0;break;
case 8:P0=table[Location-1];wela=1;wela=0;break;
}
P0=NixieTable[Number];
dula=1;
dula=0;
Delay(1);
P0=0x00;
}
void main(){
while(1){
Nixie(1,1);
Nixie(2,2);
Nixie(3,3);
}
}
二:矩阵按键模块
1:介绍
矩阵键盘扫描(输入扫描) 原理:读取第1行(列)→读取第2行(列) →读取第3行(列) → ……,然后快速循环这个过程,最终实现所有按键同时检测的效果,节省I/O口
2:原理图
按下为0;我们使用列扫描,
eg:按下1,5,9,13
1:使他P1端口全部为1
2:1,5,9,13为一列,他们的共同端口为P1^3,显示共同端口为P1^3为0;文章来源:https://www.toymoban.com/news/detail-617408.html
3:依次使P1_7, P1_6, P1_5, P1_4为0,文章来源地址https://www.toymoban.com/news/detail-617408.html
3:矩阵按键代码
#include <REGX52.H>
//声明
void Delay(unsigned int xms)
/**
* @brief 矩阵键盘读取按键键码
* @param 无
* @retval KeyNumber 按下按键的键码值
如果按键按下不放,程序会停留在此函数,松手的一瞬间,返回按键键码,没有按键按下时,返回0
*/
unsigned char MatrixKey()
{
unsigned char KeyNumber=0;
P1=0xFF;
P1_3=0;
if(P1_7==0){Delay(20);while(P1_7==0);Delay(20);KeyNumber=1;}
if(P1_6==0){Delay(20);while(P1_6==0);Delay(20);KeyNumber=5;}
if(P1_5==0){Delay(20);while(P1_5==0);Delay(20);KeyNumber=9;}
if(P1_4==0){Delay(20);while(P1_4==0);Delay(20);KeyNumber=13;}
P1=0xFF;
P1_2=0;
if(P1_7==0){Delay(20);while(P1_7==0);Delay(20);KeyNumber=2;}
if(P1_6==0){Delay(20);while(P1_6==0);Delay(20);KeyNumber=6;}
if(P1_5==0){Delay(20);while(P1_5==0);Delay(20);KeyNumber=10;}
if(P1_4==0){Delay(20);while(P1_4==0);Delay(20);KeyNumber=14;}
P1=0xFF;
P1_1=0;
if(P1_7==0){Delay(20);while(P1_7==0);Delay(20);KeyNumber=3;}
if(P1_6==0){Delay(20);while(P1_6==0);Delay(20);KeyNumber=7;}
if(P1_5==0){Delay(20);while(P1_5==0);Delay(20);KeyNumber=11;}
if(P1_4==0){Delay(20);while(P1_4==0);Delay(20);KeyNumber=15;}
P1=0xFF;
P1_0=0;
if(P1_7==0){Delay(20);while(P1_7==0);Delay(20);KeyNumber=4;}
if(P1_6==0){Delay(20);while(P1_6==0);Delay(20);KeyNumber=8;}
if(P1_5==0){Delay(20);while(P1_5==0);Delay(20);KeyNumber=12;}
if(P1_4==0){Delay(20);while(P1_4==0);Delay(20);KeyNumber=16;}
return KeyNumber;
}
void Delay(unsigned int xms)
{
unsigned char i, j;
while(xms--)
{
i = 2;
j = 239;
do
{
while (--j);
} while (--i);
}
}
到了这里,关于51单片机:数码管和矩阵按键的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!