428 lines
11 KiB
C
428 lines
11 KiB
C
|
||
/*************************************************************
|
||
此文件函数主要是linein模式按键处理和事件处理
|
||
|
||
void app_linein_task()
|
||
linein模式主函数
|
||
|
||
static int linein_sys_event_handler(struct sys_event *event)
|
||
linein模式系统事件所有处理入口
|
||
|
||
static void linein_task_close(void)
|
||
linein模式退出
|
||
|
||
**************************************************************/
|
||
|
||
|
||
#include "system/app_core.h"
|
||
#include "system/includes.h"
|
||
#include "server/server_core.h"
|
||
|
||
#include "app_config.h"
|
||
#include "app_task.h"
|
||
|
||
#include "media/includes.h"
|
||
#include "tone_player.h"
|
||
#include "audio_dec_linein.h"
|
||
|
||
#include "asm/audio_linein.h"
|
||
#include "asm/pwm_led.h"
|
||
#include "asm/charge.h"
|
||
|
||
#include "app_charge.h"
|
||
#include "app_main.h"
|
||
#include "app_online_cfg.h"
|
||
#include "app_power_manage.h"
|
||
|
||
#include "app_chargestore.h"
|
||
#include "gSensor/gSensor_manage.h"
|
||
#include "ui_manage.h"
|
||
#include "vm.h"
|
||
|
||
#include "linein/linein_dev.h"
|
||
#include "linein/linein.h"
|
||
|
||
#include "key_event_deal.h"
|
||
#include "user_cfg.h"
|
||
#include "ui/ui_api.h"
|
||
#include "fm_emitter/fm_emitter_manage.h"
|
||
#include "clock_cfg.h"
|
||
|
||
#include "bt.h"
|
||
#include "bt_tws.h"
|
||
|
||
|
||
#if TCFG_APP_LINEIN_EN
|
||
|
||
#define LOG_TAG_CONST APP_LINEIN
|
||
#define LOG_TAG "[APP_LINEIN]"
|
||
#define LOG_ERROR_ENABLE
|
||
#define LOG_DEBUG_ENABLE
|
||
#define LOG_INFO_ENABLE
|
||
/* #define LOG_DUMP_ENABLE */
|
||
#define LOG_CLI_ENABLE
|
||
#include "debug.h"
|
||
|
||
|
||
static u8 linein_last_onoff = (u8) - 1;
|
||
static u8 linein_bt_back_flag = 0;
|
||
static u8 linein_idle_flag = 1;
|
||
//-----------------------------------------------------------------------------
|
||
static u16 tm_led;
|
||
static int t_cnt;
|
||
static u8 led_flag;
|
||
|
||
|
||
static void led_cb(void *priv)
|
||
{
|
||
|
||
if (linein_get_status() == 1)
|
||
{
|
||
t_cnt++;
|
||
if (t_cnt > 1)
|
||
{
|
||
t_cnt = 0;
|
||
if (led_flag == 1)
|
||
{
|
||
led_flag = 0;
|
||
gpio_set_output_value(IO_PORTB_05, led_flag);
|
||
}
|
||
else
|
||
{
|
||
led_flag = 1;
|
||
gpio_set_output_value(IO_PORTB_05, led_flag);
|
||
}
|
||
}
|
||
}
|
||
else
|
||
{
|
||
led_flag = 1;
|
||
gpio_set_output_value(IO_PORTB_05, led_flag);
|
||
}
|
||
}
|
||
|
||
static void start_led(void)
|
||
{
|
||
if (tm_led)
|
||
{
|
||
sys_timer_del(tm_led);
|
||
}
|
||
|
||
t_cnt = 0;
|
||
led_flag = 1;
|
||
tm_led = sys_timer_add(NULL, led_cb, 250);
|
||
}
|
||
|
||
//--------------------------------------------------------------------------------
|
||
///*----------------------------------------------------------------------------*/
|
||
/**@brief 当前出于非linein 模式时候linein的在common消息处理
|
||
@param 无
|
||
@return 1:需要切换回linein 模式 0:无
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
int linein_device_event_handler(struct sys_event *event)
|
||
{
|
||
if ((u32)event->arg == DEVICE_EVENT_FROM_LINEIN) {
|
||
if (event->u.dev.event == DEVICE_EVENT_IN) {
|
||
log_info("linein online \n");
|
||
return true;
|
||
} else if (event->u.dev.event == DEVICE_EVENT_OUT) {
|
||
log_info("linein offline \n");
|
||
}
|
||
}
|
||
return false;
|
||
}
|
||
|
||
|
||
static int linein_key_event_filter_before()
|
||
{
|
||
#if TCFG_UI_ENABLE
|
||
#if (TCFG_APP_FM_EMITTER_EN == ENABLE_THIS_MOUDLE)
|
||
if (ui_get_app_menu(GRT_CUR_MENU) == MENU_FM_SET_FRE) {
|
||
return false;
|
||
}
|
||
#endif
|
||
#endif
|
||
return TRUE;
|
||
}
|
||
|
||
|
||
//*----------------------------------------------------------------------------*/
|
||
/**@brief linein 按键消息入口
|
||
@param 无
|
||
@return 1、消息已经处理,不需要发送到common 0、消息发送到common处理
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
static int linein_key_msg_deal(struct sys_event *event)
|
||
{
|
||
int ret = true;
|
||
int err = 0;
|
||
u8 vol;
|
||
int key_event = event->u.key.event;
|
||
int key_value = event->u.key.value;//
|
||
|
||
if (linein_key_event_filter_before() == false) {
|
||
return false;
|
||
}
|
||
|
||
log_info("key_event:%d \n", key_event);
|
||
#if (SMART_BOX_EN)
|
||
extern bool smartbox_key_event_filter_before(int key_event);
|
||
if (smartbox_key_event_filter_before(key_event)) {
|
||
return true;
|
||
}
|
||
#endif
|
||
|
||
switch (key_event) {
|
||
case KEY_LINEIN_START:
|
||
linein_start();
|
||
linein_last_onoff = 1;
|
||
UI_REFLASH_WINDOW(true);//刷新主页并且支持打断显示
|
||
break;
|
||
case KEY_TEST_DEMO_0:
|
||
log_info("KEY_TEST_DEMO_0 = %d \n", key_value);
|
||
app_task_put_key_msg(KEY_TEST_DEMO_1, 5678); //test demo
|
||
break;
|
||
case KEY_TEST_DEMO_1:
|
||
log_info("KEY_TEST_DEMO_1 = %d \n", key_value); //test demo
|
||
break;
|
||
|
||
case KEY_MUSIC_PP:
|
||
log_info("KEY_MUSIC_PP\n");
|
||
/* app_task_put_key_msg(KEY_TEST_DEMO_0,1234); //test demo// */
|
||
linein_last_onoff = linein_volume_pp();
|
||
linein_last_onoff ? ui_update_status(STATUS_LINEIN_PLAY)\
|
||
: ui_update_status(STATUS_LINEIN_PAUSE);
|
||
break;
|
||
case KEY_VOL_UP:
|
||
log_info(" KEY_VOL_UP\n");
|
||
linein_key_vol_up();
|
||
break;
|
||
|
||
case KEY_VOL_DOWN:
|
||
log_info(" KEY_VOL_DOWN\n");
|
||
linein_key_vol_down();
|
||
break;
|
||
|
||
default:
|
||
ret = false;
|
||
break;
|
||
}
|
||
#if (SMART_BOX_EN)
|
||
extern void smartbox_linein_msg_deal(int msg, u8 ret);
|
||
smartbox_linein_msg_deal(key_event, ret);
|
||
#endif
|
||
|
||
return ret;
|
||
}
|
||
|
||
//*----------------------------------------------------------------------------*/
|
||
/**@brief 音乐播放结束回调函数
|
||
@param 无
|
||
@return
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
static void line_tone_play_end_callback(void *priv, int flag)
|
||
{
|
||
u32 index = (u32)priv;
|
||
|
||
if (APP_LINEIN_TASK != app_get_curr_task()) {
|
||
log_error("tone callback task out \n");
|
||
return;
|
||
}
|
||
|
||
switch (index) {
|
||
case IDEX_TONE_LINEIN:
|
||
///提示音播放结束, 启动播放器播放
|
||
app_task_put_key_msg(KEY_LINEIN_START, 0);
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
}
|
||
|
||
|
||
//*----------------------------------------------------------------------------*/
|
||
/**@brief linein 入口
|
||
@param 无
|
||
@return
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
static void linein_app_init(void)
|
||
{
|
||
linein_idle_flag = 0;
|
||
UI_SHOW_WINDOW(ID_WINDOW_LINEIN);//打开ui主页
|
||
UI_SHOW_MENU(MENU_AUX, 0, 0, NULL);
|
||
sys_key_event_enable();//开启按键
|
||
ui_update_status(STATUS_LINEIN_MODE);
|
||
clock_idle(LINEIN_IDLE_CLOCK);
|
||
|
||
}
|
||
|
||
//*----------------------------------------------------------------------------*/
|
||
/**@brief linein 退出
|
||
@param 无
|
||
@return
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
|
||
static void linein_task_close(void)
|
||
{
|
||
UI_HIDE_CURR_WINDOW();
|
||
linein_stop();
|
||
/* tone_play_stop(); */
|
||
tone_play_stop_by_path(tone_table[IDEX_TONE_LINEIN]);
|
||
linein_idle_flag = 1;
|
||
}
|
||
|
||
|
||
//*----------------------------------------------------------------------------*/
|
||
/**@brief linein 模式活跃状态 所有消息入口
|
||
@param 无
|
||
@return 1、当前消息已经处理,不需要发送comomon 0、当前消息不是linein处理的,发送到common统一处理
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
static int linein_sys_event_handler(struct sys_event *event)
|
||
{
|
||
int ret = TRUE;
|
||
switch (event->type) {
|
||
case SYS_KEY_EVENT:
|
||
return linein_key_msg_deal(event);
|
||
break;
|
||
case SYS_DEVICE_EVENT:
|
||
if ((u32)event->arg == DEVICE_EVENT_FROM_LINEIN) {
|
||
if (event->u.dev.event == DEVICE_EVENT_IN) {
|
||
log_info("linein online \n");
|
||
} else if (event->u.dev.event == DEVICE_EVENT_OUT) {
|
||
log_info("linein offline \n");
|
||
app_task_switch_next();
|
||
}
|
||
return true;
|
||
}
|
||
return false;
|
||
break;
|
||
default:
|
||
return false;
|
||
}
|
||
return false;
|
||
}
|
||
|
||
|
||
//*----------------------------------------------------------------------------*/
|
||
/**@brief linein 在线检测 切换模式判断使用
|
||
@param 无
|
||
@return 1 linein设备在线 0 设备不在线
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
int linein_app_check(void)
|
||
{
|
||
if (linein_is_online()) {
|
||
return true;
|
||
}
|
||
return false;
|
||
}
|
||
|
||
//*----------------------------------------------------------------------------*/
|
||
/**@brief linein 主任务
|
||
@param 无
|
||
@return 无
|
||
@note
|
||
*/
|
||
/*----------------------------------------------------------------------------*/
|
||
void app_linein_task()
|
||
{
|
||
int res;
|
||
int err = 0;
|
||
int msg[32];
|
||
|
||
|
||
|
||
// PA mode set to class D
|
||
gpio_set_pull_down(IO_PORTA_02, 0);
|
||
gpio_set_pull_up(IO_PORTA_02, 0);
|
||
gpio_set_direction(IO_PORTA_02, 0);
|
||
gpio_set_output_value(IO_PORTA_02,0);
|
||
|
||
#if TCFG_APP_BT_EN
|
||
linein_bt_back_flag = get_bt_back_flag();//从蓝牙后台返回标志
|
||
set_bt_back_flag(0);
|
||
#else
|
||
linein_bt_back_flag = 0;
|
||
#endif
|
||
log_info("linein_bt_back_flag == %d linein_last_onoff = %d\n", \
|
||
linein_bt_back_flag, linein_last_onoff);
|
||
|
||
linein_app_init();//初始化时钟和开启ui
|
||
|
||
#if TCFG_DEC2TWS_ENABLE
|
||
extern void set_tws_background_connected_flag(u8 flag);
|
||
extern u8 get_tws_background_connected_flag();
|
||
if (get_tws_background_connected_flag()) { //不播放提示音
|
||
app_task_put_key_msg(KEY_LINEIN_START, 0);
|
||
set_tws_background_connected_flag(0);
|
||
} else
|
||
#endif
|
||
{
|
||
err = tone_play_with_callback_by_name(tone_table[IDEX_TONE_LINEIN], 1,
|
||
line_tone_play_end_callback, (void *)IDEX_TONE_LINEIN);
|
||
}
|
||
// if (err) { //
|
||
// ///提示音播放失败,直接推送KEY_MUSIC_PLAYER_START启动播放
|
||
// app_task_put_key_msg(KEY_LINEIN_START, 0);
|
||
// }
|
||
start_led();
|
||
|
||
while (1) {
|
||
app_task_get_msg(msg, ARRAY_SIZE(msg), 1);
|
||
|
||
switch (msg[0]) {
|
||
case APP_MSG_SYS_EVENT:
|
||
if (linein_sys_event_handler((struct sys_event *)(&msg[1])) == false) {
|
||
app_default_event_deal((struct sys_event *)(&msg[1])); //由common统一处理
|
||
}
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
|
||
if (app_task_exitting()) {
|
||
sys_timer_del(tm_led);
|
||
gpio_set_output_value(IO_PORTB_05, 1);
|
||
linein_task_close();
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
|
||
static u8 linein_idle_query(void)
|
||
{
|
||
return linein_idle_flag;
|
||
}
|
||
REGISTER_LP_TARGET(linein_lp_target) = {
|
||
.name = "linein",
|
||
.is_idle = linein_idle_query,
|
||
};
|
||
|
||
#else
|
||
|
||
int linein_app_check(void)
|
||
{
|
||
return false;
|
||
}
|
||
|
||
void app_linein_task()
|
||
{
|
||
|
||
}
|
||
|
||
#endif
|
||
|
||
|