Android 11 强制用户使用系统相机?

最近在Android开发者官网中查看Android 11版本变更记录的时候,发现一个有意思的改动

此项变更是说在使用Intent创建拍照,录像隐式请求的时候,只有手机预装的系统相机才会响应。举个例子,当用户需要更新微信头像,选择拍摄上传的时候,如果用户手机上有多款能响应该Intent的相机应用可供选择的话,Android11之前是这个样子的:

如果开发者没有进行适配的话,Android11上就直接跳转到系统相机去了。对于很多使用美颜,滤镜和贴纸功能的用户影响还是挺大的。

又是一波适配工作来了呀......

通过隐式Intent启动Activity的时候,我们总是需要查询一下

分别在Android Q和Android R的模拟器上运行,我们发现Android R只会返回系统相机的info

Android Q:

Android R:

文档中提供了适配方案:

If you want a specific third-party camera app to handle your app's intent, you may do so by explicitly specifying the third-party camera app’s package name to fulfill the intent.

如果希望特定的第三方相机应用程序处理应用程序的意图,可以通过显式指定第三方相机应用程序的包名称来实现该意图。例如:

Android11 中要提供原来版本的交互体验,可能就需要自己实现选择UI了......

此项变更已经在Android11 beta版本中生效,不知道正式的版本是否有所变化,也不清楚Android CTS是否会测试这一项内容,或者允许OEM厂商将其更改为原来的规则(如果CTS要测试这一项的话,OEM厂商的海外机型肯定是不能改的)。但从现在的版本迭代中可以看到,官方基于对用户的隐私和安全的保护考虑,对于API的限制是越来越多了。

虽然此项变更在issue track区域,很多Android开发者提出了明确的质疑,不过趋势是不可更改的,从一些API的限制上我们可以明显的感受到这一点。

"……我们认为,对用户的隐私与安全的保护才是正确的权衡。" — 谷歌 Issue Tracker.

比如在Android M之前,很多Android App在需要使用相机拍摄用户头像等需求的时候,大部分开发者都会使用MediaStore.ACTION_IMAGE_CAPTURE来满足这一需求。这种方式开发简单,而且不需要向系统请求Camera权限,但是在M之后,只要在manifest文件中申请了Camera权限,仅仅使用action为ACTION_IMAGE_CAPTURE的intent时,也必须要先动态申请Camera权限,否则将会抛出异常

java.lang.SecurityException: Permission Denial

官方文档中也注明了这一点

所以在使用第三方lib的时候,还要关注它在 manifest 文件中添加的东西

~~END~~


技术交流,欢迎加我微信:ezglumes ,拉你入技术交流群。

推荐阅读:

音视频面试基础题

OpenGL ES 学习资源分享

一文读懂 YUV 的采样与格式

OpenGL 之 GPUImage 源码分析

推荐几个堪称教科书级别的 Android 音视频入门项目

觉得不错,点个在看呗~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值