蓝桥杯单片机必备知识—–(5)独立按键

蓝桥杯单片机必备知识—–(5)独立按键

蓝桥杯单片机必备知识—–(5)独立按键

独立按键

在这里插入图片描述
注:在使用独立按键部分时,需将跳线帽放置BIT端

代码逻辑:

1.放在while(1)一直扫描按键是否按下
2.放在中断中 中断一次扫描按键是否按下
注:大型项目会放在中断中进行,一直扫描会占用过多资源,如果参加比赛则可以在while中一直使用循环

按键扫描函数

void read_key()
{
   
	uchar temp;  
	static unsigned state = 0;		//状态
	temp = P3 & 0x0f; 	//临时存储P3的状态
	switch(state)
	{
   
		case 0:{
   if(P3 != 0x0f) state = 1;}break;	//状态0,检测到有按键按下
		case 1:										//再次检测是否有按键按下,消抖
		{
   
			if(P3 != 0x0f){
   
			switch(temp)
			{
   
				case 0x0e:{
   s7++;state = 2;}break;	//如果S7按键对应的状态改变,则s7++
				case 0x0d:{
   s6++;state = 2;}break;	//如果S6按键对应的状态改变,则s7++
				case 0x0b:{
   s5++;state = 2;}break;	//如果S5按键对应的状态改变,则s7++
				case 0x07:{
   s4++;state = 2;}break;	//如果S4按键对应的状态改变,则s7++
			}
			}
			else state = 0;
		}break;
		case 2:{
   if(P3 == 0xff) state = 0;}break;	//检测按键是否抬起
	}
}

中断函数

void time0() interrupt 1
{
   
	static unsigned char intr = 0;
	display();
	if(++intr == 8) 	//按键消抖时间为5~10ms 
	{
   
		intr = 0;
		read_key();		//进行键扫描
	}
}

主函数内容不再赘述,如有不明白请看1,2中的内容

测试结果:

在这里插入图片描述

代码粘贴

#include <stc15f2k60s2.h>

#define uint unsigned int
#define uchar unsigned char

uchar tab[] = {
   0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff};
uchar dspbuf[8] = {
   10,10,10,10,10,10,10,10};
uchar s4 =0 ,s5 = 0,s6 = 0,s7 = 0;

void read_key();
void display();
void load();
void cls()
{
   
	//关闭LED
	P2 = (P2 & 0x1f) | 0x80;
	P0 = 0xff;
	P2 = 0x1f;
	//关闭BUZZ
	P2 = (P2 & 0x1f) | 0xa0;
	P0 = 0x00;
	P2 = 0x1f;
}

void main()
{
   
	cls();
	AUXR = 0x80;
	TMOD = 0x80;
	TL0 = 0xcd;
	TH0 = 0xd4;
	
	TR0 = 1;
	ET0 = 1;
	EA = 1;
	while(1)
	{
   }
}

void time0() interrupt 1
{
   
	static unsigned char intr = 0;
	display();
	if(++intr == 8) 	
	{
   
		intr = 0;
		read_key();
	}
}

void read_key()
{
   
	uchar temp;
	static unsigned state = 0;
	temp = P3 & 0x0f;
	switch(state)
	{
   
		case 0:{
   if(P3 != 0x0f) state = 1;}break;
		case 1:
		{
   
			if(P3 != 0x0f){
   
			switch(temp)
			{
   
				case 0x0e:{
   s7++;state = 2;}break;
				case 0x0d:{
   s6++;state = 2;}break;
				case 0x0b:{
   s5++;state = 2;}break;
				case 0x07:{
   s4++;state = 2;}break;
			}
			}
			else state = 0;
		}break;
		case 2:{
   if(P3 == 0xff) state = 0;}break;
	}
}

void load()
{
   
	
	dspbuf[0] = s4;
	dspbuf[1] = s5;
	dspbuf[2] = s6;
	dspbuf[3] = s7;
	dspbuf[4] = 10;
	dspbuf[5] = 10;
	dspbuf[6] = 10;
	dspbuf[7] = 10;
}

void display()
{
   
	static unsigned char dspcom = 0;
	load();
	P2 = (P2 & 0x1f) | 0xe0;
	P0 = 0xff;
	P2 = 0x1f;
	
	P2 = (P2 & 0x1f) | 0xc0;
	P0 = 1 << dspcom;
	P2 = 0x1f;
	
	P2 = (P2 & 0x1f) | 0xe0;
	P0 = tab[dspbuf[dspcom]];
	P2 = 0x1f;
	
	if(++dspcom == 8) dspcom = 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100136.html原文链接:https://javaforall.net

(0)
上一篇 2021年4月13日 下午1:00
下一篇 2021年4月13日 下午3:19


相关推荐

  • mybatiscodehelperpro激活码[最新免费获取]

    (mybatiscodehelperpro激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月26日
    408
  • SQL Server数据仓库的基础架构规划

    SQL Server数据仓库的基础架构规划

    2021年11月27日
    38
  • SQL嵌套查询_sql差集嵌套

    SQL嵌套查询_sql差集嵌套selecttop11from…主要是用来判断表是否有记录TRUNCATE:删除内容、释放空间但不删除定义,保留数据表的结构删除目标表中所有字段,不影响表结构派生表:派生表就是一个由查询结果生成的临时表。他是在外部查询的FROM中定义的。派生表的存在范围只是在外部查询中,只要外部查询结束了,派生表也就不存在了。派生表一定要写在FROM后面范围内,用()括起来。后面跟着派生表的名称。se…

    2022年8月10日
    9
  • pycharm的优势_jupyter pycharm

    pycharm的优势_jupyter pycharm一直用sublime,最近写服务器和客户端的程序时就有些坑了,所以我简单说一下我遇到的他们的区别sublime优点:1.字体好看,界面简洁,看起来很爽2.轻便,直接把目录拖进去就行了,不用创建项目什么的。打开只需0.1秒~但你想要的功能基本都有,还有很多酷炫的插件让你锦上添花3.写代码很酷啊,你去看下sublime官网就知道了,比如多行编辑(这个确实用到过),还有各种快捷键让…

    2022年8月29日
    4
  • ELK入门

    ELK入门ELK入门

    2022年4月25日
    33
  • oracle之表空间(tablespace)、方案(schema)、段(segment)、区(extent)、块(block)

    oracle之表空间(tablespace)、方案(schema)、段(segment)、区(extent)、块(block)

    2021年11月13日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号