先在P3口输出
p3 00001111
低四位 行会有变化
cord_h =00001111&00001110 =00001110
if !=00001111
延时0.1us
cord_h=00001110&00001111=00001110
if !=00001111
P3再输出11111110
P3=00001110|11110000=11111110
输出高四位
cord_l=P3&0xf0 //此时P3口就是输入值01111110 而不是上面的11111110
cord_l=01111110&11110000=01110000
cord_h+cord_l=00001110+01110000=01111110=0x7e //此编码即为S1的编码
#include <reg52.h>//包含头文件
#define uchar unsigned char
#define uint unsigned int
unsigned char const table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,
0x77,0x7c,0x39,0x5e,0x79,0x71}//0-F
uchar keyscan(void)
void delay(uint i)
void main()
{
uchar key
P2=0x00//1数码管亮 按相应的按键,会显示按键上的字符
while(1)
{
key=keyscan()//调用键盘扫描,
switch(key)
{
case 0x7e:P0=table[0]break//0 按下相应的键显示相对应的码值
case 0x7d:P0=table[1]break//1
case 0x7b:P0=table[2]break//2
case 0x77:P0=table[3]break//3
case 0xbe:P0=table[4]break//4
case 0xbd:P0=table[5]break//5
case 0xbb:P0=table[6]break//6
case 0xb7:P0=table[7]break//7
case 0xde:P0=table[8]break//8
case 0xdd:P0=table[9]break//9
case 0xdb:P0=table[10]break//a
case 0xd7:P0=table[11]break//b
case 0xee:P0=table[12]break//c
case 0xed:P0=table[13]break//d
case 0xeb:P0=table[14]break//e
case 0xe7:P0=table[15]break//f
}
}
}
uchar keyscan(void)//键盘扫描函数,使用行列反转扫描法
{
uchar cord_h,cord_l//行列值
P3=0x0f //行线输出全为0
cord_h=P3&0x0f//读入列线值
if(cord_h!=0x0f)//先检测有无按键按下
{
delay(100) //去抖
cord_h=P3&0x0f //读入列线值
if(cord_h!=0x0f)
{
P3=cord_h|0xf0 //输出当前列线值
cord_l=P3&0xf0 //读入行线值
return(cord_h+cord_l)//键盘最后组合码值
}
}return(0xff)//返回该值
}
void delay(uint i)//延时函数
{
while(i--)
}
这矩阵按键是怎么接的?把开发板的原理图发上来。还有开发版上最右边的4个LED灯指示是怎么接的,不知道也不好写程序的。用仿真图实现你的要求,用了4X4的矩阵按键,接在P3口,4个LED灯接在P0口了,仿真效果如下所示。
/*按键扫描函数*/void keyScan(void)
{
//P3=0x00
col1=0col2=1col3=1col4=1
temp=P2&0x3f
if(col1==0) //假设第一列有按键
{
if(temp!=0x3f) //没有按键退出这次对第一列键盘扫描
{
temp=P2&0x3C // 3CH=00111100,目的是先把P2.2、P2.3、P2.4、P2.5 这中间四位先置1,即预读先置1,做好输入的准备
switch(temp)
{
case 0x38: key=12 break
// 38H=00111000,只看中间四位,其中只有P2.2=0,代表第4行第1列为低电平,所在键值恰好是12(即C)
case 0x34:key=8break
// 34H=00110100,只看中间四位,其中只有P2.3=0,代表第3行第1列为低电平,所在键值恰好是8
case 0x2C:key=4break
// 2CH=00101100,只看中间四位,其中只有P2.4=0,代表第2行第1列为低电平,所在键值恰好是4
case 0x1C:key=0break
// 1CH=00011100,只看中间四位,其中只有P2.5=0,代表第0行第1列为低电平,所在键值恰好是0
}
}
}
col1=1col2=0col3=1col4=1
temp=P2
temp=temp&0x3f
if(col2==0)
{
if(temp!=0x3f)
{
temp=P2&0x3C
switch(temp)
{
case 0x38: key=13break//’0’键被按下时导通,则对应端口变为低电平
case 0x34:key=9break
case 0x2C:key=5break
case 0x1C:key=1break
}
}
}
col1=1col2=1col3=0col4=1
temp=P2
temp=temp&0x3f
if(temp!=0x3f)
{
temp=P2&0x3C
switch(temp)
{
case 0x38: key=14break//’0’键被按下时导通,则对应端口变为低电平
case 0x34:key=10break
case 0x2C:key=6break
case 0x1C:key=2break
}
}
col1=1col2=1col3=1col4=0
temp=P2
temp=temp&0x3f
if(temp!=0x3f)
{
temp=P2&0x3C
switch(temp)
{
case 0x38: key=15break//’0’键被按下时导通,则对应端口变为低电平
case 0x34:key=11break
case 0x2C:key=7break
case 0x1C:key=3break
}
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)