Camera2挖坑日记---如何解决预览画面变形

栏目: Android · 发布时间: 5年前

内容简介:一般情况下,今天主要是记录一下, 在使用

Camera2 是目前Android相机开发最新的API,旧版本的 Camera 已经被废弃了。

一般情况下, Camera2 的使用是将图像发送到 SurfaceView 或者 TextureView【通过SurfaceTexture】 来预览。使用JPEG或者Raw sensor格式的ImageReader来捕获JPEG图像或RAW缓冲区。 【注1】

今天主要是记录一下, 在使用 Camera2 API开发Android相机过程中,解决预览画面变形的问题。

另,本文所记录的情况,都是竖屏情况的设备。

题主参考Google方法给出的Demo,自定义了 TextureView ,可以自动适配宽高,支持全屏展示。代码地址 AutoFitTextureView

效果

以下的画面基本上处于同一角度拍摄所得

  • 变形的画面

    Camera2挖坑日记---如何解决预览画面变形
  • 正常的小画面,以宽为基准计算高度。

    Camera2挖坑日记---如何解决预览画面变形
  • 正常全屏画面,高度铺满屏幕,画面被拉近。

    Camera2挖坑日记---如何解决预览画面变形

解决

++在解决方案上,主要参考了Google官方给出的Demo。 Camera2VideoFragment ++。

Camera2 的使用上,我使用了 TextureView 作为预览画面的承载。为什么不使用 SurfaceView 呢?因为 SurfaceView 是基于Window层面的View,有很多View的属性都用不了,使用起来比较麻烦。

Camera2 API会返回一系列可以用于输出到 SurfaceTexture 的Size集合。--++TextureView显示原理即是使用SurfaceTexture构建的Surface++

Camera2挖坑日记---如何解决预览画面变形

如图:

以题主手上的Oppo r15为例,总共会返回13个可以用作输出的size

需要注意的是,如果以竖屏为例,这里的宽高是反过来的

在得到可用的size集合后,根据实际开发情况选择合适的PreviewSize即可

正常小画面展示

选定了一个合适的PreviewSize之后,只需要适配 TextureView 的宽高即可。小画面以宽为基准,需要根据屏幕宽度来计算相应的高度即可。这一部分的代码,在官方Demo里已经相当详细。其实很简单,就是自电影AutoFitTextureView里的 onMeasure 函数里,重新设定宽高。

override fun onMeasure(....){
    if (width < ((height * ratioWidth) / ratioHeight)) {
            // 控件本身的宽小于根据比例计算来得宽,则使用控件本身的宽
        setMeasuredDimension(width, (width * ratioHeight) / ratioWidth)
    } else {
        setMeasuredDimension((height * ratioWidth) / ratioHeight, height)
    }
}
复制代码

其中ratioWidth、ratioHeight即是PreviewSize

全屏展示

全屏展示预览画面,则需要使用 TextureView 的另一个函数—— setTransform 。这个函数是给 Textureview 设置一个Transform,用于改变 TextureView 的画面。By,双指缩放时可以使用这个函数。

全屏展示时, TextureView 的宽高铺满整个屏幕,相应的我们只需要改变一下 Transform 即可,此时高度不变,但是要将画面的宽度放大。放大的倍数即为屏幕的高度除以小画面时计算得来的高度比例即可。

还是在 onMeasure 函数内:

override fun onmeasure(...){
    val w = resources.displayMetrics.widthPixels
    val h = resources.displayMetrics.heightPixels
    setMeasuredDimension(w, h)
    fullScreenTransform.reset()
    fullScreenTransform.set(defTransform)
    // 宽拉伸,高不变
    fullScreenTransform.postScale(h.toFloat() /ratioHeight,
                    1f, w * 0.5f, h * 0.5f)
    setTransform(fullScreenTransform)
}
复制代码

其中fullScreenTransform即为TextureView最初始的Transform

自定义TextureView

题主将 AutoFitTextureView 重新封装了一下,对外提供了全屏展示的开关函数。地址在这里 AutoFitTextureView ,感兴趣的童鞋可以去看一下。

以上


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

移动风暴

移动风暴

[美]弗雷德·沃格尔斯坦 / 朱邦芊 / 中信出版社 / 2014-1-1 / 39

也许,除了伟大的乔布斯,每一位奋力改变世界的硅谷英雄,都值得我们肃然起敬。苹果与谷歌十年博弈,关于这场移动平台战争的报道早已铺天盖地,而这是第一次,我们能听到幕后工程师的真实声音。两大科技巨人用智能手机和平板电脑颠覆了电脑产业。它们位处变革的中心,凭借各自的经营哲学、魅力领袖和商业敏感度,把竞争变成了残酷对决。商业记者沃格尔斯坦报道这场对抗已逾十载,在《移动风暴》中,他带领我们来到一间间办公室和会......一起来看看 《移动风暴》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

在线进制转换器
在线进制转换器

各进制数互转换器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具