android – 与mediaplayer和seekTo的奇怪行为

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

现在,问题是:

我不希望视频从头开始,而是从后面的位置开始.所以我做了一个寻求(16867).由于seekTo是异步的,我将mediaplayer(player.start())的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);
}
最佳答案
由于我还没有收到Android开发者列表的任何回复,并在网上发现了类似的问题,我得出结论,这是一个错误.我在http://code.google.com/p/android/issues/detail?id=9135提交了一份错误报告

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...