小编给大家分享一下surfacechanged出现的原因是什么,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
surfacechanged出现的原因
屏幕的分辨率是固定的,但是预览的分辨率是可以修改的
打个比方,(以下单位都是px,为了方便理解我们固定手机为竖屏,横向作为宽,纵向作为高)当前预览的分辨率是1280960(4:3)手机屏幕分辨率是19201080(16:9)设置的surfaceview固定的情况下都是宽高都设置为match_parent,那么它的高宽就是屏幕的高宽为1920*1080。就导致我们强行把宽为960像素的图片放到宽度为1080的画布上导致横向就有了一定的拉伸,同理纵向也被从1280拉到了1920,很显然宽度放大了1080/960倍,高度放大了1920/1280倍,这两个值肯定不相等,导致预览变形。
surfacechanged解决方法
第一种选择合适的分辨率
如上所说,既然屏幕分辨率是死的,那我们就先获得屏幕分辨率再设置预览分辨率和屏幕分辨率一样,或者比例是一样的不就好了。
1.获取屏幕分辨率
2.设置预览的分辨率(在此之前要先获取此手机支持的分辨率,乱设置会有问题的)
这是我这台测试机所支持的预览分辨率
比如手机分辨率是19201080的,那取第一个调用parameters.setPreviewSize();函数就可以完美解决了。现在出现很多分辨率很高的手机,或者长屏的手机,作者的测试机屏幕分辨为22801080,然而又没有合适的分辨率,这个方法就没办法解决了,看看第二种。
免责声明:本站发布的内容(图片、视频和文字)以原创、来自互联网转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系QQ:712375056 进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
Copyright © 2009-2021 56dr.com. All Rights Reserved. 特网科技 特网云 版权所有 珠海市特网科技有限公司 粤ICP备16109289号
域名注册服务机构:阿里云计算有限公司(万网) 域名服务机构:烟台帝思普网络科技有限公司(DNSPod) CDN服务:阿里云计算有限公司 中国互联网举报中心 增值电信业务经营许可证B2
建议您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流浏览器浏览本网站