基于stm32的獨(dú)立按鍵掃描方式
//*
// Function: 掃描按鍵
// Returns: u8 :按鍵id值
//*
u8 KeyScan()
{
static u8 keyUp=1;//按鍵按松開標(biāo)志
u8 i,count,upCount=0;
count=sizeof(buttons)/sizeof(Button);
for (i=0;i
if (keyUp && (GPIO_ReadInputDataBit(buttons[i].ButtonPort,buttons[i].ButtonPin)==0))
{
keyUp = 0;
delay_ms(10);
if (GPIO_ReadInputDataBit(buttons[i].ButtonPort,buttons[i].ButtonPin)==0)
{
return buttons[i].ButtonId;
}
}
else if ((GPIO_ReadInputDataBit(buttons[i].ButtonPort,buttons[i].ButtonPin)==1))
{
upCount++; //記錄有多少個按鍵松開了
}
}
if (upCount == count)//按鍵松開數(shù)等于總按鍵數(shù)
{
keyUp = 1;
}
return ButtonNone;// 無按鍵按下
}
通俗易懂吧。接下來看結(jié)構(gòu)體原型
typedef struct
{
GPIO_TypeDef* ButtonPort;//按鍵端口
uint16_t ButtonPin;//按鍵引腳
u8ButtonId;//按鍵ID
}Button;
使用方法
Button buttons[]={{GPIOB,GPIO_Pin_5,ButtonFunction},
{GPIOB,GPIO_Pin_6,ButtonUp},
{GPIOB,GPIO_Pin_1,ButtonDown},
{GPIOB,GPIO_Pin_0,4}};
一般的結(jié)構(gòu)體初始化方法,前兩個參數(shù)大家都懂,最后一個可以定義一個枚舉,當(dāng)然也可以自己賦值,注意別重復(fù)和定義為0了,因?yàn)?一般用來當(dāng)作沒有按鍵的返回值。如今要加減按鍵就只需在上面的數(shù)組中處理。當(dāng)然別忘了端口的初始化,這個就不說了。
分析一下優(yōu)缺點(diǎn),
優(yōu)點(diǎn):便于擴(kuò)展,每加減一個按鍵都不用修改主要的按鍵掃描函數(shù),如果端口初始化函數(shù)寫得好的話連端口初始化函數(shù)都可以不用管。
缺點(diǎn):如果按鍵過多,會損失不少時(shí)間,主要原因是循環(huán)結(jié)構(gòu)
評論