5

我正在实现自定义视频播放器,因为我需要自定义视频控件。我有一个只有一个活动的应用程序,它在启动时会立即开始播放视频。

现在,我遇到的问题是:

我不希望视频从头开始,而是从后面的位置开始。因此我做了一个 seekTo(16867)。由于 seekTo 是异步的,所以我将媒体播放器的启动调用 (player.start()) 放在 onSeekCompleteListener 的 onSeekComplete 中。

我经历的奇怪行为是,我可以看到/听到视频从一开始播放几毫秒,然后它实际上从/跳转到我寻求的位置播放。但是 - 另一方面 - 我在 player.start 之前调用的 Log 输出返回了我寻求的正确位置 16867。

下面是相关的代码部分,完整的类在http://pastebin.com/jqAAFsuX

(我在 Nexus One / 2.2 StageFright 上)

private void playVideo(String url) {
    try {
        btnVideoPause.setEnabled(false);
        if (player==null) {
            player=new MediaPlayer();
            player.setScreenOnWhilePlaying(true);
        }
        else {
            player.stop();
            player.reset();
        }
        url = "/sdcard/myapp/main/videos/main.mp4";  // <--- just for test purposes hardcoded here now     
        player.setDataSource(url);
        player.setDisplay(holder);
        player.setAudioStreamType(AudioManager.STREAM_MUSIC);
        player.setOnCompletionListener(this);
        player.setOnPreparedListener(this);

        player.setOnSeekCompleteListener(new MediaPlayer.OnSeekCompleteListener() {
            public void onSeekComplete(MediaPlayer mediaPlayer) {
                    Log.d("APP", "current pos... "+ player.getCurrentPosition() );
                    player.start();          // <------------------ start video on seek completed
                    player.setOnSeekCompleteListener(null);
                }
        });            
        player.prepareAsync();
    }
    catch (Throwable t) {
        Log.e(TAG, "Exception in btnVideoPause prep", t);
    }
}

public void onPrepared(MediaPlayer mediaplayer) {
    width=player.getVideoWidth();
    height=player.getVideoHeight();
    if (width!=0 && height!=0) {
        holder.setFixedSize(width, height);
        progressBar.setProgress(0);
        progressBar.setMax(player.getDuration());
        player.seekTo(16867);                   // <------------------ seeking to position
    }   
    btnVideoPause.setEnabled(true);
}
4

1 回答 1

4

由于我也没有收到来自 Android 开发者列表的任何回复,并且在网络上发现了类似的问题,我断定这是一个错误。我在http://code.google.com/p/android/issues/detail?id=9135提交了错误报告

于 2010-06-22T02:49:45.950 回答