电路原理分析
按键部分[以使用K9\K10\K11\K12为例]
首先,将 KeyOut3 置 0 ,其他三条分路[KeyOut1、KeyOut2、KeyOut4]置1,此时, KeyOut3 分路的按键 K9\K10\K11\K12 作为 4 个独立按键处理
将此 4 个按键的状态直接送给小灯,即可控制小灯的亮灭:
按下 K9 ,此时 KeyIn1 变为 0
按下 K10 ,此时 KeyIn2 变为 0
按下 K11 ,此时 KeyIn3 变为 0
按下 K12 ,此时 KeyIn4 变为 0
小灯部分
小灯部分的电路原理分析详见https://www.cnblogs.com/EricsT/p/18442768
以下做简单概要
P1.4 置 0,即 ENLED 置0
在下图中将跳线连接在显示译码部分,即 ADDR0 与 P1.0 连线,ADDR1 与 P1.1 连线,ADDR2 与 P1.2 连线,ADDR3 与 P1.3 连线
P1.3 置 1,即 ADDR3 置1
通过以上使能下图的U3[74HC138]芯片
P1.0 置 0,即 ADDR0 置 0
P1.1 置 1,即 ADDR1 置 1
P1.2 置 1,即 ADDR2 置 1
通过以上,则U3芯片 A2 置 1,A1 置 1,A0 置 0,查询下图真值表可知 LEDS6 为 0
通过以上,下图中的Q16[9012]三极管导通,此时,只要DBX为0,则小灯就被点亮
即小灯被点亮:P1.0 = 0; P1.1 = 1; P1.2 = 1; P1.3 = 1; P1.4 = 0;
综合分析
KeyOut3 置 0,即 P2.1 置 0
P1.0 = 0; P1.1 = 1; P1.2 = 1; P1.3 = 1; P1.4 = 0; P2.1 = 0;其余为默认值
将 KeyIn1 的值给 DB7 ,则 K9 的状态控制 LED9 的状态
将 KeyIn2 的值给 DB6 ,则 K10 的状态控制 LED8 的状态
将 KeyIn3 的值给 DB5 ,则 K11 的状态控制 LED7 的状态
将 KeyIn4 的值给 DB4 ,则 K12 的状态控制 LED6 的状态
代码实现
#include <reg52.h>sbit ADDR0 = P1 ^ 0;
sbit ADDR1 = P1 ^ 1;
sbit ADDR2 = P1 ^ 2;
sbit ADDR3 = P1 ^ 3;
sbit ENLED = P1 ^ 4;sbit LED9 = P0 ^ 7;
sbit LED8 = P0 ^ 6;
sbit LED7 = P0 ^ 5;
sbit LED6 = P0 ^ 4;sbit KeyIn4 = P2 ^ 7;
sbit KeyIn3 = P2 ^ 6;
sbit KeyIn2 = P2 ^ 5;
sbit KeyIn1 = P2 ^ 4;void main(void)
{//使能U3[74HC138]芯片ADDR3 = 1;ENLED = 0;// LEDS6 为 0ADDR0 = 0;ADDR1 = 1;ADDR2 = 1;//keyOut3 为0,其他均为1P2 = 0xFD;while (1){LED9 = KeyIn1;//K9控制LED9LED8 = KeyIn2;//K10控制LED8LED7 = KeyIn3;//K11控制LED7LED6 = KeyIn4;//K12控制LED6}
}
电路原理分析
数码管部分
LEDS2为低电平,Q14导通,数码管可使用
数码管电路以及真值表内容详见https://www.cnblogs.com/EricsT/p/18460817
代码部分
#include <reg52.h>sbit ADDR0 = P1 ^ 0;
sbit ADDR1 = P1 ^ 1;
sbit ADDR2 = P1 ^ 2;
sbit ADDR3 = P1 ^ 3;
sbit ENLED = P1 ^ 4;sbit KeyIn4 = P2 ^ 7;unsigned char code LedChar[] =//数码管显示字符转换表
{0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8,0x80, 0x90, 0x88, 0x83, 0xC6, 0xA1, 0x86, 0x8E
};void main(void)
{bit backup = 1;//定义一个位变量,保存前一次扫描的按键值unsigned char cnt = 0;//定义一个计数变量,记录按下的次数ENLED = 0;//选择数码管DS3进行显示ADDR3 = 1;ADDR2 = 0;ADDR1 = 1;ADDR0 = 0;P2 = 0xF7;//P2.3置0,即keyOut1输出低电平P0 = LedChar[cnt];//显示按键次数初值while (1){if (backup != KeyIn4)//当前值与前次值不相等说明此时按键有动作{if (0 == backup)//如果前次值为0,则说明当前由0变1,即按键弹起{cnt++;//按键次数+1if (cnt >= 10)//只用一个数码管显示,所以加到10就清零重新开始cnt = 0;P0 = LedChar[cnt];}backup = KeyIn4;//更新备份为当前值,以备进行下次比较}}
}
bit
51单片机特有的变量类型,bit型是1位数据,只占用一个位(bit)的内存,用法和其他的基本数据类型一样。优点:节省内存空间,8个bit变量才相当于一个char变量所占用的空间。只有0和1两个值
以上代码实现的主要功能:在按下按键后弹起的过程中,数码管会显示按键弹起次数,当按键弹起10次数码管会变成0,重新开始计数,按下的时候,不作任何处理