本文鏈接: "Android MediaPlayer 倍速播放,調整播放速度" 現在市面上的很多音視頻App都有倍速播放的功能,例如把播放速度調整為0.5、1.5、2倍等等。 從Android API 23 (Android M)開始,MediaPlayer支持調整播放速度。 使用的方法是setPl ...
本文鏈接: Android MediaPlayer 倍速播放,調整播放速度
現在市面上的很多音視頻App都有倍速播放的功能,例如把播放速度調整為0.5、1.5、2倍等等。
從Android API 23 (Android M)開始,MediaPlayer支持調整播放速度。
使用的方法是setPlaybackParams,傳入一個代表播放屬性的類PlaybackParams。
本文介紹如何使用MediaPlayer調整播放速度。
MediaPlayer.setPlaybackParams 說明
播放速度設置在PlaybackParams對象中,再將此對象傳入setPlaybackParams。
setPlaybackParams是一個native方法。
如果MediaPlayer沒有準備(在prepared之前),調用此方法並不會改變MediaPlayer的狀態。
在MediaPlayer成功prepare之後,如果設置的速度為0,相當於調用了pause方法;如果設置速度不為0,相當於調用了start方法。
異常情況
如果MediaPlayer沒有初始化或者已經被釋放,即處於Idle或End狀態,調用setPlaybackParams方法會拋出IllegalStateException異常。
如果傳入的PlaybackParams不被支持,則拋出IllegalArgumentException異常。
如果設置速度小於0,則拋出java.lang.IllegalArgumentException異常。
MediaPlayer.setPlaybackParams 方法示例
設置播放速度。先判斷當前系統版本。
private boolean setPlaySpeed(float speed) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
PlaybackParams params = mediaPlayer.getPlaybackParams();
params.setSpeed(speed);
mediaPlayer.setPlaybackParams(params);
return true;
}
return false;
}
getPlaybackParams可以獲取到MediaPlayer當前的PlaybackParams對象。
也可以給這個方法加上try catch,結合返回的boolean值判斷設置速度是否成功。
private boolean setPlaySpeed(float speed) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
try {
PlaybackParams params = mediaPlayer.getPlaybackParams();
params.setSpeed(speed);
mediaPlayer.setPlaybackParams(params);
return true;
} catch (Exception e) {
Log.e(TAG, "setPlaySpeed: ", e);
return false;
}
}
return false;
}
參考代碼 https://github.com/RustFisher/android-MediaPlayer
PlaybackParams 包含的速度值
調整MediaPlayer播放速度時,我們使用了PlaybackParams對象。AudioTrack也會用到這個類。
PlaybackParams包含著播放時候的一些屬性。例如speed就是播放速度。
PlaybackParams.setSpeed(float speed)
傳入速度倍率值。會標記當前設置過了速度。
public PlaybackParams setSpeed(float speed) {
mSpeed = speed;
mSet |= SET_SPEED;
return this;
}
PlaybackParams.getSpeed()
獲取已設置的速度值。如果之前沒設置過速度,則拋出IllegalStateException異常。
public float getSpeed() {
if ((mSet & SET_SPEED) == 0) {
throw new IllegalStateException("speed not set");
}
return mSpeed;
}