標(biāo)題:
使用掃描后輸出結(jié)果進行邏輯運算的按鍵處理方法?
[打印本頁]
作者:
千早愛音愛玩51
時間:
2025-7-2 22:03
標(biāo)題:
使用掃描后輸出結(jié)果進行邏輯運算的按鍵處理方法?
最近做按鍵功能,想到了一個比較抽象,但是好像也有可行性的方案,那就是
采樣一個按鍵一段時間,比如32次,然后輸出一個int量(實際就是把一個32位的二進制數(shù)組變成了整數(shù)),然后通過運算判斷上升沿數(shù)量(0到1的轉(zhuǎn)換)進而給出按鍵結(jié)果
采樣函數(shù)放進定時器中斷里,每20ms一次,作為長按判斷的時基,實際上我想的對于長按判斷是直接掃描兩次。
采樣函數(shù)
unsigned long sampledata(void){
static unsigned char samplecounter = 0;//8位,可以計數(shù)到255
//輸出4位16進制數(shù),實際上是把一個32位的二進制數(shù)組變成了4位16進制數(shù),便于邏輯運算
static unsigned long u32data = 0;
if(startsampling){//←這里的if
if(samplecounter < 32){
u32data <<= 1;//整體左移一位,低位補0
if (P32 == 1){//采樣引腳
u32data |= 0x01;//如果P32為高才計1,如果為低就繼續(xù)左移一位,也就是補0,記了0
}
samplecounter++;
return 0;
}else{//samplecounter>=32的情況
finishsampling = 1;
startsampling = 0;
return u32data;
}
}else{//←對應(yīng)這里的else
samplecounter = 0;
u32data = 0;
return 0;
}
}
計算上升沿的函數(shù)
//通過邏輯運算統(tǒng)計上升沿數(shù)量
unsigned char recounter(unsigned long A){//A會在keyhandler調(diào)用中被賦值為sampledata
unsigned char count = 0;
unsigned long mask;//掩碼
//左移一位,然后按位取反,mask中1的次數(shù)就是0→1上升的次數(shù)
//按下按鍵開始掃描,最高位一定是0,左移舍棄無影響
mask = ~A & (A<< 1);
while(mask){//當(dāng)mask = 0時,循環(huán)結(jié)束
count += mask & 0X01;//取最低位,與count相加
mask >>= 1;//右移一位,拋棄最低位,最高位補0
}
return count;
}
然后在定時器中斷里調(diào)用按鍵處理函數(shù),進而調(diào)用這兩個函數(shù)
void KEY_HANDLER(void){
unsigned char re = recounter(sampledata());//調(diào)用采樣函數(shù),為re賦值
----------------------------------------------------------------------
我并沒有做好這個功能,嘗試幾次就放棄了,但是這個采樣函數(shù)和代碼應(yīng)該是沒什么問題,這個方案比狀態(tài)機方案原理清晰不少,不過RAM占用和CPU時間都更高,大家圖一樂吧,如果閑的沒事干的話可以試著補全
作者:
joyb
時間:
2025-7-4 14:48
有創(chuàng)意,支持
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1