Android 动态申请权限__2020.06.18

    private String[] permissionList = new String[]{   //申请的权限列表
            Manifest.permission.READ_CONTACTS,//读取联系人列表的权限
            Manifest.permission.WRITE_CONTACTS,//写联系人列表的权限
            Manifest.permission.READ_CALL_LOG,//读取通话记录的权限
            Manifest.permission.WRITE_CALL_LOG,//写入通话记录的权限
            Manifest.permission.READ_EXTERNAL_STORAGE,
            Manifest.permission.WRITE_EXTERNAL_STORAGE,
            Manifest.permission.READ_PHONE_STATE
    };

    private List<String> unPermissionList = new ArrayList<>();  //申请未得到的权限列表
    private AlertDialog mPermissionDialog;
    checkPermission();//检查应用权限


    //判断权限和申请
    private void checkPermission() {
        unPermissionList.clear();//清空申请未获得权限的权限列表
        //逐个判断是否还有未通过的权限
        for (int i = 0; i < permissionList.length; ++i) {
            if (ContextCompat.checkSelfPermission(getActivity(), permissionList[i]) != PackageManager.PERMISSION_GRANTED) {
                unPermissionList.add(permissionList[i]);//添加到未授予权限的列表中
            }
        }
        //有权限没有通过,需要申请
        if (unPermissionList.size() > 0) {
            ActivityCompat.requestPermissions(getActivity(), permissionList, 100);
            Log.i("DialActivity", "check 有权限未通过");
        } else {
            //权限都通过了,可以将程序继续打开了
            Log.i("DialActivity", "check 权限都已经申请通过");
        }
    }

    /**
     * 5.请求权限后回调的方法
     *
     * @param requestCode  是我们自己定义的权限请求码
     * @param permissions  是我们请求的权限名称数组
     * @param grantResults 是我们在弹出页面后是否允许权限的标识数组,数组的长度对应的是权限
     *                     名称数组的长度,数组的数据0表示允许权限,-1表示我们点击了禁止权限
     */
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        //super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        Log.i("DialActivity", "权限申请结果反馈");
        boolean hasPermissionDismiss = false;//有未授予的权限
        if (100 == requestCode) {
            for (int i = 0; i < grantResults.length; i++) {
                if (grantResults[i] == -1) {
                    hasPermissionDismiss = true;//有权限没有通过
                }
            }
        }
        if (hasPermissionDismiss) {//如果有没有被允许的权限
            showPermissionDialog();
        } else {
            //权限申请都已通过,可以将程序继续打开了
            Log.i("DialActivity", "onRequestPermissionResult 权限申请都已经通过了");
        }
    }

    private void showPermissionDialog() {
        if (mPermissionDialog == null) {
            mPermissionDialog = new AlertDialog.Builder(getActivity())
                    .setMessage("已禁用权限,请手动授予")
                    .setPositiveButton("设置", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            //没有授权,编写申请权限代码
                            ActivityCompat.requestPermissions(getActivity(), new String[]{Manifest.permission.READ_CONTACTS}, 100);
                            ActivityCompat.requestPermissions(getActivity(), new String[]{Manifest.permission.WRITE_CONTACTS}, 100);
                            mPermissionDialog.cancel();
                        }
                    })
                    .setNegativeButton("取消", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            mPermissionDialog.cancel();
                        }
                    })
                    .create();
        }
        mPermissionDialog.show();
    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值