我有一个MediaPlayer
对象,它使用SurfaceHolder
个对象作为表面。视频顶部有一个按钮,可以将视频带到网站。当发生这种情况时,我会使用player.pause()
暂停播放器。当我从网站返回时,我使用player.start()
恢复播放器。我知道当活动不再显示时表面会被破坏,并且一旦重新启动活动就会重新创建它。在我的surfaceCreated()
中,我再次设置了播放器的曲面(因为它在该点不再有曲面),然后恢复。但是,播放器只是从头开始重新启动视频。
我已经尝试评论带我进入网站的线路,只是为了看看暂停/开始是否正常工作并从最后一个位置恢复。确实如此。我不确定为什么当我离开并重新进入视频活动时,这种行为不会发生。
我也尝试过player.seekTo()
来电。没有区别。事实上,当我禁用按钮将我带到一个网站以暂停视频时,seekTo()
调用视频也从头开始,尽管位置不是0。
玩家对象在整个过程中都是一样的。
仅仅因为表面在重新启动时是新的,它不知道或不关心它的内容,是吗?玩家应该管理那个,对吧?
我现在没有想法。任何人都可以提供任何提示吗?
更新:所以我把一个快速的应用程序拼凑起来,以消除任何其他外部因素。这是视频课程的完整代码(其他课程只是带有播放按钮的活动):
public class VideoPlayer extends Activity implements MediaPlayer.OnCompletionListener,
MediaPlayer.OnErrorListener, MediaPlayer.OnPreparedListener, MediaPlayer.OnSeekCompleteListener, MediaPlayer.OnVideoSizeChangedListener,
SurfaceHolder.Callback {
private MediaPlayer player;
private SurfaceHolder mSurfaceHolder;
private SurfaceView mSurfaceView;
private Button leaveVideoButton;
private boolean isPaused = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.video_layout);
leaveVideoButton = (Button) findViewById(R.id.go_to_web);
leaveVideoButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Uri uri = Uri.parse("http://www.google.com");
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
pauseSteps();
startActivity(intent);
}
});
createPlayer();
createSurface();
}
private void createSurface() {
mSurfaceView = (SurfaceView) findViewById(R.id.surface);
mSurfaceHolder = mSurfaceView.getHolder();
mSurfaceHolder.addCallback(this);
mSurfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
}
private void createPlayer() {
player = new MediaPlayer();
player.setOnCompletionListener(this);
player.setOnErrorListener(this);
player.setOnPreparedListener(this);
player.setOnVideoSizeChangedListener(this);
player.setOnSeekCompleteListener(this);
}
private void pauseSteps() {
if(player.isPlaying()) {
player.pause();
isPaused = true;
}
}
private void playSteps() {
if(isPaused) {
isPaused = false;
player.start();
}
}
@Override
protected void onDestroy() {
super.onDestroy();
if (player.isPlaying()) {
player.stop();
}
player.reset();
player.release();
player = null;
}
@Override
public void surfaceCreated(SurfaceHolder holder) {
player.setDisplay(holder);
if (!isPaused) {
try {
// player.setDataSource(path);
AssetFileDescriptor afd = getResources().openRawResourceFd(R.raw.video);
if (afd == null) return;
player.setDataSource(afd.getFileDescriptor(), afd.getStartOffset(), afd.getLength());
afd.close();
player.prepare();
} catch (IOException e) {
e.printStackTrace();
}
} else {
playSteps();
}
}
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
}
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
}
@Override
public void onCompletion(MediaPlayer mp) {
}
@Override
public boolean onError(MediaPlayer mp, int what, int extra) {
return false;
}
@Override
public void onPrepared(MediaPlayer mp) {
player.start();
}
@Override
public void onSeekComplete(MediaPlayer mp) {
}
@Override
public void onVideoSizeChanged(MediaPlayer mp, int width, int height) {
}
}
更新2:所以我尝试了另一个视频,它从同一个地方恢复正常。这必须是一些编码问题。