Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

動画を再生する方法 VideoView

VideoViewはSurfaceViewを継承したwidgetクラスで、実体はopenVideo()メソッドでMediaPlayerを呼び出しています。
MediaPlayerの呼び出しの際に、Uri型でURIを渡しています。String型のファイルバスの場合はUri型に変換して送っています。
つまりこの2つの形式の指定しかできません。
サンプルコード
VideoViewの実体コード

簡単に動画を再生したい場合はVideoView、詳細な指定をしたい場合や速度を重視した場合はMediaPlayerを選択するといいと思います。
MediaPlayerを継承しているため、MediaPlayerでの実装を行うときに動画が再生できる形式か確認する方法としてVideoViewを使用するのもいいかもしれません。
正確にはVideoView → MediaPlayer → pvPlayerまたはstagefright playerです。

[参考記事] 動画を再生する方法 MediaPlayer
[参考記事] 2.0/2.1以前で再生できる動画が2.2以降で再生できない
[参考記事] アプリからネットワーク通信を行う場合

動画ファイルは組み込みの動画であれば/res/rawフォルダ以下に置くようにします。

[参考記事] SDやdata、downloadなど各種ディレクトリパスの取得方法

サンプルコード

TestApp.java

package com.example.test;

import android.app.Activity;

import android.os.Bundle;
import android.widget.VideoView;

public class TestApp extends Activity{

  /** Called when the activity is first created. */
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    String filePath = "/sdcard/test.3gp";

    VideoView videoView = (VideoView) findViewById(R.id.video);
    videoView.setVideoPath(filePath);
    videoView.start();
  }
}

main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  >
  <VideoView android:id="@+id/video"
      android:layout_width="300px"
      android:layout_height="100px" />
</LinearLayout>

VideoViewの実体コード

/frameworks/base/core/java/android/widget/VideoView.java

[参考記事] Androidのソースファイルを入手する方法

public class VideoView extends SurfaceView implements MediaPlayerControl {


    private void openVideo() {
        if (mUri == null || mSurfaceHolder == null) {
            // not ready for playback just yet, will try again later
            return;
        }
        // Tell the music playback service to pause
        // TODO: these constants need to be published somewhere in the framework.
        Intent i = new Intent("com.android.music.musicservicecommand");
        i.putExtra("command", "pause");
        mContext.sendBroadcast(i);

        // we shouldn't clear the target state, because somebody might have
        // called start() previously
        release(false);
        try {
            mMediaPlayer = new MediaPlayer();
            mMediaPlayer.setOnPreparedListener(mPreparedListener);
            mMediaPlayer.setOnVideoSizeChangedListener(mSizeChangedListener);
            mDuration = -1;
            mMediaPlayer.setOnCompletionListener(mCompletionListener);
            mMediaPlayer.setOnErrorListener(mErrorListener);
            mMediaPlayer.setOnBufferingUpdateListener(mBufferingUpdateListener);
            mCurrentBufferPercentage = 0;
            mMediaPlayer.setDataSource(mContext, mUri, mHeaders);
            mMediaPlayer.setDisplay(mSurfaceHolder);
            mMediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
            mMediaPlayer.setScreenOnWhilePlaying(true);
            mMediaPlayer.prepareAsync();
            // we don't set the target state here either, but preserve the
            // target state that was there before.
            mCurrentState = STATE_PREPARING;
            attachMediaController();
        } catch (IOException ex) {
            Log.w(TAG, "Unable to open content: " + mUri, ex);
            mCurrentState = STATE_ERROR;
            mTargetState = STATE_ERROR;
            mErrorListener.onError(mMediaPlayer, MediaPlayer.MEDIA_ERROR_UNKNOWN, 0);
            return;
        } catch (IllegalArgumentException ex) {
            Log.w(TAG, "Unable to open content: " + mUri, ex);
            mCurrentState = STATE_ERROR;
            mTargetState = STATE_ERROR;
            mErrorListener.onError(mMediaPlayer, MediaPlayer.MEDIA_ERROR_UNKNOWN, 0);
            return;
        }
    }
}

関連記事

スポンサーリンク

ホームページ製作・web系アプリ系の製作案件募集中です。

上に戻る