蓝桥杯单片机矩阵按键扫描编程

蓝桥杯单片机矩阵按键扫描编程

蓝桥杯的矩阵按键的扫描,使用reg52.h头文件的时候需要自定义P4接口,因为在该头文件中并没有定义P4接口。

#include "reg52.h"
#include "intrins.h"

typedef unsigned char u8;
typedef unsigned int u16;

sfr P4 = 0xc0;        // 自定义P4接口,P4^4代替P3^7,P4^2代替P3^6

sbit R1 = P3^0;      // 行
sbit R2 = P3^1;
sbit R3 = P3^2;
sbit R4 = P3^3;

sbit C1 = P4^4;       // 列
sbit C2 = P4^2;
sbit C3 = P3^5;
sbit C4 = P3^4;

u8 temp_keys = 0;             // 按键的位数

u8 code shuma[12] = {
   0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf,0xbf};


  // 外设初始化函数
void init_system()
{
   
    P2 = (P2 & 0x1f) | 0x80;
	P0 = 0xff;
	P2 = (P2 & 0x1f);

	P2 = (P2 & 0x1f) | 0xa0;
	P0 = 0x00;
	P2 = (P2 & 0x1f);

	P2 = (P2 & 0x1f) | 0xc0;
	P0 = 0x00;
	P2 = (P2 & 0x1f);
}


	// 外设选通函数
void select(u8 local)
{
   
    switch(local)
	{
   
	    case(4): P2 = (P2 & 0x1f) | 0x80; break;
		case(5): P2 = (P2 & 0x1f) | 0xa0; break;
		case(6): P2 = (P2 & 0x1f) | 0xc0; break;
		case(7): P2 = (P2 & 0x1f) | 0xe0; break;
	}
}

  // 简单延时函数
void delay()
{
   
    u8 t = 200;
	while(t--);
}

// 数码管点亮函数,单个数码管
void display(u8 local, u8 num)
{
   
    select(6);
	P0 = 0x80 >> (local - 1);
	P2 = P2 & 0x1f;

	select(7);
	P0 = num;
	P2 = P2 & 0x1f;

	delay();
}

// 数码管消隐函数
void close_display()
{
   
    // 消隐
	select(6);
	P0 = 0x00;
	P2 = P2 & 0x1f;
}

// 按键扫描函数
void scan_keys()
{
   
	R1 = 0;
	R2 = R3 = R4 = 1;
	C1 = C2 = C3 = C4 = 1;
	if(C1 == 0)
	{
   
	    delay();
		if(C1 == 0)
		{
   
		    temp_keys = 7;
		}
		while(!C1);
	}
	else if(C2 == 0)
	{
   
	    delay();
		if(C2 == 0)
		{
   
		    temp_keys = 11;
		}
		while(!C2);
	}
	else if(C3 == 0)
	{
   
	    delay();
		if(C3 == 0)
		{
   
		    temp_keys = 15;
		}
		while(!C3);
	}
	else if(C4 == 0)
	{
   
	    delay();
		if(C4 == 0)
		{
   
		    temp_keys = 19;
		}
		while(!C4);
	}


	R2 = 0;
	R1 = R3 = R4 = 1;
	C1 = C2 = C3 = C4 = 1;
	if(C1 == 0)
	{
   
	    delay();
		if(C1 == 0)
		{
   
		    temp_keys = 6;
		}
		while(!C1);
	}
	else if(C2 == 0)
	{
   
	    delay();
		if(C2 == 0)
		{
   
		    temp_keys = 10;
		}
		while(!C2);
	}
	else if(C3 == 0)
	{
   
	    delay();
		if(C3 == 0)
		{
   
		    temp_keys = 14;
		}
		while(!C3);
	}
	else if(C4 == 0)
	{
   
	    delay();
		if(C4 == 0)
		{
   
		    temp_keys = 18;
		}
		while(!C4);
	}

	R3 = 0;
	R2 = R1 = R4 = 1;
	C1 = C2 = C3 = C4 = 1;
	if(C1 == 0)
	{
   
	    delay();
		if(C1 == 0)
		{
   
		    temp_keys = 5;
		}
		while(!C1);
	}
	else if(C2 == 0)
	{
   
	    delay();
		if(C2 == 0)
		{
   
		    temp_keys = 9;
		}
		while(!C2);
	}
	else if(C3 == 0)
	{
   
	    delay();
		if(C3 == 0)
		{
   
		    temp_keys = 13;
		}
		while(!C3);
	}
	else if(C4 == 0)
	{
   
	    delay();
		if(C4 == 0)
		{
   
		    temp_keys = 17;
		}
		while(!C4);
	}

	R4 = 0;
	R2 = R3 = R1 = 1;
	C1 = C2 = C3 = C4 = 1;
	if(C1 == 0)
	{
   
	    delay();
		if(C1 == 0)
		{
   
		    temp_keys = 4;
		}
		while(!C1);
	}
	else if(C2 == 0)
	{
   
	    delay();
		if(C2 == 0)
		{
   
		    temp_keys = 8;
		}
		while(!C2);
	}
	else if(C3 == 0)
	{
   
	    delay();
		if(C3 == 0)
		{
   
		    temp_keys = 12;
		}
		while(!C3);
	}
	else if(C4 == 0)
	{
   
	    delay();
		if(C4 == 0)
		{
   
		    temp_keys = 16;
		}
		while(!C4);
	}

	if(temp_keys == 4)
	   {
   
	       TR1 = ~TR1;
		   t1_sec = t1_sec;
		   t1_min = t1_min;
		   t1_hour = t1_hour;
	   }
	else if(temp_keys == 5)
	   {
   
	       t1_sec = 0;
		   t1_min = 0;
		   t1_hour = 0;
	   }
	else if(temp_keys == 6)
	   {
   
	        select(4);
			P0 = 0xfe;
			P2 = P2 & 0x1f;
	   }
	else if(temp_keys == 7)
	   {
   
	        select(4);
			P0 = 0xff;
			P2 = P2 & 0x1f;	    
	   }	
}


void main()
{
   

	init_system();
    while(1)
	{
   
	   scan_keys(); 
	   display(1, shuma[temp_keys%10]);
	   display(2, shuma[ temp_keys/10]);
	   close_display();
	 	   
	}
}

初始化外设一般都是蓝桥杯一上电就需要完成的事情,关闭蜂鸣器以及继电器还有关闭LED灯和数码管这些外设,不然会使得上电之后无关的外设同时工作影响正常的显示效果。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SQL SERVER 2000数据库置疑 紧急模式

    SQL SERVER 2000数据库置疑 紧急模式SQLSERVER2000数据库,服务重启之后系统库以外的其它库都会出现置疑(置疑之前没有备份的库。除非是置疑前一秒刚备份完,或者是备份完没有再使用,可以直接恢复):1、停掉SQLSERVER服务(开始–控制面板–管理工具–服务–MSSQLSERVER–右键停止)2、找到置疑库的数据文件mdf和ldf存放位置,备份此文件到其它文件夹3、重启SQLSERVER服务

    2022年8月22日
    9
  • 单调栈简介

    单调栈简介何为单调栈栈内元素非递增或者非递减。另一种说法是从栈底到栈顶非递增或者非递减。在很多情况下,可能会出现相同的数字元素,所以称之为非递增或者非递减栈更合适。显而易见,从单调栈的这种结构很容易联想到,在算法中,合理运用单调栈,能够将O(n^2)的时间复杂度优化到O(n),这就是技巧。相对的,空间复杂度会增加,因为需要动态维护一个栈。这里需要明白一点,算法里面,都是时间和空间的取舍,所谓的时空间转换指的就是这个,所以要根据具体场景去选择。适用范围求一个数组每一个的下一个最大值、对一个数组排序、判断当前元素

    2022年9月22日
    4
  • MTP模式与USB存储模式(MTP in Android)「建议收藏」

    MTP模式与USB存储模式(MTP in Android)「建议收藏」转载:http://bbs.meizu.cn/thread-4747416-1-1.htmlMTPinAndroidMTP的全称是MediaTransferProtocol(媒体传输协议),它是微软公司提出的一套媒体文件传输协议。Android从3.0开始支持MTP。不过,在今天的智能手机领域内,Google和微软是一对冤家,为什么Android中会使用MTP呢?请看下文。一背景知…

    2022年4月20日
    117
  • HibernateTemplate详解

    HibernateTemplate详解HibernateTemplate提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。下面是HibernateTemplate的常用方法简介:qvoiddelete(Objectentity):删除指定持久化实

    2022年6月18日
    25
  • C++基本概念_c语言 c++区别

    C++基本概念_c语言 c++区别1.    面向对象的程序设计思想是什么?答:把数据结构和对数据结构进行操作的方法封装形成一个个的对象。 2.    什么是类?答:把一些具有共性的对象归类后形成一个集合,也就是所谓的类。 3.    对象都具有的二方面特征是什么?分别是什么含义?答:对象都具有的特征是:静态特征和动态特征。静态特征是指能描述对象的一些属性;动态特征是指对象表现出来的行为;

    2022年10月3日
    0
  • UPS不间断电源原理_不间断电源ups原理

    UPS不间断电源原理_不间断电源ups原理扫描以下二维码加入学习群

    2025年5月31日
    2

发表回复

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

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