单片机矩阵键盘

#ifndef KEYBOARD_H
#define KEYBOARD_H
unsigned char readKey();
#endif

#include"reg52.h"
#include"Keyboard.h"
#include"delay.h"
#define KEY P1
bit isKeyInput(){
unsigned char tmp;
KEY=0xF0;
tmp=KEY;
tmp=tmp&0xF0;
if(tmp!=0xf0){
return 1;
}else
{
return 0;
}
}
unsigned char KeyScan(){
KEY=0XFF;
KEY=0XFE;
if(KEY0X7E) return 7;//1,1
if(KEY
0XBE) return 11;//1,2
if(KEY0XDE) return 15;//1,3
if(KEY
0XEE) return 19;//1,4

KEY=0XFD;
if(KEY0X7D) return 6;//2,1
if(KEY
0XBD) return 10;//2,2
if(KEY0XDD) return 14;//2,3
if(KEY
0XED) return 18;//2,4

KEY=0XFB;
if(KEY0X7B) return 5;//3,1
if(KEY
0XBB) return 9;//3,2
if(KEY0XDB) return 13;//3,3
if(KEY
0XEB) return 17;//3,4

KEY=0XF7;
if(KEY0X77) return 4;//2,1
if(KEY
0XB7) return 8;//2,2
if(KEY0XD7) return 12;//2,3
if(KEY
0XE7) return 16;//2,4

return 0;
}
void waitKeyRelease(){
unsigned char tmp;
while(1)
{
KEY=0XF0;
tmp=KEY;
tmp=tmp&0XF0;
if(tmp==0XF0){
break;
}
}
}
unsigned char readKey(){
unsigned char keycode=0;
if(isKeyInput()){
delayMs(2);
if(isKeyInput()){
keycode=KeyScan();
waitKeyRelease();
}
}
return keycode;
}

#include"reg52.h"
#include"ls138.h"
sfr P4=0xC0;
sbit R1=P1^0;
sbit R2=P1^1;
sbit R3=P1^2;
sbit R4=P1^3;
sbit C4=P1^4;
sbit C3=P1^5;
sbit C2=P1^6;
sbit C1=P1^7;
unsigned char code SMG_duanma[18] =
{0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,
0x80,0x90,0x88,0x80,0xc6,0xc0,0x86,0x8e,
0xbf,0x7f};

void DisplayKeyNum(unsigned char value)
{
SelectHC573(6);
P0=0x01;
SelectHC573(7);
P0=value;
}
unsigned char key_num;
void ScanKeyMulti()
{
R1=0;
R2=R3=R4=1;
C1=C2=C3=C4=1;
if(C10)
{
while(C1
0);
key_num=0;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C20)
{
while(C2
0);
key_num=1;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C30)
{
while(C3
0);
key_num=2;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C40)
{
while(C4
0);
key_num=3;
DisplayKeyNum(SMG_duanma[key_num]);
}

R2=0;
R1=R3=R4=1;
C1=C2=C3=C4=1;
if(C10)
{
while(C1
0);
key_num=4;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C20)
{
while(C2
0);
key_num=5;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C30)
{
while(C3
0);
key_num=6;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C40)
{
while(C4
0);
key_num=7;
DisplayKeyNum(SMG_duanma[key_num]);
}

R3=0;
R2=R1=R4=1;
C1=C2=C3=C4=1;
if(C10)
{
while(C1
0);
key_num=8;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C20)
{
while(C2
0);
key_num=9;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C30)
{
while(C3
0);
key_num=10;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C40)
{
while(C4
0);
key_num=11;
DisplayKeyNum(SMG_duanma[key_num]);
}

R4=0;
R2=R3=R1=1;
C1=C2=C3=C4=1;
if(C10)
{
while(C1
0);
key_num=12;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C20)
{
while(C2
0);
key_num=13;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C30)
{
while(C3
0);
key_num=14;
DisplayKeyNum(SMG_duanma[key_num]);
}
else if(C40)
{
while(C4
0);
key_num=15;
DisplayKeyNum(SMG_duanma[key_num]);
}
}
void main()
{
while(1)
{
ScanKeyMulti();
}
}

#include"ls138.h"
#include"reg52.h"
void SelectHC573(unsigned char channel)
{

switch(channel)
{
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;
case 0:P2=(P2&0x1f)|0x00;
break;
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值