In my Android app, I have a custom video player that plays video from a URL. However, when the video is in portrait orientation, the video rotates 90 degrees counterclockwise in the application.
Is there a way to get the video orientation and rotate the view accordingly? I need to dynamically determine the orientation, because the application can still play landscape videos (which is currently without orientation problems).
Here is what I have to show the video:
videoController = new MediaController(this);
videoControllerExists = true;
videoController.setAnchorView(mediaHolder);
videoController.setPadding(0, 0, 0, bottomButtonHeight);
s3Video = new VideoView(MediaPreview.this);
s3Video.setVideoURI(Uri.parse(mediaURL));
s3Video.setMediaController(videoController);
DisplayMetrics displaymetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
int h = displaymetrics.heightPixels;
int w = displaymetrics.widthPixels;
mediaHolder.addView(s3Video);
s3Video.start();
s3Video.bringToFront();
videoController.requestFocus();
Here is a portrait video with which you can test if you tried this:
https://dl.dropboxusercontent.com/u/1000620/portrait.mp4
Edit
VideoView TextureView . , URL-, .
URL-?
:
public class MediaPreview extends SherlockActivity implements YouTubePlayer.OnInitializedListener, TextureView.SurfaceTextureListener, OnBufferingUpdateListener, OnCompletionListener, OnPreparedListener,
OnVideoSizeChangedListener, MediaPlayerControl {
private MediaPlayer s3VideoPlayer;
private TextureView s3TextureView;
private Surface s;
@Override
protected void onCreate(Bundle savedInstanceState) {
s3TextureView = (TextureView) findViewById(R.id.s3_video);
s3TextureView.setSurfaceTextureListener(this);
}
@Override
public void onSurfaceTextureAvailable(SurfaceTexture surface, int width,
int height) {
s = new Surface(surface);
if(isFromVideo){
playAmazonVideo(mediaHolder);
}
}
private void playAmazonVideo(FrameLayout mediaHolder){
videoController = new MediaController(this);
videoControllerExists = true;
videoController.setAnchorView(mediaHolder);
videoController.setPadding(0, 0, 0, bottomButtonHeight);
DisplayMetrics displaymetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
int h = displaymetrics.heightPixels;
int w = displaymetrics.widthPixels;
LayoutParams videoLayoutParams = new LayoutParams(h, w);
videoLayoutParams.gravity = Gravity.CENTER;
s3TextureView.setScaleX(h/w);
s3TextureView.setLayoutParams(videoLayoutParams);
try{
s3VideoPlayer = MediaPlayer.create(this, Uri.parse(mediaURL));
s3VideoPlayer.setSurface(s);
s3VideoPlayer.setOnBufferingUpdateListener(this);
s3VideoPlayer.setOnCompletionListener(this);
s3VideoPlayer.setOnPreparedListener(this);
s3VideoPlayer.setScreenOnWhilePlaying(true);
s3VideoPlayer.setOnVideoSizeChangedListener(this);
s3VideoPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
s3VideoPlayer.start();
}
@Override
public void onPrepared(MediaPlayer mp) {
if(isAmazon && mediaURL.length() > 0){
mediaProgress.setVisibility(View.GONE);
videoController.setMediaPlayer(this);
videoController.setEnabled(true);
videoController.show();
}
}
@Override
public boolean onTouchEvent(MotionEvent event){
if(isAmazon){
Log.d(TAG, "showing video controller");
videoController.show();
}
return false;
}
@Override
public boolean canPause() {
return true;
}
@Override
public boolean canSeekBackward() {
return true;
}
@Override
public boolean canSeekForward() {
return true;
}
@Override
public int getCurrentPosition() {
return s3VideoPlayer.getCurrentPosition();
}
@Override
public int getDuration() {
return s3VideoPlayer.getDuration();
}
@Override
public boolean isPlaying() {
return s3VideoPlayer.isPlaying();
}
@Override
public void pause() {
s3VideoPlayer.pause();
}
@Override
public void seekTo(int pos) {
s3VideoPlayer.seekTo(pos);
}
@Override
public void start() {
s3VideoPlayer.start();
}
}
# 2
http://wseemann.imtqy.com/FFmpegMediaMetadataRetriever/
, , , exif , , 90. - , , !
# 3
- , . , OnVideoSizeChangedListener MediaPlayer, . , , , , EXIF . ...