CN114333933A - 一种Linux平台上安卓应用低延迟音频输出方法 - Google Patents

一种Linux平台上安卓应用低延迟音频输出方法 Download PDF

Info

Publication number
CN114333933A
CN114333933A CN202210234789.1A CN202210234789A CN114333933A CN 114333933 A CN114333933 A CN 114333933A CN 202210234789 A CN202210234789 A CN 202210234789A CN 114333933 A CN114333933 A CN 114333933A
Authority
CN
China
Prior art keywords
audio
output
android application
file
linux
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202210234789.1A
Other languages
English (en)
Other versions
CN114333933B (zh
Inventor
温研
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Linzhuo Information Technology Co Ltd
Original Assignee
Beijing Linzhuo Information Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Linzhuo Information Technology Co Ltd filed Critical Beijing Linzhuo Information Technology Co Ltd
Priority to CN202210234789.1A priority Critical patent/CN114333933B/zh
Publication of CN114333933A publication Critical patent/CN114333933A/zh
Application granted granted Critical
Publication of CN114333933B publication Critical patent/CN114333933B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Telephone Function (AREA)

Abstract

本发明公开了一种Linux平台上安卓应用低延迟音频输出方法,通过获取Linux系统中安卓兼容环境中安卓应用所采用的音频播放器的类型确定音频的输出方式,且不同的输出方式均有效减少了安卓应用在音频播放过程所涉及的进程,缩减了进程间的数据交互,有效提高了安卓应用的音频输出效率,降低了输出延时,改善了用户体验。

Description

一种Linux平台上安卓应用低延迟音频输出方法
技术领域
本发明属于桌面操作系统上运行移动应用的开发技术领域,具体涉及一种Linux平台上安卓应用低延迟音频输出方法。
背景技术
音频数据处理是安卓系统非常重要的组成部分,负责音频数据的采集和输出、音频流的控制、音频设备的管理及音量调节等,主要包括音频应用框架(Audio ApplicationFramework)、音频本地框架(Audio Native Framework)、音频服务(Audio Services)和音频硬件抽象层(Audio HAL)。此外,与音频数据处理强相关的有 MultiMedia,MultiMedia负责音视频的编解码,MultiMedia 将解码后的数据通过 AudioTrack 输出,而AudioRecord 采集的录音数据交由 MultiMedia 进行编码。
一般情况下,安卓系统中安卓应用播放音频可采用MediaPlayer 和 AudioTrack。其中,MediaPlayer支持播放多种格式的音源,如:mp3、flac、wma、ogg、wav等,MediaPlayer的实现过程中先在 Native 层创建对应的音频解码器和AudioTrack,并将由音频解码器解码后的数据交由AudioTrack进行输出,由此可见,MediaPlayer的应用场景更广使用也更方便。AudioTrack仅支持播放解码后的 PCM 数据流,通常在对声音时延要求非常苛刻的应用场景才需要用到AudioTrack。
安卓系统中安卓应用播放音频的过程为:MediaPlayer解析音频文件格式,然后调用解码器生成PCM格式音频数据,再将PCM音频数据传输给AudioTrack;AudioTrack将音频数据传输给AudioFlinger;AudioFlinger混音后调用音频设备的HAL接口,由音频设备的HAL接口操作音频设备输出音频。
综上所述,由于安卓系统中安卓应用输出音频的操作过程所涉及的中间层、进程较多,音频数据处理流程较为复杂,数据传输过程的开销较大,因此导致安卓应用的音频输出效率较低,输出延时较大,很大程度上影响用户体验,现有运行于Linux平台上的安卓兼容环境内一般是基于安卓系统的音频输出机制实现的安卓应用的音频输出,因此仍存在上述问题。
发明内容
有鉴于此,本发明提供了一种Linux平台上安卓应用低延迟音频输出方法,能够针对不同的音频播放器及不同的音频文件输出标识动态确定音频输出方式从而实现低延迟的音频输出。
本发明提供的一种Linux平台上安卓应用低延迟音频输出方法,包括以下步骤:
步骤1、安卓应用需要输出音频时,若当前安卓兼容环境中不存在其他安卓应用正在输出音频,则安卓应用获取音频焦点执行步骤2;否则执行步骤6;
步骤2、若安卓应用采用MediaPlayer输出音频则执行步骤3,若安卓应用采用AudioTrack输出音频则执行步骤4;
步骤3、读取待输出音频后,采用解码器逐帧解码待输出音频得到解码音频文件,再基于PulseAudio接口逐帧将解码音频文件输出到Linux音频设备,在安卓应用完成音频输出后执行步骤5;
步骤4、读取待输出音频获取其输出标识,根据输出标识输出待输出音频,在安卓应用完成音频输出后执行步骤5;
步骤5、安卓应用释放音频焦点,并检测安卓兼容环境内的暂停音频流队列,如果暂停音频流队列中存在被暂停的音频流,则选取暂停音频流队列中最早暂停的音频流继续播放,结束本流程;如果没有,则结束本流程;
步骤6、安卓应用请求获取音频焦点,若安卓应用未能获取音频焦点,则等待设定时间间隔后执行步骤6;若安卓应用获取了音频焦点,则暂停当前音频的输出,并等待当前音频解码完毕后,将当前音频作为暂停音频流追加到安卓兼容环境的暂停音频流队列中,执行步骤2。
进一步地,所述步骤3中基于解码器逐帧解码待输出音频得到解码音频文件,再基于PulseAudio接口逐帧将解码音频文件输出到Linux音频设备包括:
将待输出音频读入内存缓冲区;采用解码单元从内存缓冲区逐帧读取待输出音频并解码得到解码音频文件,将解码音频文件写入解码内存缓冲区后;再使用输出单元从解码内存缓冲区中读取解码音频文件,并根据码率确定输出间隔,按照输出间隔采用PulseAudio接口逐帧输出到Linux音频设备。
进一步地,所述解码单元及输出单元均为以Native函数的方式实现。
进一步地,在所述将待输出音频读入内存缓冲区之前,根据待输出音频的数据源确定待输出音频的类型,若待输出音频的类型为本地音频文件,则将本地音频文件一次性读入内存缓冲区,再根据音频文件的编码格式、压缩比及编码文件大小确定音频文件解码后的解码音频文件大小,根据解码音频文件大小分配用于存放解码音频文件的解码内存缓冲区;若待输出音频为网络音频流,则将待输出音频逐帧读入内存缓冲区。
进一步地,所述按照输出间隔采用PulseAudio接口逐帧输出到Linux音频设备时采用Linux系统的计时器接口进行计时。
进一步地,所述步骤4中根据输出标识输出待输出音频包括:
当输出标识为AUDIO_OUTPUT_FLAG_DIRECT时,采用ALSA接口将待输出音频输出至Linux音频设备;
当输出标识为AUDIO_OUTPUT_FLAG_PRIMARY时,将待输出音频发送至AudioFlinger;
当输出标识为AUDIO_OUTPUT_FLAG_FAST时,若安卓应用以独占方式使用ALSA接口则采用ALSA接口将待输出音频输出至Linux音频设备;否则采用PulseAudio将待输出音频输出至Linux音频设备;
当输出标识为AUDIO_OUTPUT_FLAG_DEEP_BUFFER时,采用PulseAudio将待输出音频输出至Linux音频设备;
当输出标识为AUDIO_OUTPUT_FLAG_COMPRESS_OFFLOAD时,采用解码器解码待输出音频得到解码音频文件,若安卓应用以独占方式使用ALSA接口则采用ALSA接口将待输出音频输出至Linux音频设备;否则采用PulseAudio将待输出音频输出至Linux音频设备。
有益效果:
本发明通过获取Linux系统中安卓兼容环境中安卓应用所采用的音频播放器的类型确定音频的输出方式,且不同的输出方式均有效减少了安卓应用在音频播放过程所涉及的进程,缩减了进程间的数据交互,有效提高了安卓应用的音频输出效率,降低了输出延时,改善了用户体验。
附图说明
图1为本发明提供的一种Linux平台上安卓应用低延迟音频输出方法的流程图。
具体实施方式
下面结合附图并举实施例,对本发明进行详细描述。
本发明提供了一种Linux平台上安卓应用低延迟音频输出方法,其核心思想是:根据Linux系统内安卓兼容环境中输出音频的情况,确定当前待播放音频的安卓应用获取焦点,再根据安卓应用所采用的音频播放器的不同完成安卓应用对音频的输出。
本发明提供了一种Linux平台上安卓应用低延迟音频输出方法,流程如图1所示,具体包括以下步骤:
步骤1、在Linux系统的安卓兼容环境中,当安卓应用需要输出音频,则检测当前安卓兼容环境中是否存在正在输出音频的其他安卓应用,若当前安卓兼容环境中不存在其他安卓应用正在输出音频,则执行步骤2;若当前安卓兼容环境中存在其他安卓应用正在输出音频,则执行步骤6。
安卓兼容环境中安卓应用一般采用MediaPlayer 和 AudioTrack,但是底层都是采用AudioManagerService创建的AudioTrack输出音频,通过检测AudioTracke的使用情况即可确定安卓兼容环境中是否存在安卓应用正在输出音频。
安卓系统中定义了以下六种类型的音频流,包括:
AUDIO_STREAM_VOICE_CALL为电话语音;
AUDIO_STREAM_SYSTEM为系统声音;
AUDIO_STREAM_RING为铃声声音,如来电铃声、闹钟铃声等;
AUDIO_STREAM_MUSIC为音乐声音;
AUDIO_STREAM_ALARM为警告音;
AUDIO_STREAM_NOTIFICATION为通知音;
AUDIO_STREAM_DTMF DTMF 为拨号盘按键音。
本发明仅针对其中的AUDIO_STREAM_MUSIC音乐声音类型进行处理。
进一步地,当音频类型为AUDIO_STREAM_MUSIC类型时,由于此类音频的时长往往较长,且码率较高,因此此类音频对延迟更加敏感,因此音频类型为AUDIO_STREAM_MUSIC类型时处理效果更佳。
步骤2、安卓应用向安卓兼容环境发送requestAudioFocus消息获取音频焦点(Audio Focus),若安卓应用采用MediaPlayer输出音频则执行步骤3,若安卓应用采用AudioTrack输出音频则执行步骤4。
步骤3、读取待输出音频后,基于解码器逐帧对待输出音频解码得到解码音频文件,再基于PulseAudio接口逐帧将解码音频文件输出到Linux音频设备,在安卓应用完成音频输出后执行步骤5。
其中,读取待输出音频后,基于解码器逐帧对待输出音频解压得到解码音频文件,再基于PulseAudio接口逐帧将解码音频文件输出到Linux音频设备,包括以下步骤:
步骤3.1、获取安卓应用待输出音频的数据源,根据数据源判断待输出音频的类型,若待输出音频为本地音频文件,则将本地音频文件读入内存缓冲区,再根据音频文件的编码格式、压缩比及编码文件大小确定音频文件解码后的解码音频文件大小,根据解码音频文件大小分配用于存放解码音频文件的解码内存缓冲区;若待输出音频为网络音频流,则将待输出音频逐帧读入内存缓冲区。
在安卓兼容环境中,安卓应用往往通过setDataSource方法设置音频文件的来源,因此,本发明通过获取MediaPlayer的data source即可判断音频文件的类型,例如,如果数据源是以http://、https://等开头则该音频文件属于网络音频流的类型,否则属于本地音频文件。
对于本地音频文件的类型,为了提高执行效率,本发明采用一次性将待输出音频读取到内存缓冲区中的方式,例如:使用内存缓冲区EncodedAudioBuffer存储待输出音频,EncodedAudioBuffer的大小为EncodedAudioBufferSize,再根据待输出音频的音频文件编码格式及压缩比确定解码后音频文件的大小DecodedAudioBufferSize,将解码音频文件存储在大小为DecodedAudioBufferSize的内存缓冲区DecodedAudioBuffer中。
具体来说,可采用DecodedAudioBufferSize=EncodedAudioBufferSize*(N+t)计算得到解码后音频文件的大小,其中,N(N>=1)为压缩比。
步骤3.2、采用解码单元从内存缓冲区逐帧读取待输出音频并解码得到解码音频文件,将解码音频文件写入解码内存缓冲区后,再使用输出单元从解码内存缓冲区中读取解码音频文件进行输出。解码单元及输出单元均为以Native函数的方式实现的并行单元。
其中,解码单元用于解码待输出音频得到解码音频文件,再将解码音频文件写入解码内存缓冲区中;输出单元用于从内存缓冲区中逐帧读取解码音频文件,再采用PulseAudio接口逐帧输出解码音频文件。一般情况下,解码音频文件为PCM格式音频数据。
进一步地,本发明可以采用C/C++实现名为native_start的Native函数,在native_start中创建两个线程解码线程和输出线程,分别负责解码音频数据和输出音频数据,即,分别实现解码单元和输出单元的功能。
解码线程利用FFmpeg或其他解码器逐帧解码待输出音频,即从EncodedAudioBuffer中读取待输出音频并解码到DecodedAudioBuffer,解码后的音频文件为PCM格式音频数据。输出线程根据码率确定输出间隔interval,为了进一步提高计时精度,本发明直接使用Linux系统的计时器接口或者直接访问计时器寄存器,而不使用Android系统的计时器接口,且每隔interval时间后从DecodedAudioBuffer读取一帧数据再使用PulseAudio接口输出该帧数据,最后从DecodedAudioBuffer中移除该帧数据。
步骤4、读取待输出音频,此时的待输出音频为解码后的解码音频文件,再获取AudioTrack的输出标识,并根据输出标识对待输出音频进行分类处理以完成待输出音频的输出操作,在安卓应用完成音频输出后执行步骤5。
根据输出标识对待输出音频进行分类处理的过程具体包括:
当输出标识为AUDIO_OUTPUT_FLAG_DIRECT时,则采用ALSA接口将待输出音频输出至音频设备;当输出标识为AUDIO_OUTPUT_FLAG_PRIMARY时,则将待输出音频发送给AudioFlinger执行后续处理;当输出标识为AUDIO_OUTPUT_FLAG_FAST时,若安卓应用能以独占方式打开ALSA接口音频设备则采用ALSA接口将待输出音频输出至音频设备,若安卓应用不能以独占方式打开ALSA接口音频设备则采用PulseAudio将待输出音频输出至音频设备;当输出标识为AUDIO_OUTPUT_FLAG_DEEP_BUFFER时,则采用PulseAudio将待输出音频输出至音频设备;当输出标识为AUDIO_OUTPUT_FLAG_COMPRESS_OFFLOAD时,则先采用解码器对待输出音频进行解码得到解码音频文件,若安卓应用能以独占方式打开ALSA接口音频设备则采用ALSA接口将待输出音频输出至音频设备,若安卓应用不能以独占方式打开ALSA接口音频设备则采用PulseAudio将待输出音频输出至音频设备。
在现有安卓兼容环境中提供的AudioTrack Native API包括以下输出标识,安卓应用在采用音频播放器MediaPlayer 和 AudioTrack时将设定音频文件的输出标识:
AUDIO_OUTPUT_FLAG_DIRECT,表示音频流直接输出到音频设备,不需要软件混音,一般用于 HDMI 设备声音输出;
AUDIO_OUTPUT_FLAG_PRIMARY,表示音频流需要输出到主输出设备,一般用于铃声类声音;
AUDIO_OUTPUT_FLAG_FAST,表示音频流需要快速输出到音频设备,一般用于按键音、游戏背景音等对时延要求高的场景;
AUDIO_OUTPUT_FLAG_DEEP_BUFFER,表示音频流输出可以接受较大的时延,一般用于音乐、视频播放等对时延要求不高的场景;
AUDIO_OUTPUT_FLAG_COMPRESS_OFFLOAD,表示音频流没有经过软件解码,需要输出到硬件解码器,由硬件解码器进行解码。
进一步地,为了提高处理效率进一步降低延时,本发明提出的根据输出标识对待输出音频进行分类处理以完成待输出音频的输出操作是基于AudioTrack的Native API实现的。
步骤5、安卓应用释放Audio Focus,并检测安卓兼容环境内的暂停音频流队列,如果暂停音频流队列中存在被暂停的音频流,则从暂停音频流队列中取出最早暂停的音频流继续播放;如果没有,则结束本流程。
步骤6、安卓应用向安卓兼容环境发送requestAudioFocus消息,若安卓应用未能获取Audio Focus,则等待设定时间间隔后执行步骤6;若安卓应用获取了Audio Focus,则暂停当前的音频输出操作,并等待当前音频解码操作完成得到暂停音频流,将暂停音频流加入安卓兼容环境的暂停音频流队列中,执行步骤2。
综上所述,以上仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (6)

1.一种Linux平台上安卓应用低延迟音频输出方法,其特征在于,包括以下步骤:
步骤1、安卓应用需要输出音频时,若当前安卓兼容环境中不存在其他安卓应用正在输出音频,则安卓应用获取音频焦点执行步骤2;否则执行步骤6;
步骤2、若安卓应用采用MediaPlayer输出音频则执行步骤3,若安卓应用采用AudioTrack输出音频则执行步骤4;
步骤3、读取待输出音频后,采用解码器逐帧解码待输出音频得到解码音频文件,再基于PulseAudio接口逐帧将解码音频文件输出到Linux音频设备,在安卓应用完成音频输出后执行步骤5;
步骤4、读取待输出音频获取其输出标识,根据输出标识输出待输出音频,在安卓应用完成音频输出后执行步骤5;
步骤5、安卓应用释放音频焦点,并检测安卓兼容环境内的暂停音频流队列,如果暂停音频流队列中存在被暂停的音频流,则选取暂停音频流队列中最早暂停的音频流继续播放,结束本流程;如果没有,则结束本流程;
步骤6、安卓应用请求获取音频焦点,若安卓应用未能获取音频焦点,则等待设定时间间隔后执行步骤6;若安卓应用获取了音频焦点,则暂停当前音频的输出,并等待当前音频解码完毕后,将当前音频作为暂停音频流追加到安卓兼容环境的暂停音频流队列中,执行步骤2。
2.根据权利要求1所述的一种Linux平台上安卓应用低延迟音频输出方法,其特征在于,所述步骤3中基于解码器逐帧解码待输出音频得到解码音频文件,再基于PulseAudio接口逐帧将解码音频文件输出到Linux音频设备包括:
将待输出音频读入内存缓冲区;采用解码单元从内存缓冲区逐帧读取待输出音频并解码得到解码音频文件,将解码音频文件写入解码内存缓冲区后;再使用输出单元从解码内存缓冲区中读取解码音频文件,并根据码率确定输出间隔,按照输出间隔采用PulseAudio接口逐帧输出到Linux音频设备。
3.根据权利要求2所述的一种Linux平台上安卓应用低延迟音频输出方法,其特征在于,所述解码单元及输出单元均为以Native函数的方式实现。
4.根据权利要求2所述的一种Linux平台上安卓应用低延迟音频输出方法,其特征在于,在所述将待输出音频读入内存缓冲区之前,根据待输出音频的数据源确定待输出音频的类型,若待输出音频的类型为本地音频文件,则将本地音频文件一次性读入内存缓冲区,再根据音频文件的编码格式、压缩比及编码文件大小确定音频文件解码后的解码音频文件大小,根据解码音频文件大小分配用于存放解码音频文件的解码内存缓冲区;若待输出音频为网络音频流,则将待输出音频逐帧读入内存缓冲区。
5.根据权利要求2所述的一种Linux平台上安卓应用低延迟音频输出方法,其特征在于,所述按照输出间隔采用PulseAudio接口逐帧输出到Linux音频设备时采用Linux系统的计时器接口进行计时。
6.根据权利要求1所述的一种Linux平台上安卓应用低延迟音频输出方法,其特征在于,所述步骤4中根据输出标识输出待输出音频包括:
当输出标识为AUDIO_OUTPUT_FLAG_DIRECT时,采用ALSA接口将待输出音频输出至Linux音频设备;
当输出标识为AUDIO_OUTPUT_FLAG_PRIMARY时,将待输出音频发送至AudioFlinger;
当输出标识为AUDIO_OUTPUT_FLAG_FAST时,若安卓应用以独占方式使用ALSA接口则采用ALSA接口将待输出音频输出至Linux音频设备;否则采用PulseAudio将待输出音频输出至Linux音频设备;
当输出标识为AUDIO_OUTPUT_FLAG_DEEP_BUFFER时,采用PulseAudio将待输出音频输出至Linux音频设备;
当输出标识为AUDIO_OUTPUT_FLAG_COMPRESS_OFFLOAD时,采用解码器解码待输出音频得到解码音频文件,若安卓应用以独占方式使用ALSA接口则采用ALSA接口将待输出音频输出至Linux音频设备;否则采用PulseAudio将待输出音频输出至Linux音频设备。
CN202210234789.1A 2022-03-11 2022-03-11 一种Linux平台上安卓应用低延迟音频输出方法 Active CN114333933B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210234789.1A CN114333933B (zh) 2022-03-11 2022-03-11 一种Linux平台上安卓应用低延迟音频输出方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210234789.1A CN114333933B (zh) 2022-03-11 2022-03-11 一种Linux平台上安卓应用低延迟音频输出方法

Publications (2)

Publication Number Publication Date
CN114333933A true CN114333933A (zh) 2022-04-12
CN114333933B CN114333933B (zh) 2022-05-20

Family

ID=81033729

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210234789.1A Active CN114333933B (zh) 2022-03-11 2022-03-11 一种Linux平台上安卓应用低延迟音频输出方法

Country Status (1)

Country Link
CN (1) CN114333933B (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114879932A (zh) * 2022-07-12 2022-08-09 北京麟卓信息科技有限公司 一种基于输出方式自动切换的安卓系统音频输出优化方法
CN114968168A (zh) * 2022-08-02 2022-08-30 北京麟卓信息科技有限公司 一种安卓应用输出音量的独立控制方法

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100241963A1 (en) * 2009-03-17 2010-09-23 Kulis Zachary R System, method, and apparatus for generating, customizing, distributing, and presenting an interactive audio publication
US20120172088A1 (en) * 2010-12-31 2012-07-05 Motorola-Mobility, Inc. Method and System for Adapting Mobile Device to Accommodate External Display
CN105100871A (zh) * 2015-07-27 2015-11-25 四川长虹电器股份有限公司 智能电视在同屏多窗口模式下的静音控制方法
CN105468380A (zh) * 2015-12-29 2016-04-06 山东大学 一种安卓系统上管理音频焦点的优化方法
CN106993097A (zh) * 2017-03-31 2017-07-28 维沃移动通信有限公司 一种音乐播放方法及移动终端
CN111459715A (zh) * 2019-01-20 2020-07-28 华为技术有限公司 应用异常恢复
CN113515406A (zh) * 2021-09-15 2021-10-19 北京麟卓信息科技有限公司 一种安卓运行环境中音频播放故障处理方法及装置
CN114095778A (zh) * 2020-08-25 2022-02-25 海信视像科技股份有限公司 一种应用级播放器的音频硬解码方法及显示设备

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100241963A1 (en) * 2009-03-17 2010-09-23 Kulis Zachary R System, method, and apparatus for generating, customizing, distributing, and presenting an interactive audio publication
US20120172088A1 (en) * 2010-12-31 2012-07-05 Motorola-Mobility, Inc. Method and System for Adapting Mobile Device to Accommodate External Display
CN105100871A (zh) * 2015-07-27 2015-11-25 四川长虹电器股份有限公司 智能电视在同屏多窗口模式下的静音控制方法
CN105468380A (zh) * 2015-12-29 2016-04-06 山东大学 一种安卓系统上管理音频焦点的优化方法
CN106993097A (zh) * 2017-03-31 2017-07-28 维沃移动通信有限公司 一种音乐播放方法及移动终端
CN111459715A (zh) * 2019-01-20 2020-07-28 华为技术有限公司 应用异常恢复
CN114095778A (zh) * 2020-08-25 2022-02-25 海信视像科技股份有限公司 一种应用级播放器的音频硬解码方法及显示设备
CN113515406A (zh) * 2021-09-15 2021-10-19 北京麟卓信息科技有限公司 一种安卓运行环境中音频播放故障处理方法及装置

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
_ONCE1: "Android音频焦点处理方法", 《JIANSHU.COM/P/26EA60C499A7》 *
YONGJIAN HU .ETC: "Versatile yet lightweight record-and-replay for android", 《OOPSLA 2015:PROCEEDINGS OF THE 2015 ACM SIGPLAN INTERNATIONAL CONFERENCE ON OBJECT-ORINENTED PROGRAMMING,SYSTEMS,LANGUAGES,AND APPLICATIONS》 *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114879932A (zh) * 2022-07-12 2022-08-09 北京麟卓信息科技有限公司 一种基于输出方式自动切换的安卓系统音频输出优化方法
CN114879932B (zh) * 2022-07-12 2022-09-02 北京麟卓信息科技有限公司 一种基于输出方式自动切换的安卓系统音频输出优化方法
CN114968168A (zh) * 2022-08-02 2022-08-30 北京麟卓信息科技有限公司 一种安卓应用输出音量的独立控制方法
CN114968168B (zh) * 2022-08-02 2022-09-27 北京麟卓信息科技有限公司 一种安卓应用输出音量的独立控制方法

Also Published As

Publication number Publication date
CN114333933B (zh) 2022-05-20

Similar Documents

Publication Publication Date Title
CN114333933B (zh) 一种Linux平台上安卓应用低延迟音频输出方法
US11336953B2 (en) Video processing method, electronic device, and computer-readable medium
TWI502977B (zh) 影音播放裝置、影音處理裝置、系統以及方法
KR20080014843A (ko) 쌍방향 미디어 응답 시스템에서 시각 단서를 제공하는 방법
CN102143382A (zh) 用于提供终端中的广播流的暂停功能的装置和方法
CN106792066A (zh) 优化的视频解码播放的方法及系统
JP2008527472A (ja) マルチメディア・ストリームを処理する方法
WO2011137786A1 (zh) 视频文件播放的方法、系统及媒体资源服务器
TWI363558B (en) User-selectable music-on-hold for a communications device
CN103714837A (zh) 播放音频文件的电子设备与方法
WO2018192183A1 (zh) 无线传屏中视频文件的处理方法及装置
WO2022110943A1 (zh) 语音预览的方法及装置
US20170085614A1 (en) Method for processing multimedia streams
CN105808198A (zh) 应用于安卓系统的音频文件处理方法及装置、终端
JP2003330496A (ja) オーディオストリームのバッファリング制御方法及びその装置
CN100550130C (zh) 用于分发用于重放音乐的内容帧的内容分发服务器和终端
US20150100324A1 (en) Audio encoder performance for miracast
US20070230896A1 (en) Techniques for effective trick mode transitions
CN113099238B (zh) 一种用于判断安卓手机播放视频的解码方法
CN107657951B (zh) 一种在直播过程中处理声音的方法及终端设备
CN110868610B (zh) 流媒体传输方法、装置、服务器及存储介质
US8849089B2 (en) Motion picture creation method in portable device and related transmission method
CN113365108A (zh) 一种基于彩铃的音视频转码系统及方法
US9137051B2 (en) Method and apparatus for reducing rendering latency for audio streaming applications using internet protocol communications networks
US20050262256A1 (en) Method and device for multimedia processing

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant