使用EasyPermissions高效处理权限

首语
  • Android现在将所有的权限归为了两类,一类是普通权限,一类是危险权限。对于普通权限,系统会自动帮我们进行授权,不需要手动操作。对于危险权限,必须要由用户手动进行点击授权才可以,否则程序无法完成相应的功能。
  • Android 6.0系统中加入了运行时权限功能,在使用过程中再对危险权限进行授权。罗列Android中所有的危险权限,一共是9组24个权限,如图:
    在这里插入图片描述
Android申请权限
  • 首先必须在AndroidManifest文件中添加对应权限。
if(ContextCompat.checkSelfPermission(this,Manifest.permission.CAMERA)!=PackageManager.PERMISSION_GRANTED){
        ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.CAMERA},10001);
    }else {
        //权限申请成功,做相应功能
    }
}

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    switch (requestCode){
        case 10001:
            if (grantResults.length>0&&grantResults[0]==PackageManager.PERMISSION_GRANTED){
                //做相应功能
            }else {
                Toast.makeText(this, "权限申请成功!", Toast.LENGTH_SHORT).show();
            }
            break;
    }
}

第三方库EasyPermissions

  • EasyPermissions库是一个方便开发者为App高效处理危险权限的库,可用于在Android M或者更高版本上。
GitHub地址:https://github.com/googlesamples/easypermissions
依赖:implementation 'pub.devrel:easypermissions:2.0.1
使用步骤
1.申请权限
String PERMISSION_STORAGE_MSG = "请授予权限,否则影响部分使用功能";
int PERMISSION_STORAGE_CODE = 10001;
String[] PERMS = {Manifest.permission.CAMERA, Manifest.permission.ACCESS_FINE_LOCATION};
if (EasyPermissions.hasPermissions(this, PERMS)) {
    // 已经申请过权限,做想做的事

} else {
    // 没有申请过权限,现在去申请
    /**
     *@param host Context对象
     *@param rationale  权限弹窗上的提示语。
     *@param requestCode 请求权限的唯一标识码
     *@param perms 一系列权限
     */
    EasyPermissions.requestPermissions(this, PERMISSION_STORAGE_MSG, PERMISSION_STORAGE_CODE, PERMS);
}
2.重写Activity或Fragment的onRequestPermissionsResult方法
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    //将结果转发给EasyPermissions
    EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
}
3.实现EasyPermissions.PermissionCallbacks接口,重写两个方法
public class MainActivity extends AppCompatActivity implements EasyPermissions.PermissionCallbacks {
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
    
    /**
     * 申请成功时调用
     * @param requestCode 请求权限的唯一标识码
     * @param perms 一系列权限
     */
    @Override
    public void onPermissionsGranted(int requestCode,List<String> perms) {

    }

    /**
     * 申请拒绝时调用
     * @param requestCode 请求权限的唯一标识码
     * @param perms 一系列权限
     */
    @Override
    public void onPermissionsDenied(int requestCode,List<String> perms) {

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

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

@AfterPermissionGranted(10001)
public void onPermissionSuccess(){
    Toast.makeText(this,"AfterPermission调用成功了",Toast.LENGTH_SHORT).show();
}
5.使用EasyPermissions处理权限被拒
@Override
public void onPermissionsDenied(int requestCode, List<String> perms) {
    /**
     * 若是在权限弹窗中,用户勾选了'不在提示',且拒绝权限。
     * 这时候,需要跳转到设置界面去,让用户手动开启。
     */
    if (EasyPermissions.somePermissionPermanentlyDenied(this, perms)) {
        new AppSettingsDialog.Builder(this).build().show();
    }
}

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if (requestCode == AppSettingsDialog.DEFAULT_SETTINGS_REQ_CODE) {
	    //从设置页面返回,判断权限是否申请。
        if (EasyPermissions.hasPermissions(this, PERMS)) {
            Toast.makeText(this, "权限申请成功!", Toast.LENGTH_SHORT).show();
        } else {
            Toast.makeText(this, "权限申请失败!", Toast.LENGTH_SHORT).show();

        }
    }
}
总结
  • 使用EasyPermissions能更好高效的处理权限,让开发者在平常开发过程中提升开发效率。
  • 5
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

八归少年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值