Android VideoView无法播放视频错误,尤其是.mp4格式。

8

我正在尝试在我的应用程序中播放视频,但是出现了无法播放此视频的错误。我看到很多关于此问题的讨论。他们建议在播放器准备就绪后开始播放视频。我也这样做了,但是无法找出问题所在。请查看下面的代码。

public class Video extends Activity implements MediaPlayer.OnPreparedListener, MediaPlayer.OnErrorListener {

public VideoView vidPlayer;

@Override
protected void onCreate(Bundle savedInstanceState) {

    setup();
    activateVideoPlayer();
}

public void setup() {
    setContentView(R.layout.step_video);        
    vidPlayer = (VideoView) findViewById(R.id.videoPlayer);
    String playableUrl = "http://teststreaming7v.s3.amazonaws.com/public/7515/1374782317346-beagle_puppy_howl_640x360_448_main.mp4";

}

@Override
public void onPrepared(final MediaPlayer mediaPlayer) {
    mediaPlayer.setLooping(false);
    mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
        startPlayer();
    videoLoaded = true;
    mediaPlayer.setOnBufferingUpdateListener(new MediaPlayer.OnBufferingUpdateListener() {
        // show updated information about the buffering progress
        public void onBufferingUpdate(MediaPlayer mp, int percent) {
            Log.d(this.getClass().getName(), "percent: " + percent);

        }
    });

    mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {

        public void onCompletion(MediaPlayer mediaPlayer) {
            progress.setProgress(100);
                    setResult(Activity.RESULT_OK);
                    finish();
        }
    });

    readyToPlay = true;
}

@Override
public void onConfigurationChanged(Configuration newConfig) {
    super.onConfigurationChanged(newConfig);
}

@Override
public void onPause() {
    super.onPause();
    pausePlayer();
}

@Override
public void finish() {
    super.finish();
    overridePendingTransition(R.anim.engagement_fade_in, R.anim.engagement_fade_out);
}

@Override
public void onBackPressed() {
    isGoingBack = true;
    setResult(Activity.RESULT_CANCELED);
    finish();
}

@Override
public boolean onError(MediaPlayer mediaPlayer, int i, int i1) {
    JLogger.getInstance(this).log("Video Player Error!!" + Integer.toString(i) + " / " + Integer.toString(i1));

    return false;
}

public void startPlayer() {
    isPaused = false;
    vidPlayer.start();
}

public void pausePlayer() {
    isPaused = true;
        vidPlayer.pause();
}

private void activateVideoPlayer() {
    vidPlayer.setOnErrorListener(this);
    vidPlayer.setOnPreparedListener(this);

    btnPlay.setOnClickListener(new View.OnClickListener() {
        public void onClick(View view) {
            if (vidPlayer.isPlaying()) {
                pausePlayer();
            } else {
                startPlayer();
            }
        }
    });

    vidPlayer.setVideoURI(Uri.parse(playableUrl));
    vidPlayer.seekTo(step.resumePosition);
}
}

我使用的设备是摩托罗拉Atrix - Android 4.1.2 - 解锁状态。 我还在其他设备上尝试过,如Nexus 4、5和三星Tab 2。它们在那里都可以正常工作。

这是我的日志:

12-16 13:42:35.184    4427-4427/? D/MediaPlayer﹕ Couldn't open file on client side,trying server side
12-16 13:42:35.184    1417-1830/? I/AwesomePlayer﹕ setDataSource_l('http://teststreaming7v.s3.amazonaws.com/public/7515/1374782317346-beagle_puppy_howl_640x360_448_main.mp4')
12-16 13:42:35.184    1417-5481/? V/ChromiumHTTPDataSource﹕ connect on behalf of uid 10069
12-16 13:42:35.184    1417-5481/? I/ChromiumHTTPDataSource﹕ connect to http://teststreaming7v.s3.amazonaws.com/public/7515/1374782317346-beagle_puppy_howl_640x360_448_main.mp4 @0
12-16 13:42:35.684    1424-1673/? I/﹕ odm_disp_esd_thread is running(467) state=1
12-16 13:42:35.684    1417-5481/? W/WVMExtractor﹕ Failed to open libwvm.so
12-16 13:42:36.184    4547-4576/? W/GAV2﹕ Thread[GAThread,5,main]: Exception sending hit: HttpHostConnectException
12-16 13:42:36.184    4547-4576/? W/GAV2﹕ Thread[GAThread,5,main]: Connection to https://ssl.google-analytics.com refused
12-16 13:42:36.184    1417-5481/? E/OMXCodec﹕ failed to allocate node OMX.Nvidia.h264.decode
12-16 13:42:36.184    1417-5481/? E/OMXCodec﹕ failed to allocate node OMX.google.h264.decode
12-16 13:42:36.184    1417-5481/? I/OMXCodec﹕ [OMX.google.h264.decoder] AVC profile = 77 (Main), level = 22
12-16 13:42:36.184    1417-5481/? I/OMXCodec﹕ [OMX.google.h264.decoder] video dimensions are 320 x 240
12-16 13:42:36.184    1417-5481/? I/OMXCodec﹕ [OMX.google.h264.decoder] Crop rect is 320 x 240 @ (0, 0)
12-16 13:42:37.184    4427-4427/? D/MediaPlayer﹕ getMetadata
12-16 13:42:37.184    4427-4427/? D/VideoSample﹕ onPrepared() method
12-16 13:42:37.184    1417-1687/? D/AudioHardwareMot﹕ bufSize = 8192
12-16 13:42:37.184    1417-5484/? E/SoftAVC﹕ Decoder failed: -2
12-16 13:42:37.184    1417-5485/? E/OMXCodec﹕ [OMX.google.h264.decoder] ERROR(0x80001001, -1007)
12-16 13:42:37.184    1417-5486/? I/SoftAAC2﹕ Reconfiguring decoder: 44100 Hz, 2 channels
12-16 13:42:37.184    4427-4449/? E/MediaPlayer﹕ error (1, -2147483648)
12-16 13:42:37.184    1692-2165/? D/dalvikvm﹕ GC_EXPLICIT freed 113K, 39% free 8906K/14467K, paused 3ms+5ms, total 93ms
12-16 13:42:37.184    4427-4427/? E/MediaPlayer﹕ start called in state 0
12-16 13:42:37.184    4427-4427/? E/MediaPlayer﹕ error (-38, 0)
12-16 13:42:37.184    4427-4427/? E/MediaPlayer﹕ Error (1,-2147483648)
12-16 13:42:37.184    4427-4427/? D/VideoView﹕ Error: 1,-2147483648
12-16 13:42:37.184    4427-4427/? D/VideoSample﹕ VideoSample: Video Player Error!!1 / -2147483648
12-16 13:42:37.184    4427-4427/? D/VideoSample﹕ VideoSample: Get url:    http://teststreaming7v.s3.amazonaws.com/public/7515/1374782317346-beagle_puppy_howl_640x360_448_main.mp4
12-16 13:42:37.184    4427-4427/? E/MediaPlayer﹕ Error (-38,0)
12-16 13:42:37.184    4427-4427/? D/VideoView﹕ Error: -38,0
12-16 13:42:37.184    4427-4427/? D/VideoSample﹕ VideoSample: Video Player Error!!-38 / 0
12-16 13:42:37.184    4427-4427/? D/VideoSample﹕ VideoSample: Get url: http://teststreaming7v.s3.amazonaws.com/public/7515/1374782317346-beagle_puppy_howl_640x360_448_main.mp4`

编辑1

我试着播放以下两个.mp4文件,其中第一个可以播放,而第二个不能。

视频1属性
URL: 视频链接
视频比特率:179.9 kbits/sec
音频通道:立体声

Video1

视频2属性 URL: 视频链接
视频比特率:446.9 kbits/sec
音频通道:单声道

Video2


可能是因为moov原子不在文件开头。 - njzk2
@njzk2 这会不会影响在其他设备上播放相同的视频,比如Nexus 4或5或三星平板电脑?我对moov原子和其他相关主题不熟悉。如果我问了一些愚蠢的问题,请原谅。我的第二个视频只在Motorola Atrix和LG Optimus上无法播放。这些是我检查过的设备。 - LoveMeSomeFood
不是很确定,但你的观点确实有道理。 - njzk2
我找出了问题所在。第二个视频不是AVC基本档案(baseline profile)。 - LoveMeSomeFood
2个回答

9
问题在于第二个视频不是H.264 AVC基本档案。

谢谢,通过了解这个,我能够使用以下gstreamer管道生成这样的mp4视频:gst-launch-0.10 -e videotestsrc num-buffers=1000 ! x264enc qp-min=18 ! video/x-h264,stream-format=avc,profile=constrained-baseline ! qtmux ! filesink location=test.mp4 - jcarballo

2

我认识一个人也遇到了这个问题,同样是在处理MP4视频时,问题不在代码上,而是在视频本身,可能与每秒帧数有关。建议尝试其他视频,选择你知道质量完美的视频。


我以前从未使用过VideoView,因此您可能希望查看这些建议:https://dev59.com/DGQm5IYBdhLWcg3wtA0_ - TootsieRockNRoll

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接