Странное поведение с медиаплеером и seekTo

Я реализую пользовательский видеоплеер, потому что мне нужны пользовательские элементы управления видео. У меня есть приложение только с одним действием, которое при запуске должно сразу начать воспроизведение видео.

Теперь у меня есть проблема:

Я не хочу, чтобы видео начиналось с начала, а с более поздней позиции. Поэтому я ищу (16867). Поскольку seekTo является асинхронным, я помещаю стартовый вызов медиаплеера (player.start()) в onSeekComplete onSeekCompleteListener.

Странное поведение, которое я испытываю, заключается в том, что я могу видеть / слышать видео, воспроизводимое с начала, в течение нескольких миллисекунд, прежде чем оно действительно воспроизводится из / переходит в положение, к которому я стремился. Но, с другой стороны, вывод Log, который я вызываю до player.start, возвращает правильную позицию 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);
}

1 ответ

Решение

Поскольку я также не получил никакого ответа из списка разработчиков Android и не обнаружил подобных проблем в Интернете, я пришел к выводу, что это ошибка. Я отправил отчет об ошибке на http://code.google.com/p/android/issues/detail?id=9135

Другие вопросы по тегам