前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >3.3 51单片机-独立按键

3.3 51单片机-独立按键

作者头像
DS小龙哥
发布于 2022-01-12 05:51:31
发布于 2022-01-12 05:51:31
56100
代码可运行
举报
运行总次数:0
代码可运行

3.3 独立按键

3.3.1 按键原理图

图3-3-1

图3-3-2

JP165跳线帽断开、JP10连接J12(为了实现按键控制LED灯的效果)、JP5连接JP8、J21接左边

3.3.2 示例代码

下面代码都使用多文件编程模型,这里贴出每个文件的主要代码。

下面代码实现的效果是,按下按键控制LED灯。

Main.c文件:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include <reg51.h>
#include "delay.h"
#include "key.h"
#include "type.h"
#include "led.h"

int main()
{
    u8 key; 
    LED=0; //关闭所有LED灯,51单片机默认输出高电平,LED默认高电平点亮
    while(1)
    {
        key=Key_Scan();
        if(key)
        {
            LED=~LED; //控制8盏灯
        }
}
}

Key.h文件代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#ifndef KEY_H
#define KEY_H
#include <reg51.h>
#include "type.h"
#include "delay.h"
#include "led.h"
u8 Key_Scan(void);
#define KEY P1  //定义按键
sbit key1=KEY^0;
sbit key2=KEY^1;
sbit key3=KEY^2;
sbit key4=KEY^3;
sbit key5=KEY^4;
sbit key6=KEY^5;
sbit key7=KEY^6;
sbit key8=KEY^7;
#endif

Key.c文件代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include "key.h"
/*
按键扫描函数
*/
u8 Key_Scan(void)
{
    static u8 flag=0;
    if((KEY!=0xFF)&&(flag==0)) //判断有没有按键按下
    {
        DelayMs(20); //消抖
        flag=1; //标志按键已经被按下
        if(key1==0)return 1;
        if(key2==0)return 2;
        if(key3==0)return 3;
        if(key4==0)return 4;
        if(key5==0)return 5;
        if(key6==0)return 6;
        if(key7==0)return 7;
        if(key8==0)return 8;
    }
    else if(KEY==0xFF) //判断按键是否全部松开
    {
        flag=0; //清除按下标志位
    }
    return 0;
}

Led.h文件代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#ifndef LED_H
#define LED_H
#include <reg51.h>
#include "type.h"
#include "delay.h"

#define LED P0  //定义LED引脚
sbit LED1=P0^0;
sbit LED2=P0^1;
sbit LED3=P0^2;
sbit LED4=P0^3;
sbit LED5=P0^4;
sbit LED6=P0^5;
sbit LED7=P0^6;
sbit LED8=P0^7;
#endif

Type.h文件代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#ifndef TYPE_H
#define TYPE_H
typedef unsigned char u8;
typedef unsigned short u16;
typedef unsigned int u32;
#endif
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/11/01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 3.3 独立按键
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档