亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

android檢測SD卡讀寫權(quán)限方法

 更新時間:2018年08月01日 08:49:53   作者:GitHuang  
今天小編就為大家分享一篇android檢測SD卡讀寫權(quán)限方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

一、解析

做項目遇到了一個棘手的問題,SD卡的讀寫權(quán)限問題。

1.android版本在6.0以上版本時,以下代碼才有用:

if (Build.VERSION.SDK_INT >= 23) {
   UiUtils.getInstance().showToast("1");
   //減少是否擁有權(quán)限checkCallPhonePermission != PackageManager.PERMISSION_GRANTED
   int checkCallPhonePermission = ContextCompat.checkSelfPermission(getApplicationContext(), permission);
   if (checkCallPhonePermission != PackageManager.PERMISSION_GRANTED) {
    UiUtils.getInstance().showToast("2");
    //彈出對話框接收權(quán)限
    ActivityCompat.requestPermissions(TakeCameraActivity.this, new String[]{permission}, id);
    return;
   } else {
    UiUtils.getInstance().showToast("3");
    if(allowableRunnable!=null){
     allowableRunnable.run();
    }
   }
  }

因為在android版本5.0以上才把SD卡的讀寫權(quán)限分離開,以前的老版本是沒有進(jìn)行分離的。故找不到SD卡的讀寫權(quán)限,而在測試的過程中,華為的手機(jī)出現(xiàn)SD卡讀寫權(quán)限分離在兩個地方,有的時候可能不好找,本人就出現(xiàn)這個問題。

二、代碼介紹

調(diào)用第一個方法:

使用之前先定義兩個變量:

 private Map<Integer, Runnable> allowablePermissionRunnables = new HashMap<>();
 private Map<Integer, Runnable> disallowablePermissionRunnables = new HashMap<>();

1.”android.permission.WRITE_EXTERNAL_STORAGE”這個是SD卡的寫入權(quán)限,這里檢測一個權(quán)限就可以了,不用檢測讀的權(quán)限了。

(1)以下第一個Runnable()中是權(quán)限提示框允許之后處理的業(yè)務(wù)。

(2)第二個Runnable()中是權(quán)限提示框拒絕之后執(zhí)行的業(yè)務(wù)邏輯。

requestPermission(HDCivilizationConstants.SD_CARD_REQUEST_CODE, "android.permission.WRITE_EXTERNAL_STORAGE", new Runnable() {
   @Override
   public void run() {
   //第一個Runnable
    if (type==1){
     FileUtils.saveBitmapPng(rectBitmap, pathList, 80);
    }else{
     try {
      FileUtils.saveBitmapJPG(rectBitmap, pathList, 70);
     } catch (ContentException e) {
      e.printStackTrace();
     }
    }
   }
  }, new Runnable() {
   @Override
   public void run() {
   //第二個Runnable
//    UiUtils.getInstance().showToast("請查看SD卡的讀寫權(quán)限");
    OKPopup.getInstance().showPopup(TakeCameraActivity.this, new OKPopup.BtnClickListener() {
     @Override
     public void btnOk() {
      OKPopup.getInstance().dismissDialog();
     }
    }, false, HDCivilizationConstants.SDCARD_PERMISSION);
   }
  });

2.調(diào)用上面的那個方法之后會跳轉(zhuǎn)至這個方法(代碼如下):

 /**
  * 請求權(quán)限
  * @param id 請求授權(quán)的id 唯一標(biāo)識即可
  * @param permission 請求的權(quán)限
  * @param allowableRunnable 同意授權(quán)后的操作
  * @param disallowableRunnable 禁止權(quán)限后的操作
  */
 protected void requestPermission(int id, String permission, Runnable allowableRunnable, Runnable disallowableRunnable) {
  if(allowableRunnable!=null){
   allowablePermissionRunnables.put(id, allowableRunnable);
  }

  if (disallowableRunnable != null) {
   disallowablePermissionRunnables.put(id, disallowableRunnable);
  }

  //api版本判斷
  if (Build.VERSION.SDK_INT >= 23) {
   UiUtils.getInstance().showToast("1");
   //減少是否擁有權(quán)限checkCallPhonePermission != PackageManager.PERMISSION_GRANTED
   int checkCallPhonePermission = ContextCompat.checkSelfPermission(getApplicationContext(), permission);
   if (checkCallPhonePermission != PackageManager.PERMISSION_GRANTED) {
    UiUtils.getInstance().showToast("2");
    //彈出對話框接收權(quán)限
    ActivityCompat.requestPermissions(TakeCameraActivity.this, new String[]{permission}, id);
    return;
   } else {
    UiUtils.getInstance().showToast("3");
    if(allowableRunnable!=null){
     allowableRunnable.run();
    }
   }
  } else {
   boolean result = PermissionChecker.checkSelfPermission(this, permission)
     == PermissionChecker.PERMISSION_GRANTED;
   if(!result){
    UiUtils.getInstance().showToast("4");
    //如果未授權(quán)
    ActivityCompat.requestPermissions(TakeCameraActivity.this, new String[]{permission}, id);
   }else{
    UiUtils.getInstance().showToast("5");
    if(allowableRunnable!=null){
     allowableRunnable.run();
    }
   }
  }
 }

3.onRequestPermissionsResult方法是響應(yīng)2中的方法之后執(zhí)行。執(zhí)行代碼之后,開始執(zhí)行Runnable中的代碼程序。

 @Override
 public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
  super.onRequestPermissionsResult(requestCode, permissions, grantResults);

  if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
   Runnable allowRun = allowablePermissionRunnables.get(requestCode);
   if(allowRun!=null){
    allowRun.run();
   }

  } else {
   Runnable disallowRun = disallowablePermissionRunnables.get(requestCode);
   if(disallowRun!=null){
    disallowRun.run();
   }
  }
 }

以上這篇android檢測SD卡讀寫權(quán)限方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論