android m权限工具类,android M权限适配,简单工具类
很简单没什么说的, 因为项目大了,不能轻易引入第三方库,同时确实也没必要为了适配下权限就引入一个库。
这里写了个处理权限的工具类(部分借鉴的,勿喷),不嫌弃的话拿去!
用法:
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权限适配,简单工具类相关推荐
- java 数据对_数据表与简单java类(一对多)
emp表:empno,ename,job,sal,comm,mgr,deptno dept表:deptno,dname,loc 要求可以通过程序描述出如下对应关系 一个部门有多个部员,并且可以输出一个 ...
- [ 转载 ] Java基础10--关于Object类下所有方法的简单解析
关于Object类下所有方法的简单解析 类Object是类层次结构的根类,是每一个类的父类,所有的对象包括数组,String,Integer等包装类,所以了解Object是很有必要的,话不多说,我们直 ...
- android 动态录音权限,Android如何判断手机是否有录音权限的工具类
作用 判断手机是否有录音权限的工具类,兼容6.0以上以及以下android系统 测试环境 这篇文章是评论中的网友提出质疑后,经过重写修改与重写测试后编写的,我的调试环境是小米note3,Android ...
- Android PermissionUtils:运行时权限工具类及申请权限的正确姿势
Android PermissionUtils:运行时权限工具类及申请权限的正确姿势 ifadai 关注 2017.06.16 16:22* 字数 318 阅读 3637评论 1喜欢 6 Permis ...
- 【Android 逆向】Android 进程注入工具开发 ( 远程进程 注入动态库 文件操作 | Android 进程读取文件所需的权限 | fopen 打开文件标志位 | 验证文件权限 )
文章目录 前言 一.Android 进程读取文件所需的权限 二.fopen 打开文件标志位 三.验证文件权限 前言 一.Android 进程读取文件所需的权限 通过 注入工具 , 将 libbridg ...
- Android运行时权限,设置帮助类BaseActivity;电话权限,短信权限,
Android运行时权限设置帮助类BaseActivity 一.电话权限 package com.glandroid.smssen ...
- Android 7.0之访问文件的权限和FileProvider类
转载请标明出处: http://blog.csdn.net/djy1992/article/details/72533310 本文出自:[奥特曼超人的博客] 权限更改 Android 7.0 做了一些 ...
- 联想 android 5.1 root权限,联想A520手机ROOT权限图文教程(附联想A520root工具)
联想A520 ROOT教程: 2.将手机USB调试打开; 步骤:设置----应用程序----开发-----USB调试 设置----应用程序----未知源,后面的勾打上就行; 3.打开了USB调试和未知 ...
- android 动态获取权限有哪些,Android 6.0+ 动态获取权限
Android 6.0+ 动态获取权限 这里有一个现成的库,可以直接拿来用.方便简单 1.向app下的gradle添加依赖: dependencies{ // android 6.0+ 动态获取权限 ...
最新文章
- python26.dll没有发现_python26.dll 文件下载
- 作业三--简单四则运算
- Vi编辑器的使用方法
- 我的世界大佬最多的服务器,《我的世界》门槛最高的红石服务器TIS,看看你跟大佬们的差距吧...
- 自然数 素数 质数_在Java中获取素数的无限列表
- In和exists使用及性能分析(一):in的使用
- python--文件
- linux下图片加密原理,Linux中常见的加密技术介绍
- sqlite 无符号32_《符号与传媒》2020年总目录
- $.ajax 简单记录
- MySQL常用命令操作大全
- 安卓IOS 手机添加O365 邮箱账户
- html css字体最小,html-字体大小CSS问题
- 图片,表格末尾紧贴上方图片或表格添加脚注/备注
- FRP内网穿透访问家中的NAS和路由器后台
- SPLAYER中文字幕乱码
- 脉冲响应与频率响应的关系
- 论文阅读_基于GCN的知识图对齐
- 什么是套利型创业者?
- python 求1000以内的完数
热门文章
- 有一个包含主函数的java类_重新认识Java中的程序入口即主函数各组成部分
- 最短路dijkstra算法详解_最短路径问题---Dijkstra算法详解
- solr 查询字段唯一值_《Solr实战》之一
- 电机驱动TB6612FNG全网断货,可替代方案来了,文末送模块!
- 聊了一个小时,一名电子专业研究生的困惑
- 用android做体质计算器,Android入门项目(一):BMI体质指数计算器
- mysql btree检索策略_MySQL之Btree索引和HASH索引的区别以及索引优化策略
- Network下方什么请求也没有_HTTP的响应与请求
- 麒麟linux创建用户组,麒麟Linux系统用户和组管理指南(21页)-原创力文档
- chinaren校友录恢复重新开放_确定!九寨沟景区9月27日对外开放(试运行) 最大限量为每天5000人 各大旅企产品已上线...