android多个动态权限,android 开发 实现多个动态权限的方法(并且兼容6.0以下的版本权限授权)...

前言

android开发权限授权因为版本的不同有不同的授权方式,6.0以下的版本使用的是在注册表中添加权限的静态授权(这种授权权限提示只会出现在app安装的时候),而6.0以上(包含6.0)就需要动态授权的方式。

实现思维:

1.就算是动态授权依然需要在AndroidManifest.xml里添加静态权限。

2.动态权限的数组写法与KEY。

3.判断系统版本。

4.判断权限是否获取

5.授权完成后的回调方法执行

讲解部分

1.在AndroidManifest.xml里添加静态权限。

2.动态权限的数组写法与KEY。

//因为本人是写一个头像设置的功能,所以需要在进入相机拍照或者相册选择图像中做区分。所以写了一个KEY来处理不同的Button

private static final int Permissions_GALLERY_KEY = 1;private static final int Permissions_CAMERA_KEY = 2;//需要的权限 注意请不要将数组写成 private String mPermissions[] = {"Manifest.permission.WRITE_EXTERNAL_STORAGE"};//这样加了引号的是错误的,我犯过这种低级错误

private String mPermissions[] ={Manifest.permission.WRITE_EXTERNAL_STORAGE,

Manifest.permission.READ_EXTERNAL_STORAGE,

Manifest.permission.CAMERA};

另外附危险权限清单(一般情况下只需要关注下面的危险权限一共9组24个,正常权限系统会自动添加,不需要另外授权)

危险权限组和权限:

每个组申请一个权限,这个组的其他权限也一并申请了。

所有危险的 Android 系统权限都属于权限组。如果设备运行的是 Android 6.0(API 级别 23),并且应用的 targetSdkVersion 是 23 或更高版本,则当用户请求危险权限时系统会发生以下行为:

如果应用请求其清单中列出的危险权限,而应用目前在权限组中没有任何权限,则系统会向用户显示一个对话框,描述应用要访问的权限组。对话框不描述该组内的具体权限。例如,如果应用请求

如果应用请求其清单中列出的危险权限,而应用在同一权限组中已有另一项危险权限,则系统会立即授予该权限,而无需与用户进行任何交互。例如,如果某应用已经请求并且被授予了

任何权限都可属于一个权限组,包括正常权限和应用定义的权限。但权限组仅当权限危险时才影响用户体验。可以忽略正常权限的权限组。

如果设备运行的是 Android 5.1(API 级别 22)或更低版本,并且应用的 targetSdkVersion 是 22 或更低版本,则系统会在安装时要求用户授予权限。再次强调,系统只告诉用户应用需要的权限组,而不告知具体权限。

具体的危险权限组和权限如下:

BODY_SENSORS  物体传感器(一般指距离,光感,重力等等这些感应接收器)

代码部分

下面是一个工具类

public classPermissionUtil {private static final int PERMISSION_REQUEST_CODE = 0xab;/*** 检查单个权限

*

*@paramcontext

*@returntrue = 已获得授权.

* false = 未获得授权*/

public static booleancheckPermission(Context context, String permission) {int result =ContextCompat.checkSelfPermission(context, Manifest.permission.ACCESS_FINE_LOCATION);if (result ==PackageManager.PERMISSION_GRANTED) {return true;

}return false;

}/*** 检查一组权限

*

*@paramcontext

*@parampermissionArray

*@return返回未授权的权限list, 如果返回null等于全部权限都已经被授予.*/

public staticString[] checkPermissions(Context context, String[] permissionArray) {if (permissionArray == null || permissionArray.length == 0) {return null;

}

List notPermissionList = new ArrayList<>();for(String permission : permissionArray) {int result =ContextCompat.checkSelfPermission(context, permission);if (result !=PackageManager.PERMISSION_GRANTED) {

notPermissionList.add(permission);

}

}if (notPermissionList.size() == 0) {return null;

}return notPermissionList.toArray(newString[notPermissionList.size()]);

}/*** 申请权限

*

*@paramactivity*/

public static void applyPermission(Activity activity, String[] permissionArray, intdesignationRequestCode) {

ActivityCompat.requestPermissions(activity, permissionArray, designationRequestCode);

}/*** 申请权限

*

*@paramactivity*/

public static voidapplyPermission(Activity activity, String[] permissionArray) {

ActivityCompat.requestPermissions(activity, permissionArray, PERMISSION_REQUEST_CODE);

}/*** 处理申请权限返回后的结果,此方法可以指定requestCode

*

*@paramrequestCode 返回code

*@paramdesignationRequestCode 你指定的返回code

*@parampermissions 申请权限

*@paramgrantResults 权限申请结果

*@returnString[] == null : 1.requestCode不等于designationRequestCode 2.权限申请未知错误 grantResults小于0

* String[]长度等于0:全部权限都申请成功

* String[]长度不等于0:未申请成功的权限*/

public static String[] handlerPermissionApplyResults(int requestCode, int designationRequestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {returnhandlerResults(requestCode, designationRequestCode, permissions, grantResults);

}/*** 处理申请权限返回后的结果,此方法使用默认requestCode > PERMISSION_REQUEST_CODE

*

*@paramrequestCode 返回code

*@parampermissions 申请权限

*@paramgrantResults 权限申请结果

*@returnString[] == null : 1.requestCode不等于默认PERMISSION_REQUEST_CODE 2.权限申请未知错误 grantResults小于0

* String[]长度等于0:全部权限都申请成功

* String[]长度不等于0:未申请成功的权限*/

public static String[] handlerPermissionApplyResults(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {returnhandlerResults(requestCode, PERMISSION_REQUEST_CODE, permissions, grantResults);

}private static String[] handlerResults(int requestCode, int designationRequestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {if (requestCode ==designationRequestCode) {if (grantResults.length > 0) {

List notPermissionList = new ArrayList<>();for (int i = 0; i < grantResults.length; i++) {int result =grantResults[i];

String permission=permissions[i];if (result !=PackageManager.PERMISSION_GRANTED) {

notPermissionList.add(permission);

}

}if (!notPermissionList.isEmpty()) {return notPermissionList.toArray(newString[notPermissionList.size()]);

}return new String[0];

}else{return null;

}

}else{return null;

}

}

}

End

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值