独立按键的扫描

电路原理分析

按键部分[以使用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 为 0
    ADDR0 = 0;
    ADDR1 = 1;
    ADDR2 = 1;
    
    //keyOut3 为0,其他均为1
    P2 = 0xFD;
    
    while (1)
    {
        LED9 = KeyIn1;//K9控制LED9
        LED8 = KeyIn2;//K10控制LED8
        LED7 = KeyIn3;//K11控制LED7
        LED6 = 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++;//按键次数+1
				if (cnt >= 10)//只用一个数码管显示,所以加到10就清零重新开始
					cnt = 0;
				P0 = LedChar[cnt];
			}
			backup = KeyIn4;//更新备份为当前值,以备进行下次比较
		}
	}
}

 bit51单片机特有的变量类型,bit型是1位数据,只占用一个位(bit)的内存,用法和其他的基本数据类型一样。优点:节省内存空间,8个bit变量才相当于一个char变量所占用的空间。只有0和1两个值

以上代码实现的主要功能:在按下按键后弹起的过程中,数码管会显示按键弹起次数,当按键弹起10次数码管会变成0,重新开始计数,按下的时候,不作任何处理

posted @ 2024-12-04 11:56  EricsT  阅读(34)  评论(0编辑  收藏  举报