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();
  }
}
相关推荐
win x7 分钟前
JavaSE(基础)高频面试点及 知识点
java·面试·职场和发展
zhangx1234_1 小时前
C语言 数据在内存中的存储
c语言·开发语言
嵌入小生0072 小时前
双向链表、双向循环链表之间的异同---嵌入式入门---Linux
linux·c语言·数据结构·链表·嵌入式·小白
C澒2 小时前
前端技术核心领域与实践方向
前端·系统架构
BoJerry7773 小时前
数据结构——单链表(不带头)【C】
c语言·开发语言·数据结构
进击的小头3 小时前
设计模式组合应用:智能硬件控制系统
c语言·设计模式
EmbedLinX3 小时前
FreeRTOS 学习笔记
c语言·笔记·学习
橘颂TA3 小时前
【剑斩OFFER】算法的暴力美学——力扣 207 题:课程表
数据结构·c++·算法·leetcode·职场和发展
谁刺我心3 小时前
【蓝桥杯刷题环境】VScode插件算法刷题Competitive Companion
职场和发展·蓝桥杯
学嵌入式的小杨同学3 小时前
【Linux 封神之路】文件操作 + 时间编程实战:从缓冲区到时间格式化全解析
linux·c语言·开发语言·前端·数据库·算法·ux