//行列掃描程序,可以自己定義端口和掃描方式,這里做簡單介紹 //***********謝海斌于九江 期末考前一天******************************//
//keyboard.c 這里的行與列的掃描,也就是把字節的8位,高四位與低四位分開來,從而確定坐標。
//行列掃描程序,可以自己定義端口和掃描方式,這里做簡單介紹
#include <reg52.h>//包含頭文件
#define uchar unsigned char
#define uint unsigned int
unsigned char const dofly[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};
uchar keyscan(void); //主要的矩陣鍵盤掃描函數。
void delay(uint i);
void main()
{
uchar key;
P2=0x00;//1數碼管亮 按相應的按鍵,會顯示按鍵上的字符
while(1)
{
key=keyscan();//調用鍵盤掃描,
switch(key)
{
case 0x7e:P0=dofly[0];break;//0 按下相應的鍵顯示相對應的碼值 原理就是高四位一列低四位一列的組
//合。0111 1110 7e 0表示按鍵后為0,1表示沒有按鍵按下的。即P3.7與P3.1連接為低電平,為S1鍵
//其他類推。
case 0x7d:P0=dofly[1];break;//1
case 0x7b:P0=dofly[2];break;//2
case 0x77:P0=dofly[3];break;//3
case 0xbe:P0=dofly[4];break;//4
case 0xbd:P0=dofly[5];break;//5
case 0xbb:P0=dofly[6];break;//6
case 0xb7:P0=dofly[7];break;//7unsigned char <<變量名>>[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};
case 0xde:P0=dofly[8];break;//8
case 0xdd:P0=dofly[9];break;//9
case 0xdb:P0=dofly[10];break;//a
case 0xd7:P0=dofly[11];break;//b
case 0xee:P0=dofly[12];break;//c
case 0xed:P0=dofly[13];break;//d
case 0xeb:P0=dofly[14];break;//e
case 0xe7:P0=dofly[15];break;//f
}
}
}
uchar keyscan(void)//鍵盤掃描函數,使用行列反轉掃描法 比如:行為低電位,列為高四位
{
uchar cord_h,cord_l;//行列值
P3=0x0f; //行線輸出全為0
cord_h=P3&0x0f; //讀入列線值
if(cord_h!=0x0f) //先檢測有無按鍵按下
{
delay(100); //去抖
if(cord_h!=0x0f)
{
cord_h=P3&0x0f; //讀入列線值
P3=cord_h|0xf0; //輸出當前列線值
cord_l=P3&0xf0; //讀入行線值
return(cord_h+cord_l);//鍵盤最后組合碼值
}
}return(0xff); //返回該值
}
void delay(uint i)//延時函數
{
while(i--);
}
哈哈,高數考完了,更新下程序。完美解決了按鍵無序的問題, 明天英語,后天回家。想想就很開心吶
|