zoukankan      html  css  js  c++  java
  • android中Camera setDisplayOrientation使用

    在 写相机相关应用的时候遇到捕获的画面方向和手机的方向不一致的问题,比如手机是竖着拿的,但是画面是横的,这是由于摄像头默认捕获的画面byte[]是根 据横向来的,而你的应用是竖向的,解决办法是调用setDisplayOrientation来设置PreviewDisplay的方向,效果就是将捕获 的画面旋转多少度显示。
    设 置 preview 的顺时针旋转角度。这将影响 preview frames和拍照之后的相片显示。该方法主要用于垂直模式的应用。注意在旋转之前, front-facing cameras 的 preview显示是水平 flip 的,这就是说, image 是沿着 camera sensor 的垂直中心轴来反射的。所以用户可以像照镜子一样看到他们自己。这不会影响传入函数 onPreviewFrame(byte[], Camera) 的、JPEG 相片的、或记录的 video 的 byte array 的顺序,你可以自己做旋转处理。在preview 期间是不允许调用该方法的。如果你想要是你的照片和显示出来的角度一致,你可以参考下列代码:

      1. public static void setCameraDisplayOrientation (Activity activity, int cameraId, android.hardware.Camera camera) {  
      2.     android.hardware.Camera.CameraInfo info = new android.hardware.Camera.CameraInfo();  
      3.     android.hardware.Camera.getCameraInfo (cameraId , info);  
      4.     int rotation = activity.getWindowManager ().getDefaultDisplay ().getRotation ();  
      5.     int degrees = 0;  
      6.     switch (rotation) {  
      7.         case Surface.ROTATION_0:  
      8.             degrees = 0;  
      9.             break;  
      10.         case Surface.ROTATION_90:  
      11.             degrees = 90;  
      12.             break;  
      13.         case Surface.ROTATION_180:  
      14.             degrees = 180;  
      15.             break;  
      16.         case Surface.ROTATION_270:  
      17.             degrees = 270;  
      18.             break;  
      19.     }  
      20.     int result;  
      21.     if (info.facing == Camera.CameraInfo.CAMERA_FACING_FRONT) {  
      22.         result = (info.orientation + degrees) % 360;  
      23.         result = (360 - result) % 360;   // compensate the mirror  
      24.     } else {  
      25.         // back-facing  
      26.         result = ( info.orientation - degrees + 360) % 360;  
      27.     }  
      28.     camera.setDisplayOrientation (result);  
      29. }
  • 相关阅读:
    js 获取和设置css3 属性值的实现方法
    API的自动化测试
    删除html标签或标签属性以及样式
    JS+CSS实现数字滚动
    video元素和audio元素相关事件
    SDT v0.0.1 上线
    safari浏览器fixed后,被软键盘遮盖的问题—【未解决】
    js中DOM事件探究
    使用Web存储API存取本地数据
    剑指offer(Java版)第七题:用两个栈实现一个队列。队列的声明如下,请实现它的两个函数appendTail和deleteHead, 分别完成在队列尾部插入结点和在队列头部删除结点的功能。
  • 原文地址:https://www.cnblogs.com/Free-Thinker/p/3546741.html
Copyright © 2011-2022 走看看