国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

android開發權限詢問的示例代碼

2019-10-22 18:17:09
字體:
來源:轉載
供稿:網友

現在基于信息安全問題,特別是版本是23以上權限越嚴格。

特別是拍照,讀,寫權限

一般權限允許過,下次就不用詢問了的,所以很多應用都喜歡在首頁或者啟動頁直接詢問,不允許的就用不了1、下面給出封裝好的類,至于什么時候調看項目需要

public class EasyPermissions {private static final String TAG = "EasyPermissions";public interface PermissionCallbacks extends    ActivityCompat.OnRequestPermissionsResultCallback {  void onPermissionsGranted(List<String> perms);  void onPermissionsDenied(List<String> perms);}/** * Check if the calling context has a set of permissions. * * @param context the calling context. * @param perms  one ore more permissions, such as {@code android/119023.html">android.Manifest.permission.CAMERA}. * @return true if all permissions are already granted, false if at least one permission * is not yet granted. */public static boolean hasPermissions(Context context, String... perms) {  for (String perm : perms) {    boolean hasPerm = (ContextCompat.checkSelfPermission(context, perm) == PackageManager.PERMISSION_GRANTED);    if (!hasPerm) {      return false;    }  }  return true;}/** * Request a set of permissions, showing rationale if the system requests it. * * @param object   Activity or Fragment requesting permissions. Should implement *          {@link ActivityCompat.OnRequestPermissionsResultCallback} *          or *          {@link android.support.v13.app.FragmentCompat.OnRequestPermissionsResultCallback} * @param rationale  a message explaining why the application needs this set of permissions, will *          be displayed if the user rejects the request the first time. * @param requestCode request code to track this request, must be < 256. * @param perms    a set of permissions to be requested. */public static void requestPermissions(final Object object, String rationale,    final int requestCode, final String... perms) {  requestPermissions(object, rationale,      android.R.string.ok,      android.R.string.cancel,      requestCode, perms);}/** * Request a set of permissions, showing rationale if the system requests it. * * @param object     Activity or Fragment requesting permissions. Should implement *            {@link ActivityCompat.OnRequestPermissionsResultCallback} *            or *            {@link android.support.v13.app.FragmentCompat.OnRequestPermissionsResultCallback} * @param rationale   a message explaining why the application needs this set of permissions, will *            be displayed if the user rejects the request the first time. * @param positiveButton custom text for positive button * @param negativeButton custom text for negative button * @param requestCode  request code to track this request, must be < 256. * @param perms     a set of permissions to be requested. */public static void requestPermissions(final Object object, String rationale,    @StringRes int positiveButton,    @StringRes int negativeButton,    final int requestCode, final String... perms) {  checkCallingObjectSuitability(object);  boolean shouldShowRationale = false;  for (String perm : perms) {    shouldShowRationale = shouldShowRationale || shouldShowRequestPermissionRationale(object, perm);  }  if (shouldShowRationale) {    //彈框詢問    AlertDialog dialog = new AlertDialog.Builder(getActivity(object))        .setMessage(rationale)        .setPositiveButton(positiveButton, new DialogInterface.OnClickListener() {          @Override          public void onClick(DialogInterface dialog, int which) {            executePermissionsRequest(object, perms, requestCode);          }        })        .setNegativeButton(negativeButton, new DialogInterface.OnClickListener() {          @Override          public void onClick(DialogInterface dialog, int which) {            // Do nothing, user does not want to request            PermissionCallbacks callbacks = (PermissionCallbacks) object;            if(callbacks != null) {              callbacks.onPermissionsDenied(new ArrayList<String>());            }          }        }).create();    dialog.show();  } else {    executePermissionsRequest(object, perms, requestCode);  }}/** * Handle the result of a permission request, should be called from the calling Activity's * {@link ActivityCompat.OnRequestPermissionsResultCallback#onRequestPermissionsResult(int, String[], int[])} * method. * <p/> * If any permissions were granted or denied, the Activity will receive the appropriate * callbacks through {@link PermissionCallbacks} and methods annotated with * {@link AfterPermissionGranted} will be run if appropriate. * * @param requestCode requestCode argument to permission result callback. * @param permissions permissions argument to permission result callback. * @param grantResults grantResults argument to permission result callback. * @param object    the calling Activity or Fragment. * @throws IllegalArgumentException if the calling Activity does not implement *                 {@link PermissionCallbacks}. */public static void onRequestPermissionsResult(int requestCode, String[] permissions,    int[] grantResults, Object object) {  checkCallingObjectSuitability(object);  PermissionCallbacks callbacks = (PermissionCallbacks) object;  // Make a collection of granted and denied permissions from the request.  ArrayList<String> granted = new ArrayList<>();  ArrayList<String> denied = new ArrayList<>();  for (int i = 0; i < permissions.length; i++) {    String perm = permissions[i];    if (grantResults[i] == PackageManager.PERMISSION_GRANTED) {      granted.add(perm);    } else {      denied.add(perm);    }  }  // Report granted permissions, if any.  if (!granted.isEmpty()) {    // Notify callbacks    callbacks.onPermissionsGranted(granted);  }  // Report denied permissions, if any.  if (!denied.isEmpty()) {    callbacks.onPermissionsDenied(denied);  }  // If 100% successful, call annotated methods  if (!granted.isEmpty() && denied.isEmpty()) {    runAnnotatedMethods(object, requestCode);  }}private static boolean shouldShowRequestPermissionRationale(Object object, String perm) {  if (object instanceof Activity) {    return ActivityCompat.shouldShowRequestPermissionRationale((Activity) object, perm);  } else if (object instanceof Fragment) {    return ((Fragment) object).shouldShowRequestPermissionRationale(perm);  } else {    return false;  }}private static void executePermissionsRequest(Object object, String[] perms, int requestCode) {  checkCallingObjectSuitability(object);  if (object instanceof Activity) {    ActivityCompat.requestPermissions((Activity) object, perms, requestCode);  } else if (object instanceof Fragment) {    ((Fragment) object).requestPermissions(perms, requestCode);  }}private static Activity getActivity(Object object) {  if (object instanceof Activity) {    return ((Activity) object);  } else if (object instanceof Fragment) {    return ((Fragment) object).getActivity();  } else {    return null;  }}private static void runAnnotatedMethods(Object object, int requestCode) {  Class clazz = object.getClass();  for (Method method : clazz.getDeclaredMethods()) {    if (method.isAnnotationPresent(AfterPermissionGranted.class)) {      // Check for annotated methods with matching request code.      AfterPermissionGranted ann = method.getAnnotation(AfterPermissionGranted.class);      if (ann.value() == requestCode) {        // Method must be void so that we can invoke it        if (method.getParameterTypes().length > 0) {          throw new RuntimeException("Cannot execute non-void method " + method.getName());        }        try {          // Make method accessible if private          if (!method.isAccessible()) {            method.setAccessible(true);          }          method.invoke(object);        } catch (IllegalAccessException e) {          ILogger.e(TAG, "runDefaultMethod:IllegalAccessException", e);        } catch (InvocationTargetException e) {          ILogger.e(TAG, "runDefaultMethod:InvocationTargetException", e);        }      }    }  }}private static void checkCallingObjectSuitability(Object object) {  // Make sure Object is an Activity or Fragment  if (!((object instanceof Fragment) || (object instanceof Activity))) {    throw new IllegalArgumentException("Caller must be an Activity or a Fragment.");  }  // Make sure Object implements callbacks  if (!(object instanceof PermissionCallbacks)) {    throw new IllegalArgumentException("Caller must implement PermissionCallbacks.");  }}}

注:這個類不是我寫的,分享給大家

2、調用示例(activity或fragment):(方法調用的時機隨你)

private void requestGalleryPermission() {  //權限參數可以添加很多,不固定參數的  if (EasyPermissions.hasPermissions(this, Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE)) {    getPhotos();//如果具有權限做的操作  } else {    // Ask for one permission    EasyPermissions.requestPermissions(this, getString(R.string.permissions_tips_gallery),        GalleryFinal.PERMISSIONS_CODE_GALLERY, Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE);  }}

3、拒絕和允許做的操作(activity或fragment):

@Overridepublic void onPermissionsGranted(List<String> list) {  //允許  getPhotos();}@Overridepublic void onPermissionsDenied(List<String> list) {  //拒絕  mTvEmptyView.setText(R.string.permissions_denied_tips);  //mIvTakePhoto.setVisibility(View.GONE);}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 色达县| 宝山区| 无锡市| 盖州市| 三穗县| 麻江县| 攀枝花市| 江川县| 广德县| 东明县| 桂林市| 个旧市| 临海市| 东山县| 清流县| 仪征市| 曲靖市| 金阳县| 河津市| 工布江达县| 玉环县| 民乐县| 潮安县| 彭水| 蓬莱市| 武穴市| 宁明县| 曲阜市| 夹江县| 马尔康县| 蒙自县| 石狮市| 连山| 青海省| 惠水县| 泽库县| 南华县| 成都市| 甘泉县| 韶关市| 田林县|