URLからMP4ビデオを表示したいvideoViewがあります。Andoird 4.0.2 エミュレーターで試してみたところ、問題なく動作しました。ただし、A GingerBread ハードウェアで試してみると、クラッシュしました。デバイスに何か問題があるのではないかと考えて、Gingerbread エミュレーターでも試してみましたが、それでも進歩しませんでした。[再生] ボタンをタップすると、logcat がこれらを何度も繰り返します。
04-11 23:49:27.438: V/VideoViewDemo(413): path: http://173.193.24.66/~kanz/video/mp4/9.mp4
04-11 23:49:28.796: D/MediaPlayer(413): Couldn't open file on client side, trying server side
04-11 23:49:38.207: D/MediaPlayer(413): getMetadata
04-11 23:49:39.343: W/MediaPlayer(413): info/warning (701, 0)
04-11 23:49:39.346: I/MediaPlayer(413): Info (701,0)
04-11 23:49:45.556: W/MediaPlayer(413): info/warning (702, 0)
04-11 23:49:45.556: I/MediaPlayer(413): Info (702,0)
04-11 23:51:11.467: W/MediaPlayer(413): info/warning (701, 0)
04-11 23:51:11.467: I/MediaPlayer(413): Info (701,0)
04-11 23:51:22.096: W/MediaPlayer(413): info/warning (702, 0)
04-11 23:51:22.096: I/MediaPlayer(413): Info (702,0)
04-11 23:51:25.636: W/MediaPlayer(413): info/warning (701, 0)
04-11 23:51:25.636: I/MediaPlayer(413): Info (701,0)
04-11 23:51:37.127: W/MediaPlayer(413): info/warning (702, 0)
04-11 23:51:37.127: I/MediaPlayer(413): Info (702,0)
04-11 23:51:41.717: W/MediaPlayer(413): info/warning (701, 0)
04-11 23:51:41.717: I/MediaPlayer(413): Info (701,0)
04-11 23:51:54.086: W/MediaPlayer(413): info/warning (702, 0)
04-11 23:51:54.097: I/MediaPlayer(413): Info (702,0)
エラーが表示されていないため、問題の原因となっている行を正確に知ることができます。再生ボタンのコードは次のとおりです。
try {
final String path = mPath.getText().toString();
Log.v(TAG, "path: " + path);
if (path == null || path.length() == 0) {
Toast.makeText(MainActivity.this, "File URL/path is empty",
Toast.LENGTH_LONG).show();
} else {
// If the path has not changed, just start the media player
if (path.equals(current) && mVideoView != null) {
mVideoView.setVideoURI(Uri.parse("http://173.193.24.66/~kanz/video/mp4/9.mp4"));
mVideoView.requestFocus();
mVideoView.start();
return;
}
current = path;
mVideoView.setVideoURI(Uri.parse(getDataSource(path)));
mVideoView.requestFocus();
mVideoView.start();
}
} catch (Exception e) {
Log.e(TAG, "error: " + e.getMessage(), e);
if (mVideoView != null) {
mVideoView.stopPlayback();
}
}
}
どんな助けでも大歓迎です。ありがとう。