Android16音频之获取音频时间戳AudioTrack.getTimestamp:用法实例(一百三十九)

简介: CSDN博客专家、《Android系统多媒体进阶实战》作者

博主新书推荐:《Android系统多媒体进阶实战》🚀
Android Audio工程师专栏地址:Audio工程师进阶系列原创干货持续更新中...... 】🚀
Android多媒体专栏地址:多媒体系统工程师系列原创干货持续更新中...... 】🚀
推荐1:AAOS车载系统+AOSP14系统攻城狮入门视频实战课 🚀
推荐2:Android14 Binder之HIDL与AIDL通信实战课 🚀
推荐3:Android15快速自定义与集成音效实战课 🚀
推荐4:Android15音频策略实战课 🚀

人生格言: 人生从来没有捷径,只有行动才是治疗恐惧和懒惰的唯一良药.
更多原创,欢迎关注:Android系统攻城狮

🍉🍉🍉文章目录🍉🍉🍉

      • [🌻1. 前言](#🌻1. 前言)
      • [🌻2. Android16进阶之获取音频时间戳AudioTrack.getTimestamp介绍](#🌻2. Android16进阶之获取音频时间戳AudioTrack.getTimestamp介绍)
      • [🌻3. 代码实例](#🌻3. 代码实例)
        • [🌻3.1 完整流程:视频唇音同步](#🌻3.1 完整流程:视频唇音同步)
        • [🌻3.2 完整流程:直播精准进度条](#🌻3.2 完整流程:直播精准进度条)
        • [🌻3.3 完整流程:性能分析时钟漂移](#🌻3.3 完整流程:性能分析时钟漂移)
      • [🌻3.4 用法总结](#🌻3.4 用法总结)

🌻1. 前言

本篇目的:Android16进阶之获取音频时间戳AudioTrack.getTimestamp:用法实例

🌻2. Android16进阶之获取音频时间戳AudioTrack.getTimestamp介绍

  1. 基本概念

    getTimestamp通过AudioTrack.AudioTimestamp对象返回系统级播放时钟(nanoTime)及对应帧位置,用于唇音同步、A/V对齐、精准进度计算,误差<1 ms。

  2. 功能

    返回AudioTimestamp对象;含framePosition与nanoTime;与系统时钟独立;无需权限;适用于任意传输模式。

  3. 使用限制

    需在play()后调用;若不支持返回false;与采样率、声道数无关;与getPlaybackHeadPosition互补;部分蓝牙设备延迟较大。

  4. 性能特性

    直接读取共享内存时钟;无JNI阻塞;耗时<0.1 ms;与硬件输出同步;内存恒定。

  5. 使用场景

    视频唇音同步、直播对齐、精准进度条、性能分析。

🌻3. 代码实例

🌻3.1 完整流程:视频唇音同步
java 复制代码
AudioTrack track = new AudioTrack.Builder()
        .setAudioFormat(new AudioFormat.Builder()
                .setSampleRate(48000)
                .setChannelMask(AudioFormat.CHANNEL_OUT_STEREO)
                .setEncoding(AudioFormat.ENCODING_PCM_16BIT)
                .build())
        .setBufferSizeInBytes(65536)
        .build();
track.play();
track.write(pcmData, 0, pcmData.length);
AudioTimestamp ts = new AudioTimestamp();
if (track.getTimestamp(ts)) {
    long audioFrame = ts.framePosition;
    long audioNano = ts.nanoTime;
    long videoFrame = getVideoFrameAt(audioNano);
    syncVideoTo(videoFrame);
}

代码功能:读取音频时钟及帧位置,对齐视频帧,实现<1 ms唇音同步。

🌻3.2 完整流程:直播精准进度条
java 复制代码
AudioTrack live = new AudioTrack.Builder()
        .setAudioFormat(new AudioFormat.Builder()
                .setSampleRate(44100)
                .setChannelMask(AudioFormat.CHANNEL_OUT_STEREO)
                .setEncoding(AudioFormat.ENCODING_PCM_FLOAT)
                .build())
        .setBufferSizeInBytes(32768)
        .build();
live.play();
live.write(floatPcm, 0, floatPcm.length);
AudioTimestamp ts = new AudioTimestamp();
if (live.getTimestamp(ts)) {
    long ms = (ts.framePosition * 1000) / 44100;
    progressBar.setProgress((int) ms);
}

代码功能:利用nanoTime对齐UI线程,精准刷新进度条。

🌻3.3 完整流程:性能分析时钟漂移
java 复制代码
AudioTrack track = new AudioTrack.Builder()
        .setAudioFormat(new AudioFormat.Builder()
                .setSampleRate(16000)
                .setChannelMask(AudioFormat.CHANNEL_OUT_MONO)
                .setEncoding(AudioFormat.ENCODING_PCM_16BIT)
                .build())
        .setBufferSizeInBytes(640)
        .build();
track.play();
track.write(voipBuf, 0, voipBuf.length);
AudioTimestamp ts = new AudioTimestamp();
if (track.getTimestamp(ts)) {
    long drift = System.nanoTime() - ts.nanoTime;
    Log.i("Perf", "时钟漂移=" + (drift / 1000000.0) + " ms");
}

代码功能:对比系统时钟与音频时钟,测量底层延迟,用于性能调优。

🌻3.4 用法总结

代码关键字 功能描述 典型应用
getTimestamp(ts) 帧+纳秒 唇音同步
getTimestamp(ts) 精准时间 进度条
getTimestamp(ts) 时钟漂移 性能分析
相关推荐
sweetone1 天前
LINN莲CLASSIK桌面音响微修
经验分享·音视频
晚霞的不甘1 天前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
美狐美颜SDK开放平台1 天前
多终端适配下的人脸美型方案:美颜SDK工程开发实践分享
人工智能·音视频·美颜sdk·直播美颜sdk·视频美颜sdk
饭饭大王6662 天前
CANN 生态深度整合:使用 `pipeline-runner` 构建高吞吐视频分析流水线
人工智能·音视频
晚霞的不甘2 天前
CANN 编译器深度解析:TBE 自定义算子开发实战
人工智能·架构·开源·音视频
愚公搬代码2 天前
【愚公系列】《AI短视频创作一本通》016-AI短视频的生成(AI短视频运镜方法)
人工智能·音视频
那个村的李富贵2 天前
CANN赋能AIGC“数字人”革命:实时视频换脸与表情驱动实战
aigc·音视频
晚霞的不甘2 天前
CANN 支持强化学习:从 Isaac Gym 仿真到机械臂真机控制
人工智能·神经网络·架构·开源·音视频
晚霞的不甘2 天前
CANN 支持多模态大模型:Qwen-VL 与 LLaVA 的端侧部署实战
人工智能·神经网络·架构·开源·音视频
拾荒的小海螺2 天前
开源项目:LTX2 高效可控的开源视频生成模型
开源·音视频