KT24-1110_65E-HA-651B/cpu/br25/audio_dec/audio_dec_tone.h
2024-11-10 18:44:17 +08:00

157 lines
6.1 KiB
C
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#ifndef _AUDIO_DEC_TONE_H_
#define _AUDIO_DEC_TONE_H_
#include "asm/includes.h"
#include "media/includes.h"
#include "media/file_decoder.h"
#include "system/includes.h"
#include "media/audio_decoder.h"
#include "application/audio_dec_app.h"
#include "tone_player.h"
// 提示音解码结束缘由
#define TONE_DEC_STOP_NOR 0 // 正常播放关闭
#define TONE_DEC_STOP_BY_OTHER_PLAY 1 // 被其他播放打断关闭
/*
* 用于保护file_list播放
* 原理是在当前播放结束后先启动一个空的解码占住res
* 避免播放file_list下一个时插入了其他解码
*/
#define TONE_DEC_PROTECT_LIST_PLAY 1
#define AUDUO_DEC_TONE_HIGH_BASS_ENABLE 0//提示音高低音处理0关闭 1使能
/*
* 提示音file_list解码结构体
* 依次播放"char **file_list"变量中定义的文件直到file_list[n]为NULL
* 如 file_list[0]=123.*; file_list[1]=456.*; file_list[2]=NULL;
* 支持文件名解码、正弦波数组参数解码需要实现get_sine()接口获取参数)
* 正弦波数组播放格式示例file_list[n]=DEFAULT_SINE_TONE(SINE_WTONE_NORAML);
* 支持循环播放,循环播放需要指定播放起始(参数是代表循环次数)和结束,
* 如file_list[n]=TONE_REPEAT_BEGIN(-1); file_list[n+1]=456.*; file_list[n+2]=TONE_REPEAT_END();
* 当需要使用外部自定义数据流时,可以通过实现*stream_handler接口来处理
*/
struct tone_dec_list_handle {
struct list_head list_entry; // 链表
u8 preemption : 1; // 打断
u8 idx; // 循环播放序号
u8 repeat_begin; // 循环播放起始序号
u8 dec_ok_cnt; // 正常播放计数
u16 loop; // 循环播放次数
int sync_confirm_time;
char **file_list; // 文件名
const char *evt_owner; // 事件接受任务
void (*evt_handler)(void *priv, int flag); // 事件回调
void *evt_priv; // 事件回调私有句柄
void (*stream_handler)(void *priv, int event, struct audio_dec_app_hdl *); // 数据流设置回调
void *stream_priv; // 数据流设置回调私有句柄
#if TONE_DEC_PROTECT_LIST_PLAY
void *list_protect;
#endif
};
/*
* 提示音解码结构体
* 可以实现多个tone_dec_list_handle播放通过结构体中的链表连接
* 当解码中有正弦波数组播放时,必须要实现*get_sine接口
*/
struct tone_dec_handle {
struct list_head head; // 链表头
struct audio_dec_sine_app_hdl *dec_sin; // 文件播放句柄
struct audio_dec_file_app_hdl *dec_file; // sine播放句柄
struct tone_dec_list_handle *cur_list; // 当前播放list
struct sin_param *(*get_sine)(u8 id, u8 *num); // 按序列号获取sine数组
OS_MUTEX mutex; // 互斥
#if AUDUO_DEC_TONE_HIGH_BASS_ENABLE
struct audio_eq *high_bass;
struct audio_drc *hb_drc;//高低音后的drc
struct convert_data *hb_convert;
#endif
};
/*----------------------------------------------------------------------------*/
/**@brief 创建提示音播放句柄
@param
@return 提示音句柄
@note
*/
/*----------------------------------------------------------------------------*/
struct tone_dec_handle *tone_dec_create(void);
/*----------------------------------------------------------------------------*/
/**@brief 设置sine数组获取回调
@param *dec: 提示音句柄
@param *get_sine: sine数组获取
@return
@note 当解码中有正弦波数组播放时,必须设置该接口
*/
/*----------------------------------------------------------------------------*/
void tone_dec_set_sin_get_hdl(struct tone_dec_handle *dec, struct sin_param * (*get_sine)(u8 id, u8 *num));
/*----------------------------------------------------------------------------*/
/**@brief 创建提示音播放list句柄
@param *dec: 提示音句柄
@param **file_list: 文件名
@param preemption: 打断标记
@param *evt_handler: 事件回调接口
@param *evt_priv: 事件回调私有句柄
@param *stream_handler: tone数据流设置回调
@param *stream_priv: tone数据流设置回调私有句柄
@return list句柄
@note
*/
/*----------------------------------------------------------------------------*/
struct tone_dec_list_handle *tone_dec_list_create(struct tone_dec_handle *dec,
const char **file_list,
u8 preemption,
void (*evt_handler)(void *priv, int flag),
void *evt_priv,
void (*stream_handler)(void *priv, int event, struct audio_dec_app_hdl *app_dec),
void *stream_priv);
/*----------------------------------------------------------------------------*/
/**@brief 提示音list开始播放
@param *dec: 提示音句柄
@param *dec_list: list句柄
@return true: 成功
@return false: 成功
@note 当前没有播放,马上开始播放。当前有播放,挂载到链表后面等待播放
*/
/*----------------------------------------------------------------------------*/
int tone_dec_list_add_play(struct tone_dec_handle *dec, struct tone_dec_list_handle *dec_list);
/*----------------------------------------------------------------------------*/
/**@brief 提示音播放停止
@param **ppdec: 提示音句柄
@param push_event: 普通提示音是否推送消息
@param end_flag: 结束类型
@return
@note
*/
/*----------------------------------------------------------------------------*/
void tone_dec_stop(struct tone_dec_handle **ppdec,
u8 push_event,
u8 end_flag);
/*----------------------------------------------------------------------------*/
/**@brief 指定提示音播放停止
@param **ppdec: 提示音句柄
@param push_event: 普通提示音是否推送消息
@param end_flag: 结束类型
@return
@note 如果该提示音正在播,停止播放并且播放下一个。如果不在播放,只从链表中删除
*/
/*----------------------------------------------------------------------------*/
void tone_dec_stop_spec_file(struct tone_dec_handle **ppdec,
char *file_name,
u8 push_event,
u8 end_flag);
#endif /*_AUDIO_DEC_TONE_H_*/