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) 时钟漂移 性能分析
相关推荐
深念Y36 分钟前
FFmpeg 480p 转码失败但 1080p/720p 正常的坑
ffmpeg·音视频·转码·流媒体·分辨率·hls·m3u8
不吃鱼的猫7482 小时前
【音视频流媒体进阶:从网络到 WebRTC】第04篇-流媒体场景下的网络优化
网络·音视频·webrtc
不吃鱼的猫7483 小时前
【音视频流媒体进阶:从网络到 WebRTC】第02篇-I/O 多路复用:从 select 到 epoll
网络·音视频·webrtc
不吃鱼的猫7484 小时前
【音视频流媒体进阶:从网络到 WebRTC】第03篇-Reactor 模式与事件驱动网络框架
网络·音视频·webrtc
不吃鱼的猫7484 小时前
【音视频流媒体进阶:从网络到 WebRTC】第01篇-Socket 编程基础:TCP 与 UDP 的选择
网络·音视频·webrtc
Flamingˢ16 小时前
ZYNQ + OV5640 视频系统开发(四):HDMI 显示链路
嵌入式硬件·fpga开发·硬件架构·音视频
潜创微科技--高清音视频芯片方案开发17 小时前
2026年HUB方案商选型指南:主流厂商核心优势与不同应用场景适配方案深度分析
音视频·硬件工程
月诸清酒17 小时前
26-260410 AI 科技日报 (阿里开源视频模型HappyHorse登顶,马斯克疑似泄露Claude参数)
人工智能·开源·音视频
ai产品老杨18 小时前
异构计算时代的视频底座:基于 ZLMediaKit 与 Spring Boot 的 X86/ARM 跨平台架构解析
arm开发·spring boot·音视频
Black蜡笔小新21 小时前
花屏/蓝屏/黑屏/画面抖动/冻结/模糊检测,聊聊EasyCVR的视频质量诊断插件,解决运维人的实际烦恼
运维·音视频