news 2026/4/23 0:35:31

Android-Audio-代码路径说明

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Android-Audio-代码路径说明

Android Audio 代码路径详解

整体架构图

┌─────────────────────────────────────────────────────────────┐ │ 应用层 (Applications) │ ├─────────────────────────────────────────────────────────────┤ │ Java Media Framework (android.media.*) │ ├─────────────────────────────────────────────────────────────┤ │ JNI 桥接层 (android_media_*) │ ├─────────────────────────────────────────────────────────────┤ │ C++ Media Framework (libmedia, libaudioclient) │ ├─────────────────────────────────────────────────────────────┤ │ 音频服务层 (AudioFlinger, AudioPolicyService) │ ├─────────────────────────────────────────────────────────────┤ │ Audio HAL (Hardware Abstraction Layer) │ ├─────────────────────────────────────────────────────────────┤ │ Linux 内核 (ALSA, tinyalsa, sound driver) │ └─────────────────────────────────────────────────────────────┘

详细代码路径说明

1.Java Framework 层 (应用API)

路径:frameworks/base/media/java/android/media/

文件/目录说明
AudioTrack.java音频播放主类,管理PCM数据播放
AudioRecord.java音频录制主类,管理PCM数据采集
AudioManager.java音频系统管理,音量、设备、焦点控制
AudioSystem.java音频系统属性设置和查询
AudioAttributes.java音频属性定义(用途、内容类型等)
AudioDeviceInfo.java音频设备信息
AudioFormat.java音频格式定义(编码、采样率等)
AudioPlaybackConfiguration.java播放配置管理
AudioRecordingConfiguration.java录制配置管理

示例调用:

// 应用层代码AudioTracktrack=newAudioTrack.Builder().setAudioAttributes(newAudioAttributes.Builder().setUsage(AudioAttributes.USAGE_MEDIA).build()).setAudioFormat(newAudioFormat.Builder().setEncoding(AudioFormat.ENCODING_PCM_16BIT).setSampleRate(44100).setChannelMask(AudioFormat.CHANNEL_OUT_STEREO).build()).build();track.play();

2.JNI 桥接层

路径:frameworks/base/core/jni/

文件对应的Java类功能
android_media_AudioTrack.cppAudioTrack连接Java AudioTrack和C++ AudioTrack
android_media_AudioRecord.cppAudioRecord连接Java AudioRecord和C++ AudioRecord
android_media_AudioSystem.cppAudioSystem系统音频属性JNI
android_media_AudioManager.cppAudioManager音频管理JNI
android_media_AudioDeviceAttributes.cppAudioDeviceInfo设备信息JNI

关键代码流:

Java AudioTrack.write() → android_media_AudioTrack.cpp 的 write() → C++ AudioTrack::write()

3.Native Client 层 (C++ API)

路径:frameworks/av/media/libaudioclient/

文件功能
AudioTrack.cppC++ AudioTrack实现,应用直接调用
AudioRecord.cppC++ AudioRecord实现
AudioSystem.cppC++ AudioSystem实现
AudioEffect.cpp音频效果处理
MonoPipe.cpp/Pipe.cpp音频管道工具

特点:

  • 提供C++接口给Native应用
  • 通过Binder与AudioFlinger通信
  • 实现音频数据缓冲和传输

4.核心服务层 (AudioFlinger)

路径:frameworks/av/services/audioflinger/

audioflinger/ ├── AudioFlinger.h/cpp # 主服务入口,管理所有音频线程 ├── Threads.h/cpp # 音频线程基类和派生类 │ ├── PlaybackThread # 播放线程基类 │ ├── MixerThread # 混音播放线程 │ ├── DirectOutputThread # 直接输出线程 │ ├── OffloadThread # 硬件解码线程 │ ├── DuplicatingThread # 复制线程(录音/A2DP) │ └── RecordThread # 录制线程 ├── Tracks.h/cpp # 音频轨道管理 ├── AudioMixer.h/cpp # 混音器实现 ├── Effects.h/cpp # 音频效果框架 ├── StateQueue.h/cpp # 状态队列 ├── FastCapture.h/cpp # 快速录制 ├── FastMixer.h/cpp # 快速混音 └── AudioHwDevice.h/cpp # 音频硬件设备封装

线程类型对比:

线程类型用途延迟特性
MixerThread普通音频混音标准延迟 (~50ms)
FastMixer低延迟音频低延迟 (<20ms)
DirectOutputThread独占输出(如通话)低延迟
OffloadThread硬件解码输出低功耗
DuplicatingThread多路输出(录音)标准延迟

5.策略服务层 (AudioPolicyService)

路径:frameworks/av/services/audiopolicy/

audiopolicy/ ├── AudioPolicyService.h/cpp # 策略服务入口 ├── managerdefault/ # 默认策略实现 │ ├── AudioPolicyManager.h/cpp │ └── AudioPolicyManagerDefault.cpp ├── engine/ # 策略引擎 │ ├── Interface/ # 引擎接口 │ ├── common/ # 公共组件 │ ├── config/ # 配置管理 │ └── default/ # 默认引擎 ├── common/ # 公共工具 ├── service/ # 服务管理 └── Engine.h/cpp # 策略引擎基类

主要功能:

  • 设备选择策略
  • 音量曲线管理
  • 音频焦点管理
  • 策略配置文件解析
  • 动态策略切换

6.Audio HAL 接口定义

路径:hardware/libhardware/include/hardware/

文件功能
audio.h主音频HAL接口定义
audio_policy.h音频策略HAL接口
audio_effects.h音频效果HAL接口

关键结构体:

// 音频HAL主要接口structaudio_hw_device{structhw_device_tcommon;// 必须实现的函数int(*open_output_stream)(...);int(*close_output_stream)(...);int(*open_input_stream)(...);int(*close_input_stream)(...);// 音频控制函数int(*set_parameters)(...);char*(*get_parameters)(...);// 更多功能...};

7.厂商HAL实现路径

路径示例:

# Qualcomm平台 hardware/qcom/audio/ ├── hal/ # HAL实现 ├── legacy/ # 旧版HAL └── post_proc/ # 后处理 # 设备特定 device/<vendor>/<device>/audio/ ├── hal/ # 设备特定HAL └── configs/ # 音频配置文件

8.系统定义和配置文件

路径:system/media/audio/include/system/

文件内容
audio.h音频系统核心定义(C API)
audio-base.h基础音频类型定义
audio_effect.h音频效果定义
audio_policy.h音频策略定义

路径:system/media/audio_utils/include/

文件功能
audio_utils/音频工具库
fifo/FIFO缓冲区实现
format/格式转换工具

9.音频效果框架

路径:frameworks/av/media/libeffects/

libeffects/ ├── factory/ # 效果工厂 │ └── EffectsFactory.c ├── lvm/ # Loudness Maximizer │ ├── lib/ # 库文件 │ └── bundle/ # 效果包 ├── preprocessing/ # 预处理效果 │ ├── Include/ # 头文件 │ └── src/ # 源码 └── libs/ # 效果库 └── reverb/ # 混响效果

10.音频工具和测试

路径:frameworks/av/media/libaudioclient/tests/

测试文件测试内容
AudioTrackTests.cppAudioTrack功能测试
AudioRecordTests.cppAudioRecord功能测试
AudioEffectTests.cpp音频效果测试

路径:frameworks/av/media/mtp/

工具功能
audioserver音频服务进程
media.log音频日志工具

关键配置文件路径

1.音频策略配置

# 通用配置 /system/etc/audio_policy_configuration.xml /system/etc/audio_policy_volumes.xml /system/etc/audio_policy_volumes_drc.xml # 设备特定配置 /vendor/etc/audio_policy_configuration.xml /vendor/etc/audio_effects.xml

2.效果配置文件

/system/etc/audio_effects.conf /vendor/etc/audio_effects.conf /data/misc/audio_effects/ # 用户效果配置

编译系统配置

路径:frameworks/av/services/audioflinger/Android.bp

cc_library_shared{name:"libaudioflinger",srcs:["AudioFlinger.cpp","Threads.cpp","Tracks.cpp",// ...],shared_libs:["libaudioclient","libmedia","libcutils",// ...],// ...}

调试和日志

1.日志标签

# 常用日志过滤adb logcat -s AudioFlinger adb logcat -s AudioPolicyManager adb logcat -s AudioTrack adb logcat -s AudioRecord adb logcat -s audio_hw_primary adb logcat -s audio_policy

2.调试工具

# 音频调试工具tinymix# 混音器控制tinyplay# 音频播放tinycap# 音频录制alsa_amixer# ALSA混音器alsa_aplay# ALSA播放alsa_arecord# ALSA录制# 系统工具dumpsys media.audio_flinger# AudioFlinger状态dumpsys media.audio_policy# AudioPolicy状态dumpsys audio# 音频系统状态

代码流程示例

音频播放完整流程:

1. App → AudioTrack.java (Java) 2. AudioTrack.write() → android_media_AudioTrack.cpp (JNI) 3. android_media_AudioTrack_write() → AudioTrack.cpp (C++) 4. AudioTrack::obtainBuffer() → AudioTrack::write() (libaudioclient) 5. AudioTrack::createTrackI() → IAudioFlinger.createTrack() (Binder IPC) 6. AudioFlinger.createTrack() (services/audioflinger) 7. AudioFlinger::PlaybackThread::createTrack_l() 8. AudioFlinger::MixerThread::prepareTracks_l() 9. AudioFlinger::AudioMixer::process() 10. PlaybackThread::threadLoop_write() 11. AudioStreamOut::write() (HAL) 12. audio_hw_device::out_write() (厂商HAL) 13. tinyalsa/ALSA驱动写入

常见问题定位路径

问题类型建议查看路径
无声/杂音AudioFlinger Threads.cpp, HAL实现
音频延迟FastMixer.cpp, audio_hw.cpp
设备切换失败AudioPolicyManager.cpp, 策略配置
音量问题AudioPolicyManager音量曲线, audio_policy_volumes.xml
录音问题RecordThread.cpp, 输入设备配置
音效失效Effects.cpp, audio_effects.conf

这个代码路径结构反映了Android音频系统的模块化设计,每个层级都有明确的职责边界,便于维护和扩展。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:16:29

AutoGPT支持Markdown输出:方便文档整理

AutoGPT支持Markdown输出&#xff1a;重塑智能文档工作流 在信息爆炸的时代&#xff0c;知识工作者每天都在与碎片化内容搏斗——从海量网页中筛选资料、将零散笔记整理成报告、反复调整格式只为发布一篇结构清晰的文章。这个过程低效且耗神&#xff0c;而真正的问题在于&#…

作者头像 李华
网站建设 2026/4/21 12:15:26

测试认证选择:ISTQB还是其他?

在快速演进的软件测试行业&#xff0c;专业认证已成为职业发展的重要里程碑。根据2024年行业调研数据显示&#xff0c;持有权威认证的测试工程师薪资平均提升18%-25%&#xff0c;且晋升速度明显加快。面对市场上琳琅满目的认证体系&#xff0c;测试从业者往往陷入选择困境&…

作者头像 李华
网站建设 2026/4/17 15:21:26

Windows设备停止错误代码43 怎么解决

一、Windows 错误码43 是什么Windows错误代码43表示系统检测到设备&#xff08;如显卡、蓝牙或USB设备&#xff09;报告问题&#xff0c;是 Windows 操作系统中常见的设备管理器错误&#xff0c;当系统检测到某个硬件设备无法正常工作时&#xff0c;便会显示错误信息‌通常由硬…

作者头像 李华
网站建设 2026/4/19 2:43:02

LobeChat能否记录用户Token消耗明细?精细化计费前提

LobeChat能否记录用户Token消耗明细&#xff1f;精细化计费前提 在企业级AI应用日益普及的今天&#xff0c;一个看似简单的聊天界面&#xff0c;是否能支撑起复杂的资源管理和成本核算&#xff0c;已经成为决定其能否从“玩具”走向“工具”的关键分水岭。特别是当团队开始共用…

作者头像 李华
网站建设 2026/4/18 15:33:20

HTML语义化标签提升AI项目文档可读性

HTML语义化标签提升AI项目文档可读性 在现代人工智能项目的开发中&#xff0c;一个常被忽视却至关重要的环节是&#xff1a;如何让技术文档既“写得清楚”&#xff0c;又“被机器读懂”。随着PyTorch、CUDA等复杂工具链的普及&#xff0c;AI系统涉及的模块越来越多——从分布式…

作者头像 李华
网站建设 2026/4/22 21:56:46

本地jar包加入mvn .m2的命令

将本地jar包加入mvn .m2的命令 mvn install:install-file -DfileD:\logging-interceptor-2.7.5.jar -DgroupIdcom.squareup.okhttp -DartifactIdlogging-interceptor -Dversion2.7.5 -Dpackagingjar mvn install:install-file -DfileC:\Users\tobiaswang\Downloads\JWT-related…

作者头像 李华