新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于stm32的獨(dú)立按鍵掃描方式

基于stm32的獨(dú)立按鍵掃描方式

作者: 時(shí)間:2016-11-19 來源:網(wǎng)絡(luò) 收藏
這兩天完成了一個(gè)stm32的工程,在解決按鍵時(shí)寫出了一個(gè)獨(dú)立按鍵的掃描函數(shù),應(yīng)該有前輩已經(jīng)出來了,的其實(shí)質(zhì)就是普通的掃描方式修改的,優(yōu)點(diǎn)是將按鍵相關(guān)參數(shù)封裝為一個(gè)結(jié)構(gòu)體,每加一個(gè)按鍵都不需要在函數(shù)中增加語句,廢話少說,先看掃描函數(shù)

本文引用地址:http://m.butianyuan.cn/article/201611/318319.htm

//*
// 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++; //記錄有多少個(gè)按鍵松開了
}
}
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)體初始化方法,前兩個(gè)參數(shù)大家都懂,最后一個(gè)可以定義一個(gè)枚舉,當(dāng)然也可以自己賦值,注意別重復(fù)和定義為0了,因?yàn)?一般用來當(dāng)作沒有按鍵的返回值。如今要加減按鍵就只需在上面的數(shù)組中處理。當(dāng)然別忘了端口的初始化,這個(gè)就不說了。

分析一下優(yōu)缺點(diǎn),

優(yōu)點(diǎn):便于擴(kuò)展,每加減一個(gè)按鍵都不用修改主要的按鍵掃描函數(shù),如果端口初始化函數(shù)寫得好的話連端口初始化函數(shù)都可以不用管。

缺點(diǎn):如果按鍵過多,會(huì)損失不少時(shí)間,主要原因是循環(huán)結(jié)構(gòu)



關(guān)鍵詞: stm32獨(dú)立按鍵掃描方

評論


技術(shù)專區(qū)

關(guān)閉