在TWS类型耳机UI调试中偶尔会遇到需求是要求左右耳同时多击或者长按实现特定功能的,本文章给出解决类似需求的一种方法。
在int app_earphone_key_event_handler(struct sys_event *event)这个函数里面,主要存放按键的消息事件,按键消息会通过按键(触摸)驱动传到static int event_handler(struct application *app, struct sys_event *event)系统事件处理这里,按键具体的键值(单击、多击、长按)以及具体的按键通道等会通过结构体传入到函数中。
通过这个变量,可以判断在对耳情况下按键消息是由本地或者tws触发的
这样就可以通过这个变量去判断按键具体是由本地产生还是TWS产生,来实现对耳同时按下
具体demo如下
static u8 forom_tws_flag = 0; //tws
static u8 forom_local_flag = 0; //local
u16 tws_key_clear_timer = 0; //清除本地&tws变量定时器
void same_tws_key_flag_clear()
{
sys_timeout_del(tws_key_clear_timer);
tws_key_clear_timer = 0;
forom_tws_flag = 0;
forom_local_flag = 0;
}
static void same_tws_key_event_deal(u32 event)
{
if (!get_tws_phone_connect_state()) {
if (event == KEY_EVENT_FROM_TWS) {
forom_tws_flag = 1;
} else {
forom_local_flag = 1;
}
r_printf("forom_tws_flag %d forom_local_flag %d \n");
if (forom_tws_flag && forom_local_flag) {
printf("tws same key OK \n");
//code:这里存放需要tws按键同时按下的代码
}
if (!tws_key_clear_timer) {
//延时多久清除(多少时间内同时按下有效)
tws_key_clear_timer = sys_timeout_add(NULL,same_tws_key_flag_clear,2000);
}
}
}