Aopermission
AOP方式封装的6.0运行时申请权限的库—A library that request Permissions in an AOP manner.
扫描二维码或点此下载APK:
更新日志
2019-06-13
1、jcenter升级到1.2.0
2、修改8.0系统上透明activity引起的bug
3、targetSDK升级到28
4、支持在util类中的非静态方法中申请权限(方法中的第一个参数传入context,如果参数为空,默认使用的是application)
UML Sequence Chart(UML时序图)
How to use
一、配置
1、权限库引入方式,在app模块的build.gradle中引入如下:
apply plugin: 'android-aspectjx'
dependencies {
compile 'com.ninetripods:aop-permission:1.2.0'
..........其他............
}
//可选配置:include和exclude的规则是去匹配包名,如果找到匹配的包名,则整个jar(即整个库)生效,
//这样做主要是考虑到性能的问题。
aspectjx {
include 'com.ninetripods','使用注解所在的包名'
}
点此查看最新版本:https://jcenter.bintray.com/com/ninetripods/aop-permission/
2、在根目录的build.gradle里面配置如下:
dependencies {
classpath 'com.android.tools.build:gradle:3.0.1'//替换你的gradle版本
classpath 'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.4'
................其他................
}
说明:aspectjx:2.0.4目前是最新版本,aspectjx历史版本查看地址: https://github.com/HujiangTechnology/gradle_plugin_android_aspectjx/blob/master/CHANGELOG.md
3、本项目中在AOP类中用到了反射,如果你的项目中在混淆后导致权限申请失败,将下面的配置加到你的混淆配置中:
-keepclasseswithmembers class * {
@com.ninetripods.aopermission.permissionlib.annotation.NeedPermission <methods>;
}
-keepclasseswithmembers class * {
@com.ninetripods.aopermission.permissionlib.annotation.PermissionCanceled <methods>;
}
-keepclasseswithmembers class * {
@com.ninetripods.aopermission.permissionlib.annotation.PermissionDenied <methods>;
}
二、使用举例
1、申请单个权限
申请单个权限:
btn_click.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
callMap();
}
});
/**
* 申请权限
*/
@NeedPermission(value = {Manifest.permission.ACCESS_FINE_LOCATION}, requestCode = 0)
private void callMap() {
Toast.makeText(this, "定位权限申请通过", Toast.LENGTH_SHORT).show();
}
@NeedPermission后面的value代表需要申请的权限,是一个String[]数组;requestCode是请求码,是为了区别开同一个Activity中有多个不同的权限请求,默认是0,如果同一个Activity中只有一个权限申请,requestCode可以忽略不写。
/**
* 权限被取消
*
* @param bean CancelBean
*/
@PermissionCanceled
public void dealCancelPermission(CancelBean bean) {
Toast.makeText(this, "requestCode:" + bean.getRequestCode(), Toast.LENGTH_SHORT).show();
}
声明一个public方法接收权限被取消的回调,方法必须有一个CancelBean类型的参数,这点类似于EventBus,CancelBean中有requestCode变量,即是我们请求权限时的请求码。
/**
* 权限被拒绝
*
* @param bean DenyBean
*/
@PermissionDenied
public void dealPermission(DenyBean bean) {
Toast.makeText(this,
"requestCode:" + bean.getRequestCode()+ ",Permissions: " + Arrays.toString(bean.getDenyList().toArray()), Toast.LENGTH_SHORT).show();
}
声明一个public方法接收权限被取消的回调,方法必须有一个DenyBean类型的参数,DenyBean中有一个requestCode变量,即是我们请求权限时的请求码,另外还可以通过denyBean.getDenyList()来拿到被权限被拒绝的List。
2、申请多个权限
基本用法同上,区别是@NeedPermission后面声明的权限是多个,如下:
/**
* 申请多个权限
*/
@NeedPermission(value = {Manifest.permission.CALL_PHONE, Manifest.permission.CAMERA}, requestCode = 10)
public void callPhone() {
Toast.makeText(this, "电话、相机权限申请通过", Toast.LENGTH_SHORT).show();
}
value中声明了两个权限,一个电话权限,一个相机权限
Thanks To
https://github.com/HujiangTechnology/gradle_plugin_android_aspectjx