EasyPermission库是一个谷歌官方提供的简化基本的系统权限逻辑的库,可用于在Android M或者更高版本上。git
官方项目地址:https://github.com/googlesamples/easypermissionsgithub
在须要使用此库的module的build.gradle中添加如下代码:app
dependencies {
// For developers using AndroidX in their applications implementation 'pub.devrel:easypermissions:3.0.0' // For developers using the Android Support Library implementation 'pub.devrel:easypermissions:2.0.1' }
权限能够是单个,也能够是一些列。在EasyPermission库中,使用EasyPermissions#hasPermissions(...)检查若干权限。ide
/** * * @param context * return true:已经获取权限 * return false: 未获取权限,主动请求权限 */ public static boolean checkPermission(Activity context,String[] perms) { return EasyPermissions.hasPermissions(context, perms); }
EasyPermissions.hasPermissions():gradle
第一个参数 : Context参数.例如,Activity对象。ui
第二个参数 : 一些系列的权限。例如,public final static String[] PERMS_WRITE ={Manifest.permission.WRITE_EXTERNAL_STORAGE};this
检查后,发觉用户没有赋予权限,这时候须要代码请求权限,让用户赞成。google
在EasyPermission库中,使用EasyPermissions#requestPermissions,来请求权限。spa
/** * 请求权限 * @param context */ public static void requestPermission(Activity context,String tip,int requestCode,String[] perms) { EasyPermissions.requestPermissions(context, tip,requestCode,perms); }
EasyPermissions.requestPermissions():code
第一个参数:Context对象
第二个参数:权限弹窗上的文字提示语。告诉用户,这个权限用途。
第三个参数:此次请求权限的惟一标示,code。
第四个参数 : 一些系列的权限。
请求后,弹出系统权限弹窗,剩下是用户是否受权操做。权限结果是回调在Activity或者Fragment中的重写的onRequestPermissionsResult()方法中。
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(); } } }
将权限结果传递给EasyPermissions.onRequestPermissionsResult()来处理。
EasyPermissions.onRequestPermissionsResult()方法:
第一个参数: 请求的code
第二个参数: 一些列的请求权限
第三个参数: 用户受权的结果
第四个参数: 权限回调监听器
这里不须要手写判断权限是否成功的逻辑操做,而会在EasyPermissions.PermissionCallbacks监听器中响应。
EasyPermissions.PermissionCallbacks接口:
注意:如果在权限弹窗中,用户勾选了’NEVER ASK AGAIN.’或者’不在提示’,且拒绝权限。 这时候,须要跳转到设置界面去,让用户手动开启。
你可能并不知足,须要手动调用逻辑处理方法。EasyPermissions库为你考虑好了,具有强大之处。当用户赞成权限后,能够不须要经过监听器方式来实现,直接调用相关的逻辑代码的方法。只须要使用@AfterPermissionGranted注解标注逻辑处理的方法。
@AfterPermissionGranted注解为了提供方便,但能够添加也能够不添加,是可选的。
好处:
使用了该注解,当权限请求被用户赞成后,会根据请求code来执行,相应的含有@AfterPermissionGranted注解的方法。
简化了请求成功操做流程,不须要在EasyPermissions.onRequestPermissionsResult()的回调监听器中请求成功的方法中,再次手动调用,获取权限后须要操做的逻辑代码。
如下代码,请求写入磁盘的权限,当用户赞成权限后,弹出一个Toast弹窗的逻辑处理操做。
@AfterPermissionGranted(Constance.WRITE_PERMISSION_CODE) // 可选的 public void onPermissionsSuccess() { ToastUtils.showToast(getApplicationContext(), "用户受权成功"); }
当用户赞成权限,该方法不须要手动调用,会匹配到的Constance.WRITE_PERMISSION_CODE请求码,自动执行。
在权限弹窗中,用户可能直接拒绝权限,下次权限请求依旧会弹出该权限弹窗。除此以外,还能够勾选’NEVER ASK AGAIN.’或者’不在提示’,且拒绝权限,下次请求权限,弹窗不能弹出,没法让用户受权。这时候,须要跳转到设置界面去,让用户手动开启。
在EasyPermission库中,使用EasyPermissions.somePermissionPermanentlyDenied()来处理,是否勾选再也不提示的选项。
/** * 请求权限失败 * * @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; } }
以上代码是,当没法弹出权限弹框,直接跳转到设置界面去,让用户手动开启权限。
当从设置界面返回时候,结果会在Activity或者Fragment中onActivityResult()响应。