Android学习之动态权限
【摘要】
文章目录
1、动态权限的提出背景2、动态权限的申请3、 危险权限4、 编程要点
1、动态权限的提出背景
动态权限又称之为运行时权限,是Andorid6.0之后引入的,所谓的动态就...
1、动态权限的提出背景
动态权限又称之为运行时权限,是Andorid6.0之后引入的,所谓的动态就是需要在代码中添加相应的权限申请。
动态权限的提出也是Android人性化的一面体现,先前我们安装一个app,安装最初会让我们授予该app一些权限,而这个app可能会一股脑把所有的权限都加入,而这个app我们又离不开,给用户的隐私造成了很大的隐患。运行时权限的引入便巧妙的解决了这个问题,权限的授予并不是在安装之初一股脑授予,而是需要的时候再请求用户授予!
2、动态权限的申请
当然如果用一个权限就得用户确定是否授予的话,这个用户体验是极度不好的,也就出现了权限分组。大体上来说分为两类,一类是普通权限,另一类危险权限。需要在说明的是,如果是Android6.0以下的系统,是无需动态申请的。普通权限只要我们写入清单文件,即可实现权限的申请。而危险权限是必须在程序中动态申请!
3、 危险权限
以下列表中出现的权限使用的时候都是需要动态申请的,不再列表的进行清单文件的申请即可!
还需要一提的是,危险权限分为9组24个,只要用户同意一个组的某一个,则该组的全部都会被运行,还有一次允许后,之后会默认开启!
4、 编程要点
//这个函数直接在OnCreate调用即可!
// 定义获取基于地理位置的动态权限
private void bluetoothPermissions() {
if (ContextCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_COARSE_LOCATION)
!= PackageManager.PERMISSION_GRANTED) {
ActivityCompat.requestPermissions(this, new String[]{
android.Manifest.permission.ACCESS_COARSE_LOCATION}, 1);
}
}
/**
* 重写onRequestPermissionsResult方法
* 获取动态权限请求的结果,再开启蓝牙
*/
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
switch(requestCode)
{
case 1:
if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
//动态申请成功对应的code
} else {
Toast.makeText(this, "用户拒绝了权限", Toast.LENGTH_SHORT).show();
}
break;
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
文章来源: recclay.blog.csdn.net,作者:ReCclay,版权归原作者所有,如需转载,请联系作者。
原文链接:recclay.blog.csdn.net/article/details/82874816
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)