android 6.0权限封装,Android 6.0 运行时权限简洁封装

Android 6.0 运行时权限简洁封装

本文原创,转载请注明出处。

欢迎关注我的 简书 ,关注我的专题 Android Class 我会长期坚持为大家收录简书上高质量的 Android 相关博文。

写在前面:

Android M 中有一个比较重要的知识点就是运行时权限了,关于运行时权限的文章和封装库目前也出现了不少,在开发的过程中始终觉得运行时权限这块的代码可以进一步封装一下,让其使用起来能再简洁一点,并且还不容易出错。关于 Android 运行时权限的知识就不多讲解了,可以参考下面的一些资料:

知识点比较简单,大致了解和使用过后,就来开始我的这次封装之旅吧。

现在直观的看看封装之后的使用,是不是清爽很多?

@OnClick(R.id.tv_toolbar_right)

public void onClick() {

performRequestPermissions(getString(R.string.permission_desc), new String[]{Manifest.permission.READ_PHONE_STATE, Manifest.permission.ACCESS_COARSE_LOCATION}

, PER_REQUEST_CODE, new PermissionsResultListener() {

@Override

public void onPermissionGranted() {

Toast.makeText(MainActivity.this, "已申请权限", Toast.LENGTH_LONG).show();

}

@Override

public void onPermissionDenied() {

Toast.makeText(MainActivity.this, "拒绝申请权限", Toast.LENGTH_LONG).show();

}

});

}

我将运行时权限封装到 BaseActivity 中,MainActivty 继承BaseActivity,调用 performRequestPermissions 方法,此时我不用再去做一些判断,只需要穿入四个参数即可。当然你为了在 6.0 以下保证应用正常运行,你依然需要像以前一样,在清单文件中申明要使用的权限。

首先我需要一个接口做通信:

public interface PermissionsResultListener {

void onPermissionGranted();

void onPermissionDenied();

}

然后把逻辑代码封装在 BaseActivity 里面:

public class BaseActivity extends AppCompatActivity {

private PermissionsResultListener mListener;

private int mRequestCode;

/**

* 其他 Activity 继承 BaseActivity 调用 performRequestPermissions 方法

*

* @param desc 首次申请权限被拒绝后再次申请给用户的描述提示

* @param permissions 要申请的权限数组

* @param requestCode 申请标记值

* @param listener 实现的接口

*/

protected void performRequestPermissions(String desc, String[] permissions, int requestCode, PermissionsResultListener listener) {

if (permissions == null || permissions.length == 0) {

return;

}

mRequestCode = requestCode;

mListener = listener;

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {

if (checkEachSelfPermission(permissions)) {// 检查是否声明了权限

requestEachPermissions(desc, permissions, requestCode);

} else {// 已经申请权限

if (mListener != null) {

mListener.onPermissionGranted();

}

}

} else {

if (mListener != null) {

mListener.onPermissionGranted();

}

}

}

/**

* 申请权限前判断是否需要声明

*

* @param desc

* @param permissions

* @param requestCode

*/

private void requestEachPermissions(String desc, String[] permissions, int requestCode) {

if (shouldShowRequestPermissionRationale(permissions)) {// 需要再次声明

showRationaleDialog(desc, permissions, requestCode);

} else {

ActivityCompat.requestPermissions(BaseActivity.this, permissions, requestCode);

}

}

/**

* 弹出声明的 Dialog

*

* @param desc

* @param permissions

* @param requestCode

*/

private void showRationaleDialog(String desc, final String[] permissions, final int requestCode) {

final AlertDialog.Builder builder = new AlertDialog.Builder(this);

builder.setTitle(getString(R.string.tips))

.setMessage(desc)

.setPositiveButton(getResources().getString(R.string.confrim), new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialogInterface, int i) {

ActivityCompat.requestPermissions(BaseActivity.this, permissions, requestCode);

}

})

.setNegativeButton(getResources().getString(R.string.cancle), new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialogInterface, int i) {

dialogInterface.dismiss();

}

})

.setCancelable(false)

.show();

}

/**

* 再次申请权限时,是否需要声明

*

* @param permissions

* @return

*/

private boolean shouldShowRequestPermissionRationale(String[] permissions) {

for (String permission : permissions) {

if (ActivityCompat.shouldShowRequestPermissionRationale(this, permission)) {

return true;

}

}

return false;

}

/**

* 检察每个权限是否申请

*

* @param permissions

* @return true 需要申请权限,false 已申请权限

*/

private boolean checkEachSelfPermission(String[] permissions) {

for (String permission : permissions) {

if (ContextCompat.checkSelfPermission(this, permission) != PackageManager.PERMISSION_GRANTED) {

return true;

}

}

return false;

}

/**

* 申请权限结果的回调

*

* @param requestCode

* @param permissions

* @param grantResults

*/

@Override

public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {

super.onRequestPermissionsResult(requestCode, permissions, grantResults);

if (requestCode == mRequestCode) {

if (checkEachPermissionsGranted(grantResults)) {

if (mListener != null) {

mListener.onPermissionGranted();

}

} else {// 用户拒绝申请权限

if (mListener != null) {

mListener.onPermissionDenied();

}

}

}

}

/**

* 检查回调结果

*

* @param grantResults

* @return

*/

private boolean checkEachPermissionsGranted(int[] grantResults) {

for (int result : grantResults) {

if (result != PackageManager.PERMISSION_GRANTED) {

return false;

}

}

return true;

}

}

每一个方法都有注释,逻辑也相对简单,就是我会遍历每个数组中申请的权限,如果需要申请就去申请,然后再处理一下回调的结果,其中还有对用户拒绝,然后再次申请弹出 Dialog 的处理。

如果在 Fragment 中使用,只是改变了一下参数封到 BaseFragment 中,这里就不贴代码了,都已经上传 github

BaseActivity:

BaseFragment:

如有问题,继续交流~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值