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();
  }
}
相关推荐
小程故事多_807 小时前
[大模型面试系列] 多轮对话 Agent 设计实战(含窗口优化 + 工具调用精髓)
人工智能·面试·职场和发展
leoufung7 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
代码中介商8 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
童园管理札记9 小时前
【续】数字时代:学前教育的新改革
经验分享·深度学习·职场和发展·微信公众平台
爱编码的小八嘎10 小时前
C语言完美演绎9-12
c语言
迦南的迦 亚索的索11 小时前
AI_11_Coze_AI面试助手
人工智能·面试·职场和发展
童园管理札记11 小时前
数字时代:学前教育的新改革
经验分享·职场和发展·学习方法·微信公众平台
开发小程序的之朴12 小时前
基于Go语言的企业级CMS系统架构设计与性能分析——以AnQiCMS为例
开发语言·golang·系统架构
Navigator_Z12 小时前
LeetCode //C - 1031. Maximum Sum of Two Non-Overlapping Subarrays
c语言·算法·leetcode
逻辑驱动的ken13 小时前
Java高频面试场景题19
java·开发语言·面试·职场和发展·求职招聘