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

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

蓝桥杯的矩阵按键的扫描,使用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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux stat函数_python系统调用函数

    Linux stat函数_python系统调用函数Linux系统调用函数stat详解,以及文件信息结构体structstat结构体详解。

    2022年8月21日
    7
  • linux的linux-aarch64和 linux-x86_64「建议收藏」

    linux的linux-aarch64和 linux-x86_64「建议收藏」在下载linuxtar包的时候可以看到有下面两种tar包。。。。。。。。什么意思呢?linux-aarch64.tar.gzlinux-x86_64.tar.gz是指服务器内核版本使用命令$arch即可查看自己linux的内核版本。正常情况下下载x86的就可以这个说是cpu架构https://blog.csdn.net/rd_w_csdn/article/details/53841018这个说是交叉编译工具链应该也是提供一个aarch64内核…

    2022年10月17日
    2
  • WinRAR去除广告

    WinRAR去除广告WinRAR5.40去除广告方法,屏蔽广告弹窗方法,亲测有效winrar5.50去广告教程(仅供学习使用)[Windows]自己动手winRAR去广告删代码

    2022年4月30日
    35
  • python 生成数组_Python创建数组「建议收藏」

    python 生成数组_Python创建数组「建议收藏」1创建数组array函数>>>a=([1,2],[3,4])>>>array(a)array([[1,2],[3,4]])arange函数:指定初始值、终值、步长来创建数组>>>importnumpy>>>numpy.arange(0,1,0.1)array([0.,0.1,0.2,0.3,0.4…

    2022年5月9日
    294
  • 投影矩阵的计算_投影矩阵的几何意义

    投影矩阵的计算_投影矩阵的几何意义在进行迭代重建的过程中,我们首先需要求出投影矩阵之后才能进行其他后续的操作,在迭代重建中起到了基石的作用。并且在前面的文章中《迭代重建算法中投影矩阵的计算》已经给出了一种方法,但是我发现在程序的运行过程中存在一些未知的bug,导致程序在计算某些角度的投影矩阵时出现错误。由于一直没有找到出现bug的原因,因此我改变了计算思路,找到了下文中正确的计算方法。首先需要证明一条直线与一个正方形相交。假设一个正方形的左上角的顶点坐标为(xk,yk),那么其余三个点的坐标也就能够写出来…

    2022年10月4日
    2
  • C++之运算符重载

    C++预定义中的运算符的操作对象只限于基本的内置数据类型,但是对于我们自定义的类型(类)是没有办法操作的,但是大多时候我们需要对我们定义的类型进行类似的运算,这个时候就需要我们对运算符进行重新定义,赋

    2021年12月19日
    60

发表回复

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

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