- 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就行
- 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的输出或者禁止做出改变。