很简单没什么说的, 因为项目大了,不能轻易引入第三方库,同时确实也没必要为了适配下权限就引入一个库。

这里写了个处理权限的工具类(部分借鉴的,勿喷),不嫌弃的话拿去!

用法:

1.申请权限:

PermissionHelper mHelper = new PermissionHelper(this);

mHelper.requestPermissions("请授予xx[相机],[读写]权限!",

new PermissionHelper.PermissionListener() {

@Override

public void doAfterGrand(String... permission) {

}

@Override

public void doAfterDenied(String... permission) {

}

}, Manifest.permission.CAMERA, Manifest.permission.WRITE_EXTERNAL_STORAGE);

2.处理申请的结果:

//直接把参数交给mHelper就行了

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

mHelper.handleRequestPermissionsResult(requestCode, permissions, grantResults);

}

代码如下:

import android.annotation.TargetApi;

import android.app.Activity;

import android.app.Fragment;

import android.content.Context;

import android.content.DialogInterface;

import android.content.pm.PackageManager;

import android.os.Build;

import android.support.annotation.NonNull;

import android.support.annotation.Nullable;

import android.support.v4.app.ActivityCompat;

import android.support.v4.content.ContextCompat;

import android.support.v7.app.AlertDialog;

import net.chuangdie.mcxd.R;

import java.util.Arrays;

import java.util.List;

/**

* @author deadline

* @time 2016-10-28

* @usage android >=M 的权限申请统一处理

*

* notice:

* 很多手机对原生系统做了修改,比如小米4的6.0的shouldShowRequestPermissionRationale

* 就一直返回false,而且在申请权限时,如果用户选择了拒绝,则不会再弹出对话框了, 因此有了

* void doAfterDenied(String... permission);

*/

public class PermissionHelper {

private static final int REQUEST_PERMISSION_CODE = 1000;

private Object mContext;

private PermissionListener mListener;

private List mPermissionList;

public PermissionHelper(@NonNull Object object){

checkCallingObjectSuitability(object);

this.mContext = object;

}

/**

* 权限授权申请

* @param hintMessage

* 要申请的权限的提示

*

* @param permissions

* 要申请的权限

*

* @param listener

* 申请成功之后的callback

*/

public void requestPermissions(@NonNull CharSequence hintMessage,

@Nullable PermissionListener listener,

@NonNull final String... permissions){

if(listener != null){

mListener = listener;

}

mPermissionList = Arrays.asList(permissions);

//没全部权限

if (!hasPermissions(mContext, permissions)) {

//需要向用户解释为什么申请这个权限

boolean shouldShowRationale = false;

for (String perm : permissions) {

shouldShowRationale =

shouldShowRationale || shouldShowRequestPermissionRationale(mContext, perm);

}

if (shouldShowRationale) {

showMessageOKCancel(hintMessage, new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialog, int which) {

executePermissionsRequest(mContext, permissions,

REQUEST_PERMISSION_CODE);

}

});

}else {

executePermissionsRequest(mContext, permissions,

REQUEST_PERMISSION_CODE);

}

}else if(mListener != null) { //有全部权限

mListener.doAfterGrand(permissions);

}

}

/**

* 处理onRequestPermissionsResult

* @param requestCode

* @param permissions

* @param grantResults

*/

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

switch (requestCode) {

case REQUEST_PERMISSION_CODE:

boolean allGranted = true;

for (int grant: grantResults) {

if(grant != PackageManager.PERMISSION_GRANTED){

allGranted = false;

break;

}

}

if (allGranted && mListener != null) {

mListener.doAfterGrand((String[])mPermissionList.toArray());

}else if(!allGranted && mListener != null){

mListener.doAfterDenied((String[])mPermissionList.toArray());

}

break;

}

}

/**

* 判断是否具有某权限

* @param object

* @param perms

* @return

*/

public static boolean hasPermissions(@NonNull Object object, @NonNull String... perms) {

if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {

return true;

}

for (String perm : perms) {

boolean hasPerm = (ContextCompat.checkSelfPermission(getActivity(object), perm) ==

PackageManager.PERMISSION_GRANTED);

if (!hasPerm) {

return false;

}

}

return true;

}

/**

* 兼容fragment

* @param object

* @param perm

* @return

*/

@TargetApi(23)

private static boolean shouldShowRequestPermissionRationale(@NonNull Object object, @NonNull String perm) {

if (object instanceof Activity) {

return ActivityCompat.shouldShowRequestPermissionRationale((Activity) object, perm);

} else if (object instanceof Fragment) {

return ((Fragment) object).shouldShowRequestPermissionRationale(perm);

} else if (object instanceof android.app.Fragment) {

return ((android.app.Fragment) object).shouldShowRequestPermissionRationale(perm);

} else {

return false;

}

}

/**

* 执行申请,兼容fragment

* @param object

* @param perms

* @param requestCode

*/

@TargetApi(23)

private void executePermissionsRequest(@NonNull Object object, @NonNull String[] perms, int requestCode) {

if (object instanceof android.app.Activity) {

ActivityCompat.requestPermissions((Activity) object, perms, requestCode);

} else if (object instanceof android.support.v4.app.Fragment) {

((android.support.v4.app.Fragment) object).requestPermissions(perms, requestCode);

} else if (object instanceof android.app.Fragment) {

((android.app.Fragment) object).requestPermissions(perms, requestCode);

}

}

/**

* 检查传递Context是否合法

* @param object

*/

private void checkCallingObjectSuitability(@Nullable Object object) {

if (object == null) {

throw new NullPointerException("Activity or Fragment should not be null");

}

boolean isActivity = object instanceof android.app.Activity;

boolean isSupportFragment = object instanceof android.support.v4.app.Fragment;

boolean isAppFragment = object instanceof android.app.Fragment;

if (!(isSupportFragment || isActivity || (isAppFragment && isNeedRequest()))) {

if (isAppFragment) {

throw new IllegalArgumentException(

"Target SDK needs to be greater than 23 if caller is android.app.Fragment");

} else {

throw new IllegalArgumentException("Caller must be an Activity or a Fragment.");

}

}

}

@TargetApi(11)

private static Activity getActivity(@NonNull Object object) {

if (object instanceof Activity) {

return ((Activity) object);

} else if (object instanceof android.support.v4.app.Fragment) {

return ((android.support.v4.app.Fragment) object).getActivity();

} else if (object instanceof android.app.Fragment) {

return ((android.app.Fragment) object).getActivity();

} else {

return null;

}

}

public static boolean isNeedRequest(){

return Build.VERSION.SDK_INT >= Build.VERSION_CODES.M;

}

public void showMessageOKCancel(CharSequence message, DialogInterface.OnClickListener okListener) {

new AlertDialog.Builder(getActivity(mContext))

.setMessage(message)

.setPositiveButton(R.string.confirm, okListener)

.setNegativeButton(R.string.cancel, null)

.create()

.show();

}

public interface PermissionListener {

void doAfterGrand(String... permission);

void doAfterDenied(String... permission);

}

}

android m权限工具类,android M权限适配,简单工具类相关推荐

  1. java 数据对_数据表与简单java类(一对多)

    emp表:empno,ename,job,sal,comm,mgr,deptno dept表:deptno,dname,loc 要求可以通过程序描述出如下对应关系 一个部门有多个部员,并且可以输出一个 ...

  2. [ 转载 ] Java基础10--关于Object类下所有方法的简单解析

    关于Object类下所有方法的简单解析 类Object是类层次结构的根类,是每一个类的父类,所有的对象包括数组,String,Integer等包装类,所以了解Object是很有必要的,话不多说,我们直 ...

  3. android 动态录音权限,Android如何判断手机是否有录音权限的工具类

    作用 判断手机是否有录音权限的工具类,兼容6.0以上以及以下android系统 测试环境 这篇文章是评论中的网友提出质疑后,经过重写修改与重写测试后编写的,我的调试环境是小米note3,Android ...

  4. Android PermissionUtils:运行时权限工具类及申请权限的正确姿势

    Android PermissionUtils:运行时权限工具类及申请权限的正确姿势 ifadai 关注 2017.06.16 16:22* 字数 318 阅读 3637评论 1喜欢 6 Permis ...

  5. 【Android 逆向】Android 进程注入工具开发 ( 远程进程 注入动态库 文件操作 | Android 进程读取文件所需的权限 | fopen 打开文件标志位 | 验证文件权限 )

    文章目录 前言 一.Android 进程读取文件所需的权限 二.fopen 打开文件标志位 三.验证文件权限 前言 一.Android 进程读取文件所需的权限 通过 注入工具 , 将 libbridg ...

  6. Android运行时权限,设置帮助类BaseActivity;电话权限,短信权限,

                                      Android运行时权限设置帮助类BaseActivity  一.电话权限 package com.glandroid.smssen ...

  7. Android 7.0之访问文件的权限和FileProvider类

    转载请标明出处: http://blog.csdn.net/djy1992/article/details/72533310 本文出自:[奥特曼超人的博客] 权限更改 Android 7.0 做了一些 ...

  8. 联想 android 5.1 root权限,联想A520手机ROOT权限图文教程(附联想A520root工具)

    联想A520 ROOT教程: 2.将手机USB调试打开; 步骤:设置----应用程序----开发-----USB调试 设置----应用程序----未知源,后面的勾打上就行; 3.打开了USB调试和未知 ...

  9. android 动态获取权限有哪些,Android 6.0+ 动态获取权限

    Android 6.0+ 动态获取权限 这里有一个现成的库,可以直接拿来用.方便简单 1.向app下的gradle添加依赖: dependencies{ // android 6.0+ 动态获取权限 ...

最新文章

  1. python26.dll没有发现_python26.dll 文件下载
  2. 作业三--简单四则运算
  3. Vi编辑器的使用方法
  4. 我的世界大佬最多的服务器,《我的世界》门槛最高的红石服务器TIS,看看你跟大佬们的差距吧...
  5. 自然数 素数 质数_在Java中获取素数的无限列表
  6. In和exists使用及性能分析(一):in的使用
  7. python--文件
  8. linux下图片加密原理,Linux中常见的加密技术介绍
  9. sqlite 无符号32_《符号与传媒》2020年总目录
  10. $.ajax 简单记录
  11. MySQL常用命令操作大全
  12. 安卓IOS 手机添加O365 邮箱账户
  13. html css字体最小,html-字体大小CSS问题
  14. 图片,表格末尾紧贴上方图片或表格添加脚注/备注
  15. FRP内网穿透访问家中的NAS和路由器后台
  16. SPLAYER中文字幕乱码
  17. 脉冲响应与频率响应的关系
  18. 论文阅读_基于GCN的知识图对齐
  19. 什么是套利型创业者?
  20. python 求1000以内的完数

热门文章

  1. 有一个包含主函数的java类_重新认识Java中的程序入口即主函数各组成部分
  2. 最短路dijkstra算法详解_最短路径问题---Dijkstra算法详解
  3. solr 查询字段唯一值_《Solr实战》之一
  4. 电机驱动TB6612FNG全网断货,可替代方案来了,文末送模块!
  5. 聊了一个小时,一名电子专业研究生的困惑
  6. 用android做体质计算器,Android入门项目(一):BMI体质指数计算器
  7. mysql btree检索策略_MySQL之Btree索引和HASH索引的区别以及索引优化策略
  8. Network下方什么请求也没有_HTTP的响应与请求
  9. 麒麟linux创建用户组,麒麟Linux系统用户和组管理指南(21页)-原创力文档
  10. chinaren校友录恢复重新开放_确定!九寨沟景区9月27日对外开放(试运行) 最大限量为每天5000人 各大旅企产品已上线...