先看下动态权限的工具类:

package com.xiayiye.yhsh.permissionsdemo;import android.Manifest;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.net.Uri;
import android.os.Build;
import android.provider.Settings;
import android.support.v4.app.ActivityCompat;
import android.util.Log;
import android.widget.Toast;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;/*** @author :下一页5(轻飞扬)*         创建时间:2018/5/22.20:23*/
public class PermissionUtils {private static final String TAG = PermissionUtils.class.getSimpleName();public static final int CODE_RECORD_AUDIO = 0;public static final int CODE_GET_ACCOUNTS = 1;public static final int CODE_READ_PHONE_STATE = 2;public static final int CODE_CALL_PHONE = 3;public static final int CODE_CAMERA = 4;public static final int CODE_ACCESS_FINE_LOCATION = 5;public static final int CODE_ACCESS_COARSE_LOCATION = 6;public static final int CODE_READ_EXTERNAL_STORAGE = 7;public static final int CODE_WRITE_EXTERNAL_STORAGE = 8;public static final int CODE_MULTI_PERMISSION = 100;public static final String PERMISSION_RECORD_AUDIO = Manifest.permission.RECORD_AUDIO;public static final String PERMISSION_GET_ACCOUNTS = Manifest.permission.GET_ACCOUNTS;public static final String PERMISSION_READ_PHONE_STATE = Manifest.permission.READ_PHONE_STATE;public static final String PERMISSION_CALL_PHONE = Manifest.permission.CALL_PHONE;public static final String PERMISSION_CAMERA = Manifest.permission.CAMERA;public static final String PERMISSION_ACCESS_FINE_LOCATION = Manifest.permission.ACCESS_FINE_LOCATION;public static final String PERMISSION_ACCESS_COARSE_LOCATION = Manifest.permission.ACCESS_COARSE_LOCATION;public static final String PERMISSION_READ_EXTERNAL_STORAGE = Manifest.permission.READ_EXTERNAL_STORAGE;public static final String PERMISSION_WRITE_EXTERNAL_STORAGE = Manifest.permission.WRITE_EXTERNAL_STORAGE;private static final String[] requestPermissions = {PERMISSION_RECORD_AUDIO,PERMISSION_GET_ACCOUNTS,PERMISSION_READ_PHONE_STATE,PERMISSION_CALL_PHONE,PERMISSION_CAMERA,PERMISSION_ACCESS_FINE_LOCATION,PERMISSION_ACCESS_COARSE_LOCATION,PERMISSION_READ_EXTERNAL_STORAGE,PERMISSION_WRITE_EXTERNAL_STORAGE};interface PermissionGrant {void onPermissionGranted(int requestCode);}/*** Requests permission.** @param activity* @param requestCode request code, e.g. if you need request CAMERA permission,parameters is PermissionUtils.CODE_CAMERA*/public static void requestPermission(final Activity activity, final int requestCode, PermissionGrant permissionGrant) {if (activity == null) {return;}Log.i(TAG, "requestPermission requestCode:" + requestCode);if (requestCode < 0 || requestCode >= requestPermissions.length) {Log.w(TAG, "requestPermission illegal requestCode:" + requestCode);return;}final String requestPermission = requestPermissions[requestCode];//如果是6.0以下的手机,ActivityCompat.checkSelfPermission()会始终等于PERMISSION_GRANTED,// 但是,如果用户关闭了你申请的权限,ActivityCompat.checkSelfPermission(),会导致程序崩溃(java.lang.RuntimeException: Unknown exception code: 1 msg null),// 你可以使用try{}catch(){},处理异常,也可以在这个地方,低于23就什么都不做,// 个人建议try{}catch(){}单独处理,提示用户开启权限。if (Build.VERSION.SDK_INT < 23) {return;}int checkSelfPermission;try {checkSelfPermission = ActivityCompat.checkSelfPermission(activity, requestPermission);} catch (RuntimeException e) {Toast.makeText(activity, "please open this permission", Toast.LENGTH_SHORT).show();Log.e(TAG, "RuntimeException:" + e.getMessage());return;}if (checkSelfPermission != PackageManager.PERMISSION_GRANTED) {Log.i(TAG, "ActivityCompat.checkSelfPermission != PackageManager.PERMISSION_GRANTED");if (ActivityCompat.shouldShowRequestPermissionRationale(activity, requestPermission)) {Log.i(TAG, "requestPermission shouldShowRequestPermissionRationale");shouldShowRationale(activity, requestCode, requestPermission);} else {Log.d(TAG, "requestCameraPermission else");ActivityCompat.requestPermissions(activity, new String[]{requestPermission}, requestCode);}} else {Log.d(TAG, "ActivityCompat.checkSelfPermission ==== PackageManager.PERMISSION_GRANTED");Toast.makeText(activity, "opened:" + requestPermissions[requestCode], Toast.LENGTH_SHORT).show();permissionGrant.onPermissionGranted(requestCode);}}private static void requestMultiResult(Activity activity, String[] permissions, int[] grantResults, PermissionGrant permissionGrant) {if (activity == null) {return;}//TODOLog.d(TAG, "onRequestPermissionsResult permissions length:" + permissions.length);Map<String, Integer> perms = new HashMap<>();ArrayList<String> notGranted = new ArrayList<>();for (int i = 0; i < permissions.length; i++) {Log.d(TAG, "permissions: [i]:" + i + ", permissions[i]" + permissions[i] + ",grantResults[i]:" + grantResults[i]);perms.put(permissions[i], grantResults[i]);if (grantResults[i] != PackageManager.PERMISSION_GRANTED) {notGranted.add(permissions[i]);}}if (notGranted.size() == 0) {Toast.makeText(activity, "all permission success" + notGranted, Toast.LENGTH_SHORT).show();permissionGrant.onPermissionGranted(CODE_MULTI_PERMISSION);} else {openSettingActivity(activity, "those permission need granted!");}}/*** 一次申请多个权限*/public static void requestMultiPermissions(final Activity activity, PermissionGrant grant) {final List<String> permissionsList = getNoGrantedPermission(activity, false);final List<String> shouldRationalePermissionsList = getNoGrantedPermission(activity, true);//TODO checkSelfPermissionif (permissionsList == null || shouldRationalePermissionsList == null) {return;}Log.d(TAG, "requestMultiPermissions permissionsList:" + permissionsList.size() + ",shouldRationalePermissionsList:" + shouldRationalePermissionsList.size());if (permissionsList.size() > 0) {ActivityCompat.requestPermissions(activity, permissionsList.toArray(new String[permissionsList.size()]),CODE_MULTI_PERMISSION);Log.d(TAG, "showMessageOKCancel requestPermissions");} else if (shouldRationalePermissionsList.size() > 0) {showMessageOKCancel(activity, "should open those permission",new DialogInterface.OnClickListener() {@Overridepublic void onClick(DialogInterface dialog, int which) {ActivityCompat.requestPermissions(activity, shouldRationalePermissionsList.toArray(new String[shouldRationalePermissionsList.size()]),CODE_MULTI_PERMISSION);Log.d(TAG, "showMessageOKCancel requestPermissions");}});} else {grant.onPermissionGranted(CODE_MULTI_PERMISSION);}}private static void shouldShowRationale(final Activity activity, final int requestCode, final String requestPermission) {//TODOString[] permissionsHint = activity.getResources().getStringArray(R.array.permissions);showMessageOKCancel(activity, "Rationale: " + permissionsHint[requestCode], new DialogInterface.OnClickListener() {@Overridepublic void onClick(DialogInterface dialog, int which) {ActivityCompat.requestPermissions(activity,new String[]{requestPermission},requestCode);Log.d(TAG, "showMessageOKCancel requestPermissions:" + requestPermission);}});}private static void showMessageOKCancel(final Activity context, String message, DialogInterface.OnClickListener okListener) {new AlertDialog.Builder(context).setMessage(message).setPositiveButton("打开权限", okListener).setNegativeButton("取消", null).create().show();}/*** @param activity* @param requestCode  Need consistent with requestPermission* @param permissions* @param grantResults*/public static void requestPermissionsResult(final Activity activity, final int requestCode, String[] permissions,int[] grantResults, PermissionGrant permissionGrant) {if (activity == null) {return;}Log.d(TAG, "requestPermissionsResult requestCode:" + requestCode);if (requestCode == CODE_MULTI_PERMISSION) {requestMultiResult(activity, permissions, grantResults, permissionGrant);return;}if (requestCode < 0 || requestCode >= requestPermissions.length) {Log.w(TAG, "requestPermissionsResult illegal requestCode:" + requestCode);Toast.makeText(activity, "illegal requestCode:" + requestCode, Toast.LENGTH_SHORT).show();return;}Log.i(TAG, "onRequestPermissionsResult requestCode:" + requestCode + ",permissions:" + permissions.toString()+ ",grantResults:" + grantResults.toString() + ",length:" + grantResults.length);if (grantResults.length == 1 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {Log.i(TAG, "onRequestPermissionsResult PERMISSION_GRANTED");//TODO success, do something, can use callbackpermissionGrant.onPermissionGranted(requestCode);} else {//TODO hint user this permission functionLog.i(TAG, "onRequestPermissionsResult PERMISSION NOT GRANTED");//TODOString[] permissionsHint = activity.getResources().getStringArray(R.array.permissions);openSettingActivity(activity, "Result" + permissionsHint[requestCode]);}}private static void openSettingActivity(final Activity activity, String message) {showMessageOKCancel(activity, message, new DialogInterface.OnClickListener() {@Overridepublic void onClick(DialogInterface dialog, int which) {Intent intent = new Intent();intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);Log.d(TAG, "getPackageName(): " + activity.getPackageName());Uri uri = Uri.fromParts("package", activity.getPackageName(), null);intent.setData(uri);activity.startActivity(intent);}});}/*** @param activity* @param isShouldRationale true: return no granted and shouldShowRequestPermissionRationale permissions, false:return no granted and !shouldShowRequestPermissionRationale* @return*/public static ArrayList<String> getNoGrantedPermission(Activity activity, boolean isShouldRationale) {ArrayList<String> permissions = new ArrayList<>();for (int i = 0; i < requestPermissions.length; i++) {String requestPermission = requestPermissions[i];//TODO checkSelfPermissionint checkSelfPermission = -1;try {checkSelfPermission = ActivityCompat.checkSelfPermission(activity, requestPermission);} catch (RuntimeException e) {Toast.makeText(activity, "please open those permission", Toast.LENGTH_SHORT).show();Log.e(TAG, "RuntimeException:" + e.getMessage());return null;}if (checkSelfPermission != PackageManager.PERMISSION_GRANTED) {Log.i(TAG, "getNoGrantedPermission ActivityCompat.checkSelfPermission != PackageManager.PERMISSION_GRANTED:" + requestPermission);if (ActivityCompat.shouldShowRequestPermissionRationale(activity, requestPermission)) {Log.d(TAG, "shouldShowRequestPermissionRationale if");if (isShouldRationale) {permissions.add(requestPermission);}} else {if (!isShouldRationale) {permissions.add(requestPermission);}Log.d(TAG, "shouldShowRequestPermissionRationale else");}}}return permissions;}
}

再看下如何调用

package com.xiayiye.yhsh.permissionsdemo;import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.app.FragmentActivity;
import android.util.Log;
import android.view.View;
import android.widget.Toast;/*** @author 轻飞扬*         2018年5月22日20:41:03*/
public class PermissionActivity extends FragmentActivity implements ActivityCompat.OnRequestPermissionsResultCallback {private static final String TAG = PermissionActivity.class.getSimpleName();@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_permission);/*FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();PermissionsFragment fragment = new PermissionsFragment();transaction.replace(R.id.content_fragment, fragment);transaction.commit();*/}/*** Called when the 'show camera' button is clicked.* Callback is defined in resource layout definition.*/public void showCamera(View view) {Log.i(TAG, "Show camera button pressed. Checking permission.");PermissionUtils.requestPermission(this, PermissionUtils.CODE_CAMERA, mPermissionGrant);}public void getAccounts(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_GET_ACCOUNTS, mPermissionGrant);}public void callPhone(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_CALL_PHONE, mPermissionGrant);}public void readPhoneState(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_READ_PHONE_STATE, mPermissionGrant);}public void accessFineLocation(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_ACCESS_FINE_LOCATION, mPermissionGrant);}public void accessCoarseLocation(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_ACCESS_COARSE_LOCATION, mPermissionGrant);}public void readExternalStorage(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_READ_EXTERNAL_STORAGE, mPermissionGrant);}public void writeExternalStorage(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_WRITE_EXTERNAL_STORAGE, mPermissionGrant);}public void recordAudio(View view) {PermissionUtils.requestPermission(this, PermissionUtils.CODE_RECORD_AUDIO, mPermissionGrant);}private PermissionUtils.PermissionGrant mPermissionGrant = new PermissionUtils.PermissionGrant() {@Overridepublic void onPermissionGranted(int requestCode) {switch (requestCode) {case PermissionUtils.CODE_RECORD_AUDIO:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_RECORD_AUDIO", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_GET_ACCOUNTS:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_GET_ACCOUNTS", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_READ_PHONE_STATE:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_READ_PHONE_STATE", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_CALL_PHONE:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_CALL_PHONE", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_CAMERA:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_CAMERA", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_ACCESS_FINE_LOCATION:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_ACCESS_FINE_LOCATION", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_ACCESS_COARSE_LOCATION:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_ACCESS_COARSE_LOCATION", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_READ_EXTERNAL_STORAGE:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_READ_EXTERNAL_STORAGE", Toast.LENGTH_SHORT).show();break;case PermissionUtils.CODE_WRITE_EXTERNAL_STORAGE:Toast.makeText(PermissionActivity.this, "Result Permission Grant CODE_WRITE_EXTERNAL_STORAGE", Toast.LENGTH_SHORT).show();break;default:break;}}};/*** Callback received when a permissions request has been completed.*/@Overridepublic void onRequestPermissionsResult(final int requestCode, @NonNull String[] permissions,@NonNull int[] grantResults) {PermissionUtils.requestPermissionsResult(this, requestCode, permissions, grantResults, mPermissionGrant);}
}

看不懂的可以下载moudle源码跑起来

点击下载源码

Android动态权限申请工具类非常好用包含9组危险权限相关推荐

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

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

  2. android动态申请悬浮框权限,Android动态权限申请工具(包括悬浮窗)

    为了保证APP正常运行,动态权限申请是android比较常用的功能,由于每次都需要做申请.等待返回还有拒绝反馈等操作,比较麻烦,所以集成了一个比较简单的动态权限申请库 集成方法: Step 1. Ad ...

  3. android 字体像素转换工具类_Android中px与dip,sp与dip等的转换工具类

    Android中px与dip,sp与dip等的转换工具类 功能 通常在代码中设置组件或文字大小只能用px,通过这个工具类我们可以把dip(dp)或sp为单位的值转换为以px为单位的值而保证大小不变.方 ...

  4. Android中对话框的工具类

    Android中对话框的工具类,里面总结了比较好用的方法,直接调用即可 public class DialogUtils {private DialogUtils() {}private static ...

  5. android 字体像素转换工具类_android px,dp,sp大小转换工具

    package com.voole.playerlib.util; import android.content.Context; /** * Android大小单位转换工具类 * * float s ...

  6. Android沉浸式状态栏工具类,一句代码轻松搞定

    Android沉浸式状态栏工具类,一句代码轻松搞定 博客原文及源码地址:http://jaeger.itscoder.com/android/2016/03/27/statusbar-util.htm ...

  7. Android大小单位转换工具类

    package com.utouu.im.util; /**  * Android大小单位转换工具类  *   *   */ public class DisplayUtil { /** * 将px值 ...

  8. 使用POI在Excel中动态生成图表工具类(支持柱状、组合、环状图、折线图、等常用图)

    使用POI在Excel中动态生成图表工具类 使用POI在Excel中动态生成图表工具类 由于公司是一个生成报表的机构,之前一直使用pageOffice,但是公司领导就是不买,你说公司那样有钱磨磨唧唧干 ...

  9. android 开发工具类,Android中常用开发工具类—持续更新...

    一.自定义ActionBar public class ActionBarTool { public static void setActionBarLayout(Activity act,Conte ...

最新文章

  1. 【mysql】linux安装mysql
  2. 详解正则表达式匹配方法 match()
  3. JS中的let和var的区别
  4. opencv中imgproc库中函数详解(1)
  5. 深入理解JVM原理之编译openjdk7
  6. Jaxb对xml报文头的小修小改
  7. 为了证明自己有多能喝,理工科的学生竟做出这种事
  8. python:浅析python 中__name__ = '__main__' 的作用
  9. 开课吧:微服务与DDD解析
  10. Python:学习笔记之多值参数(函数中*传递元组**传递字典)案例演练
  11. Latex:WinEdt打开.tex文件时的编码问题
  12. oracle 7天密码过期,oracle密码过期ORA-28002: 7天之后口令将过期的解决方法
  13. office2003无法正常安装卸载问题解决
  14. 计算机组成原理 — PCI-E 外设接口标准
  15. 云南计算机一级c类基础知识,云南省大学计算机一级C类多选题及答案.pdf
  16. 如何阅读一本书-【未排版!】
  17. 「Java」冒泡排序
  18. 对植物大战僵尸的数据修改
  19. 指定的服务器标记为删除,如何解决“指定的服务已被标记为删除”错误
  20. android开发可用技巧

热门文章

  1. php开启端口复用,请问下workman是否支持端口复用?
  2. app图标圆角角度_教你如何绘制风格统一的APP界面图标
  3. 在python中用import或者from_[转]python基础之---import与from...import....
  4. mysql 优化设计库_MySQL 数据库最优化设计原则
  5. mysql connect返回值_mysql_connect
  6. mysql 创建事件_mysql怎么建立事件
  7. ios 获取html的高度,iOS Webview自适应实际内容高度的4种方法详解
  8. datagrid vue_类似 easyui 中 datagrid 使用习惯的 element-ui 数据表格组件(el-datagrid)...
  9. WUSTOJ 1282: Start(Java)
  10. 字符串相似度算法——Levenshtein Distance算法