国产精品久久久久影院,成人午夜福利视频,国产精品久久久久高潮,国产精品 欧美 亚洲 制服,国产精品白浆无码流出

【GD32H757Z海棠派開發(fā)板使用手冊】第二講 GPIO-按鍵查詢檢測實驗

發(fā)布者:Blissful5最新更新時間:2024-12-04 來源: elecfans關鍵字:GPIO 手機看文章 掃描二維碼
隨時隨地手機看文章

2.1實驗內(nèi)容

通過本實驗主要學習以下內(nèi)容:

  • GPIO輸入功能原理;

  • 按鍵查詢輸入檢測原理;

2.2實驗原理

2.2.1GPIO輸入功能原理

GD32H7XX系列MCU GPIO輸入配置結構如下圖所示,輸入可配置上下拉電阻,通過施密特觸發(fā)器后可通過備用功能輸入或者通過輸入狀態(tài)寄存器進行讀取。

wKgZomYfNiGAWO16AAFIwFAfv7E864.png

輸入狀態(tài)寄存器為GPIOx_ISTAT,其狀態(tài)位定義如下圖所示,每個控制位對應相應引腳的輸入電平狀態(tài)。

wKgaomYfNjWAeZzOAAM-GYnYKgU218.png

GPIO引腳輸入電平判斷閾值如下圖所示,當輸入電平小于0.3VDD時,可被內(nèi)部有效識別為低電平;當輸入電平大于0.7VDD時,可被內(nèi)部有效識別為高電平

wKgaomYfNkmAR5zkAAC5lJ1E1yQ855.png

2.3硬件設計

GD32H7海棠派派開發(fā)板具有兩個按鍵,對應電路圖如下圖所示,其中,喚醒按鍵未按下時為低電平,按下后喚醒按鍵為高電平;用戶按鍵未按下時為高電平,按下后用戶按鍵為低電平,通過讀取按鍵對應GPIO引腳的電平狀態(tài)可檢測對應按鍵是否被按下。

wKgaomYfNluAM-ZFAAEjZDLe6AQ096.png

注意:機械按鍵在按下或者松開時具有抖動,建議可增加硬件消抖或者軟件消抖,以避免按鍵檢測被多次觸發(fā)。

2.4代碼解析

本例程實現(xiàn)通過查詢的方式可查詢按鍵按下的時間,進而可實現(xiàn)短時間按下和長時間按下的檢測。

主函數(shù)代碼如下,首先進行驅(qū)動初始化/按鍵初始化/LED初始化/串口初始化,并打印Example of key scan detection.之后進入主循環(huán),通過key_scan函數(shù)實現(xiàn)對按鍵的掃描并檢測按鍵按下時間。

C
int main(void)
{
/* 系統(tǒng)延時初始化 */
driver_init();

//注冊按鍵掃描
driver_tick_handle[0].tick_value=10;
driver_tick_handle[0].tick_task_callback=key_scan_10ms_callhandle;


/* 按鍵組初始化 */
bsp_key_group_init();

/* LED組初始化 */
bsp_led_group_init();

/* 板載UART初始化 */
bsp_uart_init(&BOARD_UART);

delay_ms(1000);

printf_log('Example of key scan detection.rn');


while (1)
{
delay_ms(1);

/* 按鍵掃描結果檢查:檢測任意按鍵和多按鍵組合按下時間,所有按鍵彈起后有效 */
if(SET==all_key_up)
{
/* 檢測按鍵組合按下時長 */
if(USER_KEY.press_timerms >= PRESS_3000MS && WKUP_KEY.press_timerms >= PRESS_3000MS)
{
printf_log('USER_KEY/KEY2/WKUP_KEY pressed together for more than 3000ms.rn');
USER_KEY.press_timerms=PRESS_NONE;
WKUP_KEY.press_timerms=PRESS_NONE;
}
else if(USER_KEY.press_timerms >= PRESS_50MS && WKUP_KEY.press_timerms >= PRESS_50MS)
{
printf_log('USER_KEY/KEY2/WKUP_KEY pressed together for more than 50ms.rn');
USER_KEY.press_timerms=PRESS_NONE;
WKUP_KEY.press_timerms=PRESS_NONE;
}

if(USER_KEY.press_timerms >= PRESS_200MS && USER_KEY.press_timerms < PRESS_5000MS)
{
USER_KEY.press_timerms=PRESS_NONE;
printf_log('USER_KEY press more than 200ms, less than 5000ms .rn');
}
else if(USER_KEY.press_timerms >= PRESS_5000MS)
{
USER_KEY.press_timerms=PRESS_NONE;
printf_log('USER_KEY press more than 5000ms.rn');
}
else if(USER_KEY.press_timerms >= PRESS_DOWN)
{
USER_KEY.press_timerms=PRESS_NONE;
printf_log('USER_KEY press briefly.rn');
}


if(WKUP_KEY.press_timerms >= PRESS_200MS && WKUP_KEY.press_timerms < PRESS_5000MS)
{
WKUP_KEY.press_timerms=PRESS_NONE;
printf_log('WKUP_KEY press more than 200ms, less than 5000ms .rn');
}
else if(WKUP_KEY.press_timerms >= PRESS_5000MS)
{
WKUP_KEY.press_timerms=PRESS_NONE;
printf_log('WKUP_KEY press more than 5000ms.rn');
}
else if(WKUP_KEY.press_timerms >= PRESS_DOWN)
{
WKUP_KEY.press_timerms=PRESS_NONE;
printf_log('WKUP_KEY press briefly.rn');
}

all_key_up=RESET;
}

//非彈起檢查
if(USER_KEY.press_cycle_count >= PRESS_50MS)
{
bsp_led_toggle(&LED2);
}
else if(WKUP_KEY.press_cycle_count >= PRESS_50MS)
{
bsp_led_toggle(&LED2);
}
else
{
bsp_led_off(&LED2);
}


//直接讀取
if(bsp_key_state_get(&USER_KEY)==SET)
{
bsp_led_toggle(&LED1);
}
else if(bsp_key_state_get(&WKUP_KEY)==SET)
{
bsp_led_toggle(&LED1);
}
else
{
bsp_led_off(&LED1);
}
}
}

按鍵初始化函數(shù)如下,通過KEY_DEF定義相關按鍵參數(shù),之后調(diào)用bsp_key_init對按鍵進行分別初始化。

C
void bsp_key_group_init(void)
{
uint8_t i;
for(i=0;i{
bsp_key_init(((typdef_bsp_key *)KEY_INIT_GROUP[i]));
}
}
KEY_DEF(USER_KEY,A,1,IN_PU,SET,NULL); // PA1定義為USER_KEY非中斷模式,默認狀態(tài)高
KEY_DEF(WKUP_KEY,A,0,IN_PD,RESET,NULL); // PA0定義為KEY2非中斷模式,默認狀態(tài)高

通過key_scan進行按鍵掃描,實現(xiàn)對按鍵按下時間長度范圍的檢測。

C
bit_status key_scan(uint16_t scan_ms_cycle)
{
uint8_t i;
bit_status press_flag=RESET;
for(i=0;i{
// ((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=press_none;
if(bsp_key_state_get((typdef_bsp_key *)KEY_INIT_GROUP[i])==SET && ((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count<0xffff){

((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms =PRESS_DOWN;
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count+=scan_ms_cycle;
}
}

for(i=0;i{

if(bsp_key_state_get((typdef_bsp_key *)KEY_INIT_GROUP[i])==SET && ((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count < 15000) //持續(xù)15s被按下標記為按鍵可能損壞        
{
return press_flag;
}
}

for(i=0;i{
if( (((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count > PRESS_50MS) && (((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count < 15000) )
{
press_flag=SET;
all_key_up=SET;
if(((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count > PRESS_5000MS){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_5000MS;
}
else if(((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count>PRESS_4000MS){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_4000MS;
}
else if(((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count>PRESS_3000MS){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_3000MS;
}
else if(((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count>PRESS_2000MS){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_2000MS;
}
else if(((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count>PRESS_1000MS){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_1000MS;
}
else if(((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count>PRESS_500MS){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_500MS;
}
else if(((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count>PRESS_200MS){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_200MS;
}
else{
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_timerms=PRESS_50MS;
}
}
if(bsp_key_state_get((typdef_bsp_key *)KEY_INIT_GROUP[i])==RESET){
((typdef_bsp_key *)KEY_INIT_GROUP[i])->press_cycle_count=0;
}
}
return press_flag;
}

key_scan通過10ms掃描中斷回調(diào)函數(shù)進行調(diào)用。

C
void key_scan_10ms_callhandle(void)
{
key_scan(10);
}

2.5實驗結果

將本例程燒錄到開發(fā)板中,在液晶屏上首先打印Example of key scan detection.

之后短按或者長按WKUP或USER按鍵,將在液晶上顯示按下的狀態(tài)。


關鍵字:GPIO 引用地址:【GD32H757Z海棠派開發(fā)板使用手冊】第二講 GPIO-按鍵查詢檢測實驗

上一篇:【GD32H757Z海棠派開發(fā)板使用手冊】第十二講 SDIO-SD卡讀寫實驗
下一篇:【GD32F303紅楓派開發(fā)板使用手冊】第六講 PMU-低功耗實驗講

推薦閱讀最新更新時間:2025-07-02 07:14

使用pinctrl和gpio子系統(tǒng)實現(xiàn)LED燈驅(qū)動
前邊已經(jīng)學了兩種點燈,本質(zhì)依然還是通過配置寄存器;在學習STM32的時候除了學習配置一下寄存器,基本都是使用庫來開發(fā),那么在i.MX6ULL還使用寄存器開發(fā)明顯是不太適合,那么i.MX6ULL有更方便的開發(fā)呢,這篇就來學習一下使用 pinctrl 和 gpio 子系統(tǒng)來完成 LED 燈驅(qū)動。 |修改設備樹文件 添加 pinctrl 節(jié)點 開發(fā)板上的 LED 燈使用了 GPIO1_IO04這個 PIN,打開 imx6ull-14x14-evk.dts,在 iomuxc 節(jié)點的 imx6ul-evk 子節(jié)點下創(chuàng)建一個名為“pinctrl_led”的子節(jié)點,節(jié)點內(nèi)容如下所示: /* 添加的 */ pinctrl_led
[單片機]
使用pinctrl和<font color='red'>gpio</font>子系統(tǒng)實現(xiàn)LED燈驅(qū)動
STM32單片機GPIO口的學習
  GPIO:   STM32的(64引腳的)IO口一共有3個,分別是PA、PB、PC.   STM32的IO端口可以由軟件配置成8種模式:   1,輸入浮空   2,輸入上拉   3,輸入下拉   4,模擬輸入   5,開漏輸出   6,推挽輸出   7,推挽復用功能   8,開漏復用功能   STM32的每個IO端口都有7個寄存器來控制。他們分別是:配置模式的2個32位的端口配置寄存器CRL和CRH;2個32位的數(shù)據(jù)寄存器IDR和ODR;1個32位的置位/復位寄存器BSRR;一個16位的復位寄存器BRR;1個32位的鎖存寄存器LCKR;我們常用的IO端口寄存器只有4個:CRL、CRH、IDR、ODR。   注意(在配置ST
[單片機]
【AVR ASF4庫函數(shù)學習筆記】二、GPIO
平臺:Microchip Studio (原Atmel Studio 7) 欣世紀 DMAVR-L Atmega 128A - AU 頭文件為port.h 枚舉類型 enum port_pull_mode { PORT_PULL_OFF, PORT_PULL_UP, }; enum port_dir { PORT_DIR_IN, PORT_DIR_OUT, PORT_DIR_OFF, }; 函數(shù) X = ABCDEFG static inline bool PORTX_get_pin_level(const uint8_t pin) 讀取連接到端口的引腳上的電平 stat
[單片機]
STM32:stm32f10x_gpio.c中GPIO_Init的分析說明
1 /** 2 *函數(shù)功能:初始化引腳模式 3 *參數(shù)說明:GPIOx,該參數(shù)為GPIO_TypeDef 類型的指針,指向GPIO 端口的地址 4 * GPIO_InitTypeDef:GPIO_InitTypeDef 結構體指針,指向初始化變量 5 */ 6 void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct) 7 { 8 uint32_t currentmode =0x00,currentpin = 0x00,pinpos = 0x00,pos = 0x00; 9 uint32_t tmpreg = 0x00, pinmas
[單片機]
stm32 gpio 工作方式及 mos管的認識
GPIO 寄存器的配置 模式一 開漏輸出 CPU 寫寄存器來 輸出1通過輸出控制電路 N-MOS管處于關閉狀態(tài),輸出電平不受MOS管影響,而受上下拉電阻的影響,所以IO口輸出不一定為1; 輸出為0,N-MOS管開啟,把輸出端電平拉低,所以輸出為0;CPU讀出來的就是0. 模式二-------開漏復用輸出 復用是通過 外設 來控制輸入輸出 其他與開漏輸出一樣 模式三----------推挽輸出 推挽輸出:輸入1時,上方的 P-MOS 導通,下方的 N-MOS關閉,對外輸出高電平; 輸入0時,下方的 N-MOS 導通,上方的 P-MOS關閉,對外輸出低電平。 模式四------推挽復用輸出 復用是通過 外
[單片機]
stm32 <font color='red'>gpio</font> 工作方式及 mos管的認識
stm32之GPIO寄存器學習
GPIO即通用輸入/輸出 (General Purpose Input Output) 包括: 兩個32位的配置寄存器 GPIOx- CRL,GPIOx- CRH 兩個32位的數(shù)據(jù)寄存器 GPIOx- IDR,GPIOx- ODR 一個32位的 set/reset 寄存器 GPIOx- BSRR 一位16位的 reset 寄存器 GPIOx- BRR 一位32位的鎖定寄存器 GPIOx- LCKR 端口的模式包括: 浮空輸入(Input floating)—— 即沒有上拉電阻和下拉電阻,電壓呈不確定性,一般用來做ADC輸入用,這樣可以減少上下拉電阻對結果的影響 上拉輸入(Input pull-up)
[單片機]
stm32之<font color='red'>GPIO</font>寄存器學習
STM32進入睡眠模式下的GPIO配置參考
1. GPIO內(nèi)部電路圖 1.根據(jù)設備原理圖查看IO外部引腳連接電路,閑置狀態(tài)為低電平時,設置為下拉輸入;閑置狀態(tài)為高電平時,設置為上拉輸入;閑置狀態(tài)為懸空時設置為模擬輸入;輸出引腳根據(jù)功能需要設置就行 原因:當IO通過外圍電路電阻接地被拉低時,如果設置為上拉輸入,則在芯片內(nèi)部的上拉電阻和外圍的下拉電阻構成回路,電流損耗取決于這兩個電阻;當IO通過外圍電路電阻接電源被拉高時,則在芯片內(nèi)部的下拉電阻和外圍的上拉電阻構成回路,電流損耗也取決于這兩個電阻;當懸空時,斯密特觸發(fā)器是打開的,要判斷輸入的是高電平還是低電平,需要一點電流損耗,但是設備模擬輸入,這個觸發(fā)器是關閉的 --------------------- 假設你的這個GP
[單片機]
STM32進入睡眠模式下的<font color='red'>GPIO</font>配置參考
STM32F4CubeMX學習筆記之GPIO_LED
開發(fā)板:普中PZ6808L-F4 開發(fā)環(huán)境:keil5+CnbeMx 兩個LED配置為推挽輸出
[單片機]
STM32F4CubeMX學習筆記之<font color='red'>GPIO</font>_LED
小廣播
設計資源 培訓 開發(fā)板 精華推薦

最新單片機文章

 
EEWorld訂閱號

 
EEWorld服務號

 
汽車開發(fā)圈

 
機器人開發(fā)圈

電子工程世界版權所有 京ICP證060456號 京ICP備10001474號-1 電信業(yè)務審批[2006]字第258號函 京公網(wǎng)安備 11010802033920號 Copyright ? 2005-2025 EEWORLD.com.cn, Inc. All rights reserved