Android EasyPermissions官方库高效处理权限相关教程
介绍:
easypermission库是一个简化基本的系统权限逻辑的库,可用于在android m或者更高版本上。
1 相关文档
官方文档:
运行时权限官方文档解释:
2 为什么使用easypermissions
android m对权限系统进行了改变。android m之前所需权限只需要在androidmanifest中申请即可。但更新android m系统后,部分“dangerous permission”需要在运行时询问申请。
导入easypermissions依赖库:
在module的build.gradle中添加以下代码。
dependencies { compile 'pub.devrel:easypermissions:1.0.1' }
依赖库配置完成后,开始使用。
使用步骤
1. 使用easypermissions检查权限:
权限可以是单个,也可以是一些列。在easypermission库中,使用easypermissions#haspermissions(...)检查若干权限。
<code> /** * * @param context * return true:已经获取权限 * return false: 未获取权限,主动请求权限 */ public static boolean checkpermission(activity context,string[] perms) { return easypermissions.haspermissions(context, perms); }</code> easypermissions.haspermissions():
第一个参数 : context参数.例如,activity对象。
第二个参数 : 一些系列的权限。例如,public final static string[] perms_write ={manifest.permission.write_external_storage};
2. 使用easypermissions请求权限:
检查后,发觉用户没有赋予权限,这时候需要代码请求权限,让用户同意。
在easypermission库中,使用easypermissions#requestpermissions,来请求权限。
<code><code><code> /** * 请求权限 * @param context */ public static void requestpermission(activity context,string tip,int requestcode,string[] perms) { easypermissions.requestpermissions(context, tip,requestcode,perms); }</code></code></code> easypermissions.requestpermissions():
第一个参数:context对象 第二个参数:权限弹窗上的文字提示语。告诉用户,这个权限用途。 第三个参数:这次请求权限的唯一标示,code。 第四个参数 : 一些系列的权限。
3. easypermissions响应请求结果:
请求后,弹出系统权限弹窗,剩下是用户是否授权操作。权限结果是回调在activity或者fragment中的重写的onrequestpermissionsresult()方法中。
<code><code><code>public class mainactivity extends appcompatactivity implements easypermissions.permissioncallbacks{ //.....省略部分代码。 /** * 重写onrequestpermissionsresult,用于接受请求结果 * * @param requestcode * @param permissions * @param grantresults */ @override public void onrequestpermissionsresult(int requestcode, @nonnull string[] permissions, @nonnull int[] grantresults) { super.onrequestpermissionsresult(requestcode, permissions, grantresults); //将请求结果传递easypermission库处理 easypermissions.onrequestpermissionsresult(requestcode, permissions, grantresults, this); } /** * 请求权限成功。 * 可以弹窗显示结果,也可执行具体需要的逻辑操作 * * @param requestcode * @param perms */ @override public void onpermissionsgranted(int requestcode, list<string> perms) { toastutils.showtoast(getapplicationcontext(), "用户授权成功"); } /** * 请求权限失败 * * @param requestcode * @param perms */ @override public void onpermissionsdenied(int requestcode, list<string> perms) { toastutils.showtoast(getapplicationcontext(), "用户授权失败"); /** * 若是在权限弹窗中,用户勾选了'never ask again.'或者'不在提示',且拒绝权限。 * 这时候,需要跳转到设置界面去,让用户手动开启。 */ if (easypermissions.somepermissionpermanentlydenied(this, perms)) { new appsettingsdialog.builder(this).build().show(); } } }</string></string></code></code></code>
将权限结果传递给easypermissions.onrequestpermissionsresult()来处理。、
easypermissions.onrequestpermissionsresult()方法:
第一个参数: 请求的code 第二个参数: 一些列的请求权限 第三个参数: 用户授权的结果 第四个参数: 权限回调监听器
这里不需要手写判断权限是否成功的逻辑操作,而会在easypermissions.permissioncallbacks监听器中响应。
easypermissions.permissioncallbacks接口:
onpermissionsgranted():
用户授权成功,接下来执行具体需要的逻辑操作
onpermissionsdenied():
用户授权失败,处理失败的逻辑。
注意:若是在权限弹窗中,用户勾选了'never ask again.'或者'不在提示',且拒绝权限。 这时候,需要跳转到设置界面去,让用户手动开启。
你可能并不满足,需要手动调用逻辑处理方法。easypermissions库为你考虑好了,具备强大之处。当用户同意权限后,可以不需要通过监听器方式来实现,直接调用相关的逻辑代码的方法。只需要使用@afterpermissiongranted注解标注逻辑处理的方法。
4. @afterpermissiongranted注解:
@afterpermissiongranted注解为了提供方便,但可以添加也可以不添加,是可选的。
好处:
使用了该注解,当权限请求被用户同意后,会根据请求code来执行,相应的含有@afterpermissiongranted注解的方法。
简化了请求成功操作流程,不需要在easypermissions.onrequestpermissionsresult()的回调监听器中请求成功的方法中,再次手动调用,获取权限后需要操作的逻辑代码。
以下代码,请求写入磁盘的权限,当用户同意权限后,弹出一个toast弹窗的逻辑处理操作。
<code><code><code><code><code><code><code><code> @afterpermissiongranted(constance.write_permission_code) 是可选的 public void onpermissionssuccess() { toastutils.showtoast(getapplicationcontext(), "用户授权成功"); }</code></code></code></code></code></code></code></code>
当用户同意权限,该方法不需要手动调用,会匹配到的constance.write_permission_code请求码,自动执行。
5. 使用easypermissions处理权限被拒的情况:
在权限弹窗中,用户可能直接拒绝权限,下次权限请求依旧会弹出该权限弹窗。除此之外,还可以勾选'never ask again.'或者'不在提示',且拒绝权限,下次请求权限,弹窗不能弹出,无法让用户授权。这时候,需要跳转到设置界面去,让用户手动开启。
在easypermission库中,使用easypermissions.somepermissionpermanentlydenied()来处理,是否勾选不再提示的选项。
<code><code><code><code><code><code><code><code><code> /** * 请求权限失败 * * @param requestcode * @param perms */ @override public void onpermissionsdenied(int requestcode, list<string> perms) { toastutils.showtoast(getapplicationcontext(), "用户授权失败"); /** * 若是在权限弹窗中,用户勾选了'never ask again.'或者'不在提示',且拒绝权限。 * 这时候,需要跳转到设置界面去,让用户手动开启。 */ if (easypermissions.somepermissionpermanentlydenied(this, perms)) { new appsettingsdialog.builder(this).build().show(); } } @override protected void onactivityresult(int requestcode, int resultcode, intent data) { super.onactivityresult(requestcode, resultcode, data); switch (requestcode) { //当从软件设置界面,返回当前程序时候 case appsettingsdialog.default_settings_req_code: //执行toast显示或者其他逻辑处理操作 break; } }</string></code></code></code></code></code></code></code></code></code>
以上代码是,当无法弹出权限弹框,直接跳转到设置界面去,让用户手动开启权限。
当从设置界面返回时候,结果会在activity或者fragment中onactivityresult()响应。
运行效果,如下:
总结
以上所述是小编给大家介绍的android easypermissions官方库高效处理权限相关教程,希望对大家有所帮助
上一篇: 清水蕨菜的做法与窍门
推荐阅读
-
Android EasyPermissions官方库高效处理权限相关教程
-
Android EasyPermissions官方库高效处理权限相关教程
-
【Android 应用开发】Google 官方 EasyPermissions 权限申请库 ( 最简单用法 | 一行代码搞定权限申请 | 推荐用法 )
-
Android EasyPermissions官方库,高效处理权限相关教程
-
【Android 应用开发】Google 官方 EasyPermissions 权限申请库 ( 最简单用法 | 一行代码搞定权限申请 | 推荐用法 )
-
Android EasyPermissions官方库,高效处理权限相关教程