Android EasyPermissions官方库高效处理权限相关教程

Android EasyPermissions官方库高效处理权限相关教程,第1张

概述介绍:easypermission库是一个简化基本的系统权限逻辑的库,可用于在AndroidM或者更高版本上。

介绍:

easypermission库是一个简化基本的系统权限逻辑的库,可用于在AndroID M或者更高版本上。

1 相关文档

官方文档:

https://github.com/googlesamples/easypermissions

运行时权限官方文档解释:

https://developer.android.com/training/permissions/requesting.html

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对象 第二个参数:权限d窗上的文字提示语。告诉用户,这个权限用途。 第三个参数:这次请求权限的唯一标示,code。 第四个参数 : 一些系列的权限。

3. EasyPermissions响应请求结果:

请求后,d出系统权限d窗,剩下是用户是否授权 *** 作。权限结果是回调在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,grantResults,this); } /**  * 请求权限成功。  * 可以d窗显示结果,也可执行具体需要的逻辑 *** 作  *  * @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,"用户授权失败");  /**   * 若是在权限d窗中,用户勾选了'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():

用户授权失败,处理失败的逻辑。

注意:若是在权限d窗中,用户勾选了'NEVER ASK AGAIN.'或者'不在提示',且拒绝权限。 这时候,需要跳转到设置界面去,让用户手动开启。

你可能并不满足,需要手动调用逻辑处理方法。EasyPermissions库为你考虑好了,具备强大之处。当用户同意权限后,可以不需要通过监听器方式来实现,直接调用相关的逻辑代码的方法。只需要使用@AfterPermissionGranted注解标注逻辑处理的方法。

4. @AfterPermissionGranted注解:

@AfterPermissionGranted注解为了提供方便,但可以添加也可以不添加,是可选的。

好处:

使用了该注解,当权限请求被用户同意后,会根据请求code来执行,相应的含有@AfterPermissionGranted注解的方法。

简化了请求成功 *** 作流程,不需要在EasyPermissions.onRequestPermissionsResult()的回调监听器中请求成功的方法中,再次手动调用,获取权限后需要 *** 作的逻辑代码。

以下代码,请求写入磁盘的权限,当用户同意权限后,d出一个Toastd窗的逻辑处理 *** 作。

<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处理权限被拒的情况:

在权限d窗中,用户可能直接拒绝权限,下次权限请求依旧会d出该权限d窗。除此之外,还可以勾选'NEVER ASK AGAIN.'或者'不在提示',且拒绝权限,下次请求权限,d窗不能d出,无法让用户授权。这时候,需要跳转到设置界面去,让用户手动开启。

在EasyPermission库中,使用EasyPermissions.somePermissionPermanentlyDenIEd()来处理,是否勾选不再提示的选项。

<code><code><code><code><code><code><code><code><code> /**  * 请求权限失败  *  * @param requestCode  * @param perms  */ @OverrIDe public voID onPermissionsDenIEd(int requestCode,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>

以上代码是,当无法d出权限d框,直接跳转到设置界面去,让用户手动开启权限。

当从设置界面返回时候,结果会在Activity或者Fragment中onActivityResult()响应。

运行效果,如下:

总结

以上所述是小编给大家介绍的AndroID EasyPermissions官方库高效处理权限相关教程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!

总结

以上是内存溢出为你收集整理的Android EasyPermissions官方库高效处理权限相关教程全部内容,希望文章能够帮你解决Android EasyPermissions官方库高效处理权限相关教程所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/web/1143807.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-31
下一篇2022-05-31

发表评论

登录后才能评论

评论列表(0条)

    保存