真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

android開發(fā)權(quán)限詢問(wèn)的示例代碼

現(xiàn)在基于信息安全問(wèn)題,特別是版本是23以上權(quán)限越嚴(yán)格。

創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、博州網(wǎng)絡(luò)推廣、小程序定制開發(fā)、博州網(wǎng)絡(luò)營(yíng)銷、博州企業(yè)策劃、博州品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供博州建站搭建服務(wù),24小時(shí)服務(wù)熱線:18982081108,官方網(wǎng)址:www.cdcxhl.com

特別是拍照,讀,寫權(quán)限

一般權(quán)限允許過(guò),下次就不用詢問(wèn)了的,所以很多應(yīng)用都喜歡在首頁(yè)或者啟動(dòng)頁(yè)直接詢問(wèn),不允許的就用不了1、下面給出封裝好的類,至于什么時(shí)候調(diào)看項(xiàng)目需要

public class EasyPermissions {

private static final String TAG = "EasyPermissions";

public interface PermissionCallbacks extends
    ActivityCompat.OnRequestPermissionsResultCallback {

  void onPermissionsGranted(List perms);

  void onPermissionsDenied(List 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.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) {
    //彈框詢問(wèn)
    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());
            }
          }
        }).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.
 * 

* 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 granted = new ArrayList<>(); ArrayList 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."); } }}

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

2、調(diào)用示例(activity或fragment):(方法調(diào)用的時(shí)機(jī)隨你)

private void requestGalleryPermission() {
  //權(quán)限參數(shù)可以添加很多,不固定參數(shù)的
  if (EasyPermissions.hasPermissions(this, Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
    getPhotos();//如果具有權(quán)限做的操作
  } 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):

@Override
public void onPermissionsGranted(List list) {
  //允許
  getPhotos();
}

@Override
public void onPermissionsDenied(List list) {
  //拒絕
  mTvEmptyView.setText(R.string.permissions_denied_tips);
  //mIvTakePhoto.setVisibility(View.GONE);
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


網(wǎng)站欄目:android開發(fā)權(quán)限詢問(wèn)的示例代碼
URL鏈接:http://weahome.cn/article/ghpops.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部