安卓手机APP开发__媒体开发部分__调试的日志

devtools/2024/11/13 15:32:27/

安卓手机APP开发__媒体开发部分__调试的日志

概述

默认情况下,ExoPlayer仅有错误日志。为了记录播放器的事件,使用了事件日志类
这个类提供了额外的日志信息对于理解播放器正在做什么是很有帮助的,也有利于
调试播放的问题。事件日志记录器实现了分析监听器,所以用ExoPlayer来注册一个
实例是容易的。

Kotlin

player.addAnalyticsListener(EventLogger())

查看日志的最简单的方式是使用安卓工作台的日志标签页。你能选择你的APP作为一个
可调试的进程,告诉日志标签页仅记录选择的APP。使用事件日志记录器的表达式来过滤
日志也是可以的。

另一个使用安卓工作台的日志标签页的方法是使用控制台。例如

adb logcat EventLogger:* ExoPlayerImpl:* *:s

播放器的信息

ExoPlayerImpl类传递两个重要的信息,包括播放器版本,设备版本,操作系统版本,
还有ExoPlayer的加载了哪些模块。


 

ExoPlayerImpl: Init 59a18ab [AndroidXMedia3/1.0.0-rc02] [flame, Pixel 4, Google, 33]
ExoPlayerImpl: Release 59a18ab [AndroidXMedia3/1.0.0-rc02] [flame, Pixel 4, Google, 33] [media3.common, media3.datasource, media3.ui, media3.exoplayer, media3.decoder, media3.exoplayer.dash, media3.extractor]

播放状态

播放器的状态的改变都被记录如下:

EventLogger: playWhenReady [eventTime=0.00, mediaPos=0.00, window=0, true, USER_REQUEST]
EventLogger: state [eventTime=0.01, mediaPos=0.00, window=0, BUFFERING]
EventLogger: state [eventTime=0.93, mediaPos=0.00, window=0, period=0, READY]
EventLogger: isPlaying [eventTime=0.93, mediaPos=0.00, window=0, period=0, true]
EventLogger: playWhenReady [eventTime=9.40, mediaPos=8.40, window=0, period=0, false, USER_REQUEST]
EventLogger: isPlaying [eventTime=9.40, mediaPos=8.40, window=0, period=0, false]
EventLogger: playWhenReady [eventTime=10.40, mediaPos=8.40, window=0, period=0, true, USER_REQUEST]
EventLogger: isPlaying [eventTime=10.40, mediaPos=8.40, window=0, period=0, true]
EventLogger: state [eventTime=20.40, mediaPos=18.40, window=0, period=0, ENDED]
EventLogger: isPlaying [eventTime=20.40, mediaPos=18.40, window=0, period=0, false]

在这个例子中,播放器准备完成后,播放开始于0.93秒,用户在播放后9.4秒时,暂停了播放,
在一秒后又恢复了播放。播放在10秒后完成了。在方括号内元素是:


    [eventTime=float]: 从播放器创建后的时钟时间
    [mediaPos=float]: 当前播放位置
    [window=int]: 当前的窗口的索引
    [period=int]: 在那个窗口中的当前的时期

在每一行的最后的元素显示了被报告的状态的值。

媒体轨道

当可用的或者是选择的轨道有改变时,轨道信息就被记录下来了。
在播放开始之后,这至少能发生一次。对于可适配的流,如下的例子
显示了轨道的日志:

EventLogger: tracks [eventTime=0.30, mediaPos=0.00, window=0, period=0,
EventLogger:   group [
EventLogger:     [X] Track:0, id=133, mimeType=video/avc, bitrate=261112, codecs=avc1.4d4015, res=426x240, fps=30.0, supported=YES
EventLogger:     [X] Track:1, id=134, mimeType=video/avc, bitrate=671331, codecs=avc1.4d401e, res=640x360, fps=30.0, supported=YES
EventLogger:     [X] Track:2, id=135, mimeType=video/avc, bitrate=1204535, codecs=avc1.4d401f, res=854x480, fps=30.0, supported=YES
EventLogger:     [X] Track:3, id=160, mimeType=video/avc, bitrate=112329, codecs=avc1.4d400c, res=256x144, fps=30.0, supported=YES
EventLogger:     [ ] Track:4, id=136, mimeType=video/avc, bitrate=2400538, codecs=avc1.4d401f, res=1280x720, fps=30.0, supported=NO_EXCEEDS_CAPABILITIES
EventLogger:   ]
EventLogger:   group [
EventLogger:     [ ] Track:0, id=139, mimeType=audio/mp4a-latm, bitrate=48582, codecs=mp4a.40.5, channels=2, sample_rate=22050, supported=YES
EventLogger:     [X] Track:1, id=140, mimeType=audio/mp4a-latm, bitrate=127868, codecs=mp4a.40.2, channels=2, sample_rate=44100, supported=YES
EventLogger:   ]
EventLogger: ]

在这个例子中,播放器已经选择了五个可用的轨道中的四个。第五个视频轨道没有被选择,
因为它超过了设备的能力。在播放期间,播放器根据已经选择的视频轨道进行适配。
当播放器的适配从一个轨道到另一个轨道,就被记录了下来。如下所示:


 

EventLogger: downstreamFormat [eventTime=3.64, mediaPos=3.00, window=0, period=0, id=134, mimeType=video/avc, bitrate=671331, codecs=avc1.4d401e, res=640x360, fps=30.0]

这一行日志显示了播放器在进入媒体后3秒时切换到了640x360的分辨率的视频轨道.

解码器的选择

在大部分的用例中,ExoPlayer的渲染器使用MediaCodec。当一个解码器被初始化后,
记录的日志如下:

EventLogger: videoDecoderInitialized [0.77, 0.00, window=0, period=0, video, OMX.qcom.video.decoder.avc]
EventLogger: audioDecoderInitialized [0.79, 0.00, window=0, period=0, audio, OMX.google.aac.decoder]


http://www.ppmy.cn/devtools/18364.html

相关文章

Vue 3 路由机制详解与实践

一、路由的理解 路由是指导用户界面导航的一种机制。它通过映射 URL 到应用程序的不同视图组件来实现页面间的切换和导航。 二、路由基本切换效果 路由基本切换效果指的是当用户在应用程序中进行页面导航时,通过路由可以实现页面的切换,从而展示不同的…

mac配置maven

在 macOS 上配置 Maven 也相对简单。以下是一种常用的方法: 1. 安装maven **下载 Maven:**首先,你需要从 Maven 官网(https://maven.apache.org/download.cgi)下载最新版本的 Maven。你可以选择二进制压缩包&#xf…

电机入门1

文章目录 122.12.22.3 33.13.23.33.4 1 2 2.1 电机板 驱动板电机分类 驱动器分类 转速 转向扭矩定时器 ADC 2.2 PID 自动控制 的核心闭环控制算是 PID的应用 2.3 无刷电机用的 可大大提高其控制效率 和控制精度 3 开发板的IO 电流太小了 20~25ma 电机要A 驱动板 信号放大没舵…

面试宝典(1)——数据库篇(MySQL)

面试宝典(1)——数据库篇(MySQL) 1.什么是索引? 索引是一种用于加快数据库查询速度的数据结构。 索引可以帮助数据库快速定位到数据库表中特定列的记录,从而加快数据检索和查询的速度。 通过在表的列上…

MAC如何重装系统(怒冲30大洋,才拿到的教程~,收藏点赞兄弟们)

背景 应该是之前装了一些远程的软件,卸载一直不干净,导致电脑很卡,而且网络貌似出现了问题,钉钉直接登陆不上了。其余软件网络倒是还好。所以就去PDD,买了个教程,重装了一下。才发现是mac自带,…

机器学习day2

一、KNN算法简介 KNN 算法,或者称 k最邻近算法,是 有监督学习中的分类算法 。它可以用于分类或回归问题,但它通常用作分类算法。 二、KNN分类流程 1.计算未知样本到每一个训练样本的距离 2.将训练样本根据距离大小升序排列 3.取出距离最近…

leetcode hot100_part25

2024/4/23 56.合并区间 略 189.轮转数组 使用额外数组 遍历老数组,每个位置的元素放到新数组的位置(取余)。 环状替换 这个思路也想到了但是没想出来。 也就是连续跳,从i位置跳到它应该在(取余后)的位置x,再从x位…

信号的调幅(AM)、调频(FM)与调相(PM)对频谱结构的影响(找找复刻电赛D题的伙伴)

0.目录 (1)调制与解调的基本概念 (2)调幅对频谱结构的影响 (3)调频信号幅值变化对频谱结构的影响 (4)调频信号频率变化对频谱结构的影响 (5)调幅调频信号…