按鍵局部程序分析
u8 KEY_Scan(u8 mode) { static u8 key_up=1;//按鍵按松開標志 if(mode)key_up=1; //支持連按 if(key_up&&(KEY0==0||KEY1==0||WK_UP==1)) { delay_ms(10);//去抖動 key_up=0; if(KEY0==0)return KEY0_PRES; else if(KEY1==0)return KEY1_PRES; else if(WK_UP==1)return WKUP_PRES; } else if(KEY0==1&&KEY1==1&&WK_UP==0)key_up=1; return 0;// 無按鍵按下 }
當 mode 為 0 的時候,
KEY_Scan 函數將不支持連續按,掃描某個按鍵,該按鍵按下之后必須要松開,才能第二次觸發,否則不會再響應這個按鍵,這樣的好處就是可以防止按一次多次觸發,而壞處就是在需要長按的時候就不合適了。
當 mode 為 1 的時候,
KEY_Scan 函數將支持連續按,如果某個按鍵一直按下,則會一直返回這個按鍵的鍵值,這樣可以方便的實現長按檢測。
t=KEY_Scan(0); //得到鍵值 switch(t) { case KEY0_PRES: LED0=!LED0; break; case KEY1_PRES: LED1=!LED1; break; case WKUP_PRES: LED0=!LED0; LED1=!LED1; break; default: delay_ms(10); }
第一個程序的return值回傳到switch的case。
void KEY_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOC,ENABLE);//使能 PORTA,PORTC 時鍾 GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable, ENABLE); //關閉 jtag,使能 SWD,可以用 SWD 模式調試 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_15;//PA15 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; //設置成上拉輸入 GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化 GPIOA15 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;//PC5 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; //設置成上拉輸入 GPIO_Init(GPIOC, &GPIO_InitStructure);//初始化 GPIOC5 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;//PA0 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; //PA0 設置成輸入,默認下拉 GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化 GPIOA.0 }