
我看了幾個小時,在kile上調試過,自己分析過,怎么也分析不出來,先看看我的分析思路。
假如按鍵S10按下,那么P3口是11010000,直接看我的標號1234(if語句里面),應為前面都是判斷鍵按下去沒,
1 cord_h最終還是等于11010000
2 P3運算完后等于11011111
3 cord_l運算完后等于00001111
4 最后cord_h+cord_l返回值是11010000+00001111=11011111;
11011111為0xDF
可是switch選擇里面沒有0xdf這一項。
我分析錯了嗎?
程序下載到單片機里運行正常,可以正常顯示鍵值。
怎么看懂這個反轉掃描法?
//行列掃描程序,可以自己定義端口和掃描方式,這里做簡單介紹 #include <reg52.h>//包含頭文件 #define uchar unsigned char #define uint unsigned int
uchar keyscan(void); void delay(uint i);
void main() { uchar key; P2=0x00;//8數碼管亮 按相應的按鍵,會顯示按鍵上的字符 while(1) { key=keyscan();//調用鍵盤掃描, switch(key) { case 0x7e:P0=0xc0;break;//0 按下相應的鍵顯示相對應的碼值 case 0x7d:P0=0xf9;break;//1 case 0x7b:P0=0xa4;break;//2 case 0x77:P0=0xb0;break;//3 case 0xbe:P0=0x99;break;//4 case 0xbd:P0=0x92;break;//5 case 0xbb:P0=0x82;break;//6 case 0xb7:P0=0xf8;break;//7 case 0xde:P0=0x80;break;//8 case 0xdd:P0=0x90;break;//9 case 0xdb:P0=0x88;break;//a case 0xd7:P0=0x83;break;//b case 0xee:P0=0xc6;break;//c case 0xed:P0=0xa1;break;//d case 0xeb:P0=0x86;break;//e case 0xe7:P0=0x8e;break;//f } } } uchar keyscan(void)//鍵盤掃描函數,使用行列反轉掃描法 { uchar cord_h,cord_l;//行列值 P3=0xf0; //行線輸出全為0 cord_h=P3&0xf0; //讀入列線值 if(cord_h!=0xf0) //先檢測有無按鍵按下 { delay(100); //去抖 if(cord_h!=0xf0) { 1 cord_h=P3&0xf0; //讀入列線值 2 P3=cord_h|0x0f; //輸出當前列線值 3 cord_l=P3&0x0f; //讀入行線值 4 return(cord_h+cord_l);//鍵盤最后組合碼值并返回 } }return(0xff); //否則返回固定值0xff }
void delay(uint i)//延時函數 { while(i--); } |