我正在使用 ExoPlayer 播放 HLS 文件,并且正在尝试获取实际观察到的比特率(而不是指示的比特率)。
我现在有onInFoListener
界面,但文档很粗略,有人可以帮忙吗?
我正在使用 ExoPlayer 播放 HLS 文件,并且正在尝试获取实际观察到的比特率(而不是指示的比特率)。
我现在有onInFoListener
界面,但文档很粗略,有人可以帮忙吗?
经过研究,我想出了这个:
事实上,ExoPlayer 带有一个InfoListener
可用于此目的的界面。这是我写的代码。
(在我的实现mVideoPlayer
中是保存我的 ExoPlayer 实例的 var 名称)
在准备播放器的代码上......
...
// assigns this as InfoListener for ExoPlayer
mVideoPlayer.setInfoListener(this);
...
稍后在 InfoListener 实现中......
private long mBytesLoaded = 0;
private long mBytesLoadedSeconds = 0;
private long mLastBytesLoadedTime = 0;
@Override
public void onLoadStarted(int sourceId, long length, int type, int trigger, Format format, int mediaStartTimeMs, int mediaEndTimeMs) {
Log.d(TAG, "onLoadStarted sourceId " + sourceId + " length " + length + " type " + type + " format " + format + " mediaStartTimeMs " + mediaStartTimeMs + " mediaEndTimeMs " + mediaEndTimeMs);
if(mLastBytesLoadedTime == 0) mLastBytesLoadedTime = System.currentTimeMillis();
}
@Override
public void onLoadCompleted(int sourceId, long bytesLoaded, int type, int trigger, Format format, int mediaStartTimeMs, int mediaEndTimeMs, long elapsedRealtimeMs, long loadDurationMs) {
Log.d(TAG, "onLoadCompleted sourceId " + sourceId + " bytesLoaded " + bytesLoaded + " type " + type + " format " + format + " mediaStartTimeMs " + mediaStartTimeMs + " mediaEndTimeMs " + mediaEndTimeMs);
// log... logBytesLoadedInSeconds
long now = System.currentTimeMillis();
float diffInSeconds = (now - mLastBytesLoadedTime) / 1000;
this.logBytesLoadedInSeconds(bytesLoaded, diffInSeconds); // helper function, explain bellow
mLastBytesLoadedTime = now;
}
这是记录在几秒钟内加载了多少字节的辅助函数
/**
* Logs an amount of bytes loaded in an amount of seconds
*
* @param bytes amount of bytes loaded
* @param seconds time in seconds that it took to load those bytes
*/
private void logBytesLoadedInSeconds(long bytes, float seconds){
mBytesLoaded += bytes;
mBytesLoadedSeconds += seconds;
if(mBytesLoadedSeconds > 0){
double bytesPerSecond = mBytesLoaded / mBytesLoadedSeconds;
double bitsPerSecond = bytesPerSecond * 8; // (8 bits in a byte)
if(bitsPerSecond < mIndicatedBitrate){
// buffer is falling behind!
mBufferWarned = true;
}else{
if(mBufferWarned){
// buffer caught up
}
}
}
}
最后,我们可以使用所有这些信息来估计观察到的 birate……
public int getObservedBitrate(){
if(mBytesLoadedSeconds != 0){
double bytesPerSecond = mBytesLoaded / mBytesLoadedSeconds;
double bitsPerSecond = bytesPerSecond * 8; // (8 bits in a byte)
Log.d(TAG," mBytesLoaded " + mBytesLoaded + " in "+mBytesLoadedSeconds+" seconds ("+(int)bitsPerSecond+" b/s indicated "+mIndicatedBitrate+" b/s) ");
return (int)bitsPerSecond;
}
return 0;
}
我知道为时已晚,但这可能对其他人有所帮助,
Format format = your_exoplayer.getVideoFormat() //returns Format
现在,一旦您获得了 Format,您可以通过以下代码获得 trackName
TrackNameProvider trackNameProvider = new DefaultTrackNameProvider(getResources());
trackNameProvider.getTrackName(format) //returns track name in string format (Ex:- 640 * 360, 0.50 Mbps)
HlsSampleSource 有一个 EventListener 和几个调用来实现。其中一些调用返回具有“比特率”属性的 Format 对象 (com.google.android.exoplayer.chunk.Format)。
格式出现在:onDownstreamFormatChanged onLoadStarted onLoadCompleted
HlsSampleSource.EventListener 可以在渲染器构建期间作为 HlsSampleSource 的一部分传递。