Android会检测来自网址的视频是否为纵向

在我的Android应用中,我有一个自定义视频播放器,可以播放来自网址的视频.但是,当以纵向拍摄视频时,视频会在应用程序中逆时针旋转90度.

有没有办法让我获得视频的方向并相应地旋转视图?我需要动态检测方向,因为应用程序仍然可以播放横向视频(目前它没有方向问题).

以下是我显示视频的内容:

// create the video controller
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);
// do something here to determine if video is in portrait orientation
DisplayMetrics displaymetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
int h = displaymetrics.heightPixels;
int w = displaymetrics.widthPixels;

// add the video player to the view and play
mediaHolder.addView(s3Video);
s3Video.start();
s3Video.bringToFront();
videoController.requestFocus();

这是一个肖像视频,如果你正在尝试这个,你可以测试:
https://dl.dropboxusercontent.com/u/1000620/portrait.mp4

编辑

在查看一些示例后,我从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) {

    // set up textureview
        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){

            // set up mediacontroller
            videoController = new MediaController(this);
            videoControllerExists = true;
            videoController.setAnchorView(mediaHolder);
            videoController.setPadding(0, 0, 0, bottomButtonHeight);

            // set scale for textureview
            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);

       // Setting up video view using Media Player
        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.github.io/FFmpegMediaMetadataRetriever/

不幸的是,这似乎没有得到视频的旋转,即使我看了视频文件的exif,我可以看到方向值是90.所以如果有任何其他解决方案,请分享!

编辑#3

这是我尝试的其他东西.我看到你可以为MediaPlayer设置一个OnVideoSizeChangedListener来获取视频的宽度和高度.但是对于我正在使用的视频,宽度总是大于高度,并且玩家根据旋转EXIF值知道是否旋转视频.所以我不能用这个……

解决方法:

我无法弄清楚旋转问题,所以我最后只更新了我的Rails应用程序,以便在更新时保存视频的旋转.然后,当我从网站上获取视频到Android应用程序时,我还检索视频的旋转并相应地更新纹理视图旋转.它真的不是一个理想的方法,但我找不到任何其他解决方案.

这就是它最终的样子:

        // set scale for textureview
        final Intent i = getIntent();
        videoRotation = i.getIntExtra("videoRotation", 0);
        Log.d(TAG, "setting video rotation...");
        DisplayMetrics displaymetrics = new DisplayMetrics();
        getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
        int h = displaymetrics.heightPixels;
        int w = displaymetrics.widthPixels;
        Log.d(TAG, "hxw: " + h + w);
        LayoutParams videoLayoutParams = new LayoutParams(h, w);
        videoLayoutParams.gravity = Gravity.CENTER;
        s3TextureView.setScaleX(h/w);    
        s3TextureView.setRotation(Math.abs(360-videoRotation));
        s3TextureView.setLayoutParams(videoLayoutParams);
        Log.d(TAG, "done setting video rotation");
上一篇:php – ffmpeg修复视频方向


下一篇:android – setRequestedOrientation,但仍然根据传感器改变