51_蓝桥杯_独立按键

一 电路

注意:J5跳帽接到2~3引脚,使按键S4-S5四个按键的另外一端接地,从而成为4个独立按键。

二 独立按键工作原理

三 代码

代码1:按下S7点亮L1指示灯,松开按键,指示灯熄灭,按下S6点亮L2指示灯,按下S5点亮L3指示灯,按下S4点亮L4指示灯。

复制代码
#include "reg52.h"

void Delay(unsignde int t)
{
  while(t--);
}//实现延时功能的函数
 
void InitHC138(unsigned char n)
{
 switch (n)
 { 
   case 4;
      HC138_C = 1;
      HC138_B = 0;
      HC138_A = 0;//输出Y4
   break;
   case 5;
      HC138_C = 1;
      HC138_B = 0;
      HC138_A = 1;//输出Y5
   break;
case 4;
      HC138_C = 1;
      HC138_B = 1;
      HC138_A = 0;//输出Y6
   break;
   case 5;
      HC138_C = 1;
      HC138_B = 1;
      HC138_A = 1;//输出Y7
   break;
 }
}//锁存器选择

void dulianjian()
{
  if(S7 == 0)
  {
   Delay(100);
    if(S7 == 0)
    {
      L1 = 0;
      while(S7 == 0)
      L1 = 1;
     }
    }

   if(S6 == 0)
   {
   Delay(100);
    if(S6 == 0)
    {
      L2 = 0;
      while(S5 == 0)
      L2 = 1;
     }
    }

   if(S5 == 0)
   {
   Delay(100);
    if(S5 == 0)
    {
      L3 = 0;
      while(S5 == 0)
      L3 = 1;
     }
    }

   if(S4 == 0)
   {
   Delay(100);
    if(S4 == 0)
    {
      L4 = 0;
      while(S4 == 0)
      L4 = 1;
     }
    }
}

void main()
{
  InitHC138(4);
  while(1)
  {
    dulianjian();
  }
}

代码2 : S7点亮L1时,S6不可执行操作,S5点亮L3,S4点亮L4;

S6点亮L2时,S7不可执行操作,S5点亮L5,S4点亮L6;

L1,L2均未被点亮时,S5,S4均不可执行操作。

复制代码
#include "reg52.h"

void Delay(unsignde int t)
{
  while(t--);
}//实现延时功能的函数
 
void InitHC138(unsigned char n)
{
 switch (n)
 { 
   case 4;
      HC138_C = 1;
      HC138_B = 0;
      HC138_A = 0;//输出Y4
   break;
   case 5;
      HC138_C = 1;
      HC138_B = 0;
      HC138_A = 1;//输出Y5
   break;
case 4;
      HC138_C = 1;
      HC138_B = 1;
      HC138_A = 0;//输出Y6
   break;
   case 5;
      HC138_C = 1;
      HC138_B = 1;
      HC138_A = 1;//输出Y7
   break;
 }
}//锁存器选择

unsigned char stat_k = 0;
void dulianjian()
{
  if(S7 == 0)
  {
   Delay(100);
    if(stat_k == 0)
    {
      L1 = 0;
      stat_k = 1;
    }
      else if(stat_k = 1)
      L1 = 1;
      stat_k = 0;
     }
    }

   
  if(S6 == 0)
  {
   Delay(100);
    if(stat_k == 0)
    {
      L2 = 0;
      stat_k = 2;
    }
      else if(stat_k = 2)
      L2 = 1;
      stat_k = 0;
     }
    }

   if(S5 == 0)
  {
   Delay(100);
    if(stat_k == 1)
    {
      L3 = 0;
      while(S5 == 0);
      L3 = 1;
    }
      else if(stat_k = 2)
      L5 = 0;
      while(S5 == 0);
      L5 = 1;
     }
    }
   if(S4 == 0)
  {
   Delay(100);
    if(stat_k == 1)
    {
      L4 = 0;
      while(S5 == 0);
      L4 = 1;
    }
      else if(stat_k = 2)
      L6 = 0;
      while(S5 == 0);
      L6 = 1;
     }
    }
}

void main()
{
  InitHC138(4);
  while(1)
  {
    dulianjian();
  }
}
相关推荐
wuminyu8 分钟前
Java锁机制之Java对象重量级锁源码剖析
java·linux·c语言·jvm·c++
apocelipes1 小时前
GNU GCC 多版本函数扩展
c语言·c++·linux编程
辰痕~1 小时前
指针,结构体,动态内存分配
c语言
Zik----2 小时前
保研面试拷打
面试·职场和发展
luj_17682 小时前
残熵算法:风险缓冲与效率优化的融合
c语言·开发语言·网络·经验分享·算法
Legendary_0083 小时前
从 DC 圆口到 USB-C PD:LED 照明设备的供电升级逻辑
c语言·开发语言
运筹vivo@3 小时前
LeetCode 2574. 左右元素和的差值
算法·leetcode·职场和发展·每日一题
ychqsq3 小时前
45.新芽
经验分享·职场和发展
@insist1234 小时前
系统架构设计师-安全架构设计:网络安全威胁分类与典型攻击原理
web安全·系统架构·软考·安全架构·系统架构设计师·软件水平考试
一只齐刘海的猫4 小时前
【Leetcode】移动零
算法·leetcode·职场和发展