当前位置:首页 > 单片机 > 单片机
[导读]#includesbitADDR0=P1^0;sbitADDR1=P1^1;sbitADDR2=P1^2;sbitADDR3=P1^3;sbitENLED=P1^4;sbitKEY_IN_1=P2^4;sbitKEY_IN_2=P2^5;sbitKEY_IN_3=P2^6;sbitKEY_IN_4=P2^7;sbitKEY_OUT_1=P2^3;sbitKEY_OUT_2=P2^2;sbitKEY

#include

sbitADDR0=P1^0;

sbitADDR1=P1^1;

sbitADDR2=P1^2;

sbitADDR3=P1^3;

sbitENLED=P1^4;

sbitKEY_IN_1=P2^4;

sbitKEY_IN_2=P2^5;

sbitKEY_IN_3=P2^6;

sbitKEY_IN_4=P2^7;

sbitKEY_OUT_1=P2^3;

sbitKEY_OUT_2=P2^2;

sbitKEY_OUT_3=P2^1;

sbitKEY_OUT_4=P2^0;

codeunsignedcharLedChar[]={//数码管显示字符转换表

0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,

0x80,0x90,0x88,0x83,0xC6,0xA1,0x86,0x8E

};

unsignedcharKeySta[4][4]={//全部矩阵按键的当前状态

{1,1,1,1},

{1,1,1,1},

{1,1,1,1},

{1,1,1,1}

};

voidmain(){

unsignedchari,j;

unsignedcharbackup[4][4]={//按键值备份,保存前一次的值

{1,1,1,1},

{1,1,1,1},

{1,1,1,1},

{1,1,1,1}

};

EA=1;//使能总中断

ENLED=0;//选择数码管DS1进行显示

ADDR3=1;

ADDR2=0;

ADDR1=0;

ADDR0=0;

TMOD=0x01;//设置T0为模式1

TH0=0xFC;//为T0赋初值0xFC67,定时1ms

TL0=0x67;

ET0=1;//使能T0中断

TR0=1;//启动T0

P0=LedChar[0];//默认显示0

while(1){

for(i=0;i<4;i++){//循环检测4*4的矩阵按键

for(j=0;j<4;j++){

if(KeySta[i][j]!=backup[i][j]){//检测按键动作

if(KeySta[i][j]==0){//按键按下时执行动作

P0=LedChar[i*4+j];//将编号显示到数码管

}

backup[i][j]=KeySta[i][j];//更新前一次的备份值

}

}

}

}

}

/*T0中断服务函数,扫描矩阵按键状态并消抖*/

voidInterruptTimer0()interrupt1{

unsignedcharj;

staticunsignedchari=0;//矩阵按键扫描输出索引

staticunsignedcharkeybuf[4][4]={//矩阵按键扫描缓冲区

{0xFF,0xFF,0xFF,0xFF},

{0xFF,0xFF,0xFF,0xFF},

{0xFF,0xFF,0xFF,0xFF},

{0xFF,0xFF,0xFF,0xFF}

};

TH0=0xFC;//重新加载初值

TL0=0x67;

//将一行的4个按键值移入缓冲区

keybuf[i][0]=(keybuf[i][0]<<1)|KEY_IN_1;

keybuf[i][1]=(keybuf[i][1]<<1)|KEY_IN_2;

keybuf[i][2]=(keybuf[i][2]<<1)|KEY_IN_3;

keybuf[i][3]=(keybuf[i][3]<<1)|KEY_IN_4;

//消抖后更新按键状态

for(j=0;j<4;j++){//每行4个按键,所以循环4次

if((keybuf[i][j]&0x0F)==0x00){//连续4次扫描值为0,即4*4ms内都是按下状态时,可认为按键已稳定的按下

KeySta[i][j]=0;

}

elseif((keybuf[i][j]&0x0F)==0x0F){//连续4次扫描值为1,即4*4ms内都是弹起状态时,可认为按键已稳定的弹起

KeySta[i][j]=1;

}

}

//执行下一次的扫描输出

switch(i){//根据索引,释放当前输出引脚,拉低下次的输出引脚

case0:KEY_OUT_1=1;KEY_OUT_2=0;break;

case1:KEY_OUT_2=1;KEY_OUT_3=0;break;

case2:KEY_OUT_3=1;KEY_OUT_4=0;break;

case3:KEY_OUT_4=1;KEY_OUT_1=0;break;

default:break;

}

i=++i&0x03;

}


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

STM32与51单片机之间有什么差异呢?两者可以说是一场科技与性能的较量了。在科技飞速发展的今天,微控制器(MCU)已广泛应用于各类电子设备和系统中,发挥着举足轻重的作用。其中,STM32和51单片机作为两种常见的微控制...

关键字: STM32 51单片机 MCU

51单片机将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对51单片机的相关情况以及信息有所认识和了解,详细内容如下。

关键字: 单片机 51单片机

今天说说激光雷达的扫描角度,它的技术原理、应用与挑战是什么呢?激光雷达,作为一种主动式遥感设备,通过发射激光并接收其反射信号来获取目标物体的距离、速度和其他相关信息。扫描角度作为激光雷达的关键参数,决定了其探测范围和分辨...

关键字: 激光雷达 扫描

在嵌入式系统开发中,单片机是不可或缺的重要组成部分。其中,STM32单片机和51单片机是两种常见的单片机芯片。本文将对比分析这两种单片机的区别,并探讨STM32单片机的优势。

关键字: stm32单片 51单片机

51单片机是指由美国INTEL公司生产的一系列单片机的总称,这一系列单片机包括了许多品种,如8031,8051,8751,8032,8052,8752等,其中8051是最早最典型的产品,该系列其它单片机都是在8051的基...

关键字: 51单片机 串行通信

51单片机是一种常见的微控制器,它具有串行通信接口(Serial Communication Interface,SCI)。通过串口通信接口,51单片机可以与其他设备或系统进行串行通信,实现数据传输和控制。

关键字: 51单片机 串口通信

Pic单片机和51单片机是两种应用广泛的微控制器,它们各自具有不同的特点和优势,选择哪种单片机取决于具体应用需求。下面将对Pic单片机和51单片机进行详细的介绍和对比。

关键字: PIC单片机 51单片机 单片机

随着电子信息技术的快速发展,串行通信在各种应用中得到了广泛的应用。其中,51单片机作为一种常见的嵌入式系统,具有低功耗、高性能、易于编程等特点,常用于各种自动化控制、数据采集等系统中。而PC机具有强大的数据处理能力和丰富...

关键字: 51单片机 PC机 串行通信

51 单片机内部有一个全双工串行接口。什么叫全双工串口呢?一般来说,只能接受或只能发送的称为单工串行;既可接收又可发送,但不能同时进行的称为半双工;能同时接收和发送的串行口称为全双工串行口。

关键字: 51单片机 串口通信 半双工

步进电机是一种无刷电机,可将电脉冲转换为机械旋转。顾名思义,它根据输入脉冲逐步旋转,是现代数字程序控制系统中的主要执行元件。

关键字: 51单片机 步进电机 无刷电机
关闭
关闭