1.判断长按短按
u8 Mode_state_flag = 0;
u32 buttonPressTime = 0;
u8 longPressflag = 0;
u8 shortPressflag = 0;
// 普通认证 执行此处函数
void T_Key0_Func(void)
{
if (TKey_Signal.oneBit.b0 == 1)
{
buttonPressTime++;
}
if ((TKey_Signal.oneBit.b0 == 1) && (Pre_TKey_Release.oneBit.b0 == 1)) // 按下执行
{
Pre_TKey_Release.oneBit.b0 = 0; // 为0时代表按键被按下,为1时代表按键松开
F_User_Tkey0 = 1;
FTP0IE = 1;
FTP0EN = 1;
FGIE = 1;
}
else if (TKey_Signal.oneBit.b0 == 0) // 松开执行
{
Pre_TKey_Release.oneBit.b0 = 1; // 无手指 执行
if (F_User_Tkey0 == 1) // 松键执行-在这里
{
F_User_Tkey0 = 0;
if (buttonPressTime <= 1000) //短按切換、
{
PB ^= 0B00010000;
}
else //長按
{
PB ^= 0B00001000; //PB3
}
FTP0IE = 0;
buttonPressTime = 0;
#if (IS_SLEEP_MODE == 1)
F_User_Sleep = ~F_User_Sleep; // 测试使用,用户需要注释,自行根据程序给出该标志位
#endif
}
}
}
現在的思路是建立一个变量,在按键按下时会进行累加,然后在按键松开的时候对这个变量的值进行判断。就可以判断。但是现在发现短按时灯会短暂熄灭又亮起。测试发现该问题偶发性。
猜测1:硬件消抖问题
猜测2:时间应该再弄长一点
解决:在GPIO初始化中将PB设置为0x00000000就行
2.给系统增加按键功能,并且独立开长按和短按
case 0:
PB = 0B01001000; // 翻转 PB6 的输出电平
Mode_state_flag = 1;
break;
case 1:
PB = 0B00001100; // 翻转 PB6 的输出电平
Mode_state_flag = 2;
break;
case 2:
PB = 0B00001000; // 翻转 PB6 的输出电平
Mode_state_flag = 3;
break;
case 3:
PB = 0B01000100; // 翻转 PB6 的输出电平
Mode_state_flag = 0;
break;
}
问题1:现在希望通过switch case这个语句来进行对按键状态的变换,但是发现在点按按键时由PB2输出PWM1控制的LED灯的现象为立马达到最亮,然后继续点按按键无任何反应。
因为灯的亮度有变化,所以代表程序的控制是起作用的。亮度一下子达到最高,代表着此时PB2的引脚输出的为低电平。但是在控制高电平时灯并没有熄灭,亮度也没发生变化。改了下初始化变化为无反应。
猜测1:是不是这个口作为PWM的输出口,导致无法通过这种方式控制。注释掉定时器的初始化函数问题解决,所以考虑,问题出在pwm的初始化内。
在按键扫描函数中
增加引脚重复初始化的话按键可以响应,但是led灯的亮度每次都是最高
问题2:现在已经可以实现基本的颜色切换了,但是解决了可以切换的问题后,在长按后的颜色并未保留下来。
猜测2:应该在定时器内作区分,或者说在按键扫描函数内重新对PWM的输出或者禁止做出改变。