按键程序理解

 按键局部程序分析

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
}

这调用了:GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable, ENABLE);这个函数,用于禁止 JTAG,开启 SWD,因为 PA15 占用了 JTAG 的一个 IO,所以要禁止 JTAG,从而让 PA15 用作普通 IO输入。

原文地址:https://www.cnblogs.com/action0/p/12739649.html