成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在鴻蒙系統上實現權限請求框架—桃夭權限請求框架

開發 前端
桃夭是鴻蒙系統上的一款權限請求框架,對請求權限的代碼進行高度封裝,極大的簡化了申請權限的代碼邏輯,同時支持在Ability、FractionAbility、AbilitySlice、Fractiion里面申請權限。

[[433362]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

本文正在參與優質創作者激勵

一、簡介

桃夭是鴻蒙系統上的一款權限請求框架,對請求權限的代碼進行高度封裝,極大的簡化了申請權限的代碼邏輯,同時支持在Ability、FractionAbility、AbilitySlice、Fractiion里面申請權限。

二、源碼

源碼

建議大家把源碼下載下來看看。

三、申請權限的一般步驟

  • 判斷是否有權限,如果有權限,直接進行下一步。
  • 如果沒有權限,可以彈窗告知用戶申請權限的原因。
  • 彈窗告知用戶后,如果用戶同意申請權限,則判斷用戶是否點擊了不再提醒。
  • 如果用戶沒有點擊不再提醒,則開始申請權限。
  • 如果用戶點擊了不再提醒,則彈窗告知用戶去設置頁面開啟權限,用戶點擊彈窗后,跳轉到設置頁面。
  • 重寫onRequestPermissionsFromUserResult方法,判斷用戶是否授予權限。

每次申請權限的時候,都需要經過以上幾個步驟,當申請的權限越來越多,大量的重復代碼就出現了。為了減少重復代碼,我封裝了一個權限請求框架,權限請求框架取名為桃夭。

四、桃夭的使用方式

如下代碼,先添加依賴,然后你只需要告知權限請求框架你需要什么權限,權限請求框架就會告知你權限申請成功還是失敗。你不需要手動判斷是否有權限,不需要彈窗告知用戶申請權限的原因,不需要判斷用戶是否點擊了不再提醒,不需要跳轉設置頁面讓用戶開啟權限,不需要重寫onRequestPermissionsFromUserResult方法。框架把這些代碼邏輯都給做了,你只需要關注權限申請成功還是失敗。

申請權限變得如此之簡單。

添加依賴

  1. api 'io.gitee.zhongte:taoyao:1.0.1' 

 申請權限

  1. // 申請多設備協同權限 
  2. EasyPermission.requestPermission(this, EasyPermission.DISTRIBUTED_DATASYNC, new PermissionAction() { 
  3.             @Override 
  4.             public void onGranted(List<String> permissions) { 
  5.                 // 權限申請成功 
  6.                  
  7.             } 
  8.  
  9.             @Override 
  10.             public void onDenied(List<String> permissions) { 
  11.                 // 權限申請失敗 
  12.             } 
  13.         }, SystemPermission.DISTRIBUTED_DATASYNC); 

 申請權限的時候可能會涉及到兩個彈窗,一個彈窗是用來告知用戶申請權限的原因,另一個彈窗是用來告知用戶去設置頁面開啟權限,這兩個彈窗在不同的應用里面可能長得不一樣,所以這兩個彈窗并沒有被封裝到桃夭框架里面,而是需要使用者根據你的彈窗樣式對桃夭進行二次封裝,我在源碼里面對桃夭框架進行了二次封裝,大家可以把源碼下載下來,參考下我是如何對桃夭框架進行二次封裝的。二次封裝完成后,就可以愉快的使用上面的代碼申請權限了。

五、實現原理

5、1 檢測申請的權限是否在配置文件中聲明

申請的權限必須在配置文件中聲明,否則桃夭會直接拋異常。如何檢測申請的權限是否在配置文件中聲明。

如下代碼,獲取bundleManager對象,通過bundleManager對象獲取應用信息,之后就可以獲取應用在配置文件中聲明的權限了。

  1. /** 
  2.  * 獲取在配置文件中聲明的權限 
  3.  * 
  4.  * @param context 上下文 
  5.  * @return 在配置文件中聲明的權限 
  6.  */ 
  7. private List<String> getConfigPermissions(Context context) { 
  8.     // 獲取bundleManager對象 
  9.     IBundleManager bundleManager = context.getBundleManager(); 
  10.     String bundleName = context.getBundleName(); 
  11.     try { 
  12.         // 獲取應用信息 
  13.         BundleInfo bundleInfo = bundleManager.getBundleInfo(bundleName, IBundleManager.GET_BUNDLE_WITH_REQUESTED_PERMISSION); 
  14.         // 獲取應用在配置文件中聲明的權限 
  15.         List<String> reqPermissionDetails = bundleInfo.reqPermissions; 
  16.         if (reqPermissionDetails == null || reqPermissionDetails.isEmpty()) { 
  17.             throw new IllegalStateException("請在配置文件中聲明要申請的權限"); 
  18.         } 
  19.         return reqPermissionDetails; 
  20.     } catch (RemoteException e) { 
  21.         e.printStackTrace(); 
  22.     } 
  23.     return new ArrayList<>(); 

獲取到在配置文件中聲明的權限后,就可以判斷申請的權限是否在配置文件中了

  1. /** 
  2.      * 檢查申請的權限是否在配置文件中聲明 
  3.      * 
  4.      * @param permissions 要申請的權限 
  5.      */ 
  6.     private void checkPermissions(String... permissions) { 
  7.         if (permissions == null || permissions.length == 0) { 
  8.             throw new IllegalArgumentException("請至少申請一個權限"); 
  9.         } 
  10.         // 獲取在配置文件中聲明的權限 
  11.         mReqPermissions = getConfigPermissions(mOrigin.getContext()); 
  12.         if (mReqPermissions.isEmpty()) { 
  13.             throw new IllegalStateException("請在配置文件中聲明要申請的權限"); 
  14.         } 
  15.         for (String target : permissions) { 
  16.             if (!mReqPermissions.contains(target)) { 
  17.                 // 沒有在配置中聲明要申請的權限,直接拋異常 
  18.                 throw new IllegalStateException(String.format("%1$s權限沒有配置文件中聲明", target)); 
  19.             } 
  20.         } 
  21.     } 

5、2 判斷是否有權限

檢測完權限是否在配置中聲明后,就可以判斷是否有權限了。這里就是通過上下文對象的verifySelfPermission方法來判斷是否有權限,如果沒有權限,可以彈窗告知用戶申請的原因。

  1. /** 
  2.     * 是否有權限 
  3.     *  
  4.     * @param context 
  5.     * @param permissions 
  6.     * @return 
  7.     */ 
  8.    @Override 
  9.    public boolean hasPermission(Context context, List<String> permissions) { 
  10.        for (String permission : permissions) { 
  11.            int result = context.verifySelfPermission(permission); 
  12.            if (result == IBundleManager.PERMISSION_DENIED) { 
  13.                // 沒有權限 
  14.                return false
  15.            } 
  16.        } 
  17.        return true
  18.    } 

5、3 判斷用戶是否點擊了不再提醒

通過上下文對象的canRequestPermission方法來判斷用戶是否點擊了不再提醒。

  1. /** 
  2.    * 用戶是否點擊了不在提醒 
  3.    * 
  4.    * @param permission 權限 
  5.    * @return 
  6.    */ 
  7.   @Override 
  8.   public boolean canRequestPermission(String permission) { 
  9.       return mContext.canRequestPermission(permission); 
  10.   } 

5、4 跳轉到設置頁面

如果用戶點擊了不再提醒,則可以跳轉到設置頁面讓用戶開啟權限

  1. /** 
  2.      * 跳轉到設置頁面 
  3.      */ 
  4.     @Override 
  5.     public void gotoSetting() { 
  6.         try { 
  7.             Intent intent = new Intent(); 
  8.             intent.setAction(IntentConstants.ACTION_APPLICATION_DETAILS_SETTINGS); 
  9.             intent.setUri(Uri.parse("package:" + mOrigin.getContext().getBundleName())); 
  10.             mOrigin.startAbility(intent); 
  11.         } catch (Exception e) { 
  12.             e.printStackTrace(); 
  13.         } 
  14.     } 

5、5 啟動透明的Ability申請權限

如果沒有權限,用戶頁面沒有點擊不再提醒,那就可以申請權限了。為了不讓調用者重寫onRequestPermissionsFromUserResult方法,桃夭內部啟動了一個Ability。如下代碼。

  1. /** 
  2.  * 開啟一個透明的Ability來申請權限,這樣外界就不需要重寫onRequestPermissionsFromUserResult方法 
  3.  */ 
  4. public class PermissionAbility extends Ability { 
  5.  
  6.     private static final int REQUEST_CODE = 0X10; 
  7.     public static final String KEY_PERMISSION = "key_permission"
  8.     public static final String KEY_TYPE = "key_type"
  9.     public static final String SENSITIVE_PERMISSION = "sensitive_permission"
  10.  
  11.     @Override 
  12.     public void onStart(Intent intent) { 
  13.         super.onStart(intent); 
  14.         getWindow().setTransparent(true); 
  15.         super.setUIContent(ResourceTable.Layout_ability_permission); 
  16.         List<String> permissions = intent.getSerializableParam(KEY_PERMISSION); 
  17.         String permissionType = intent.getStringParam(KEY_TYPE); 
  18.         // 請求權限 
  19.         requestPermissionsFromUser(permissions.toArray(new String[0]), REQUEST_CODE); 
  20.     } 
  21.  
  22.     @Override 
  23.     public void onRequestPermissionsFromUserResult(int requestCode, String[] permissions, int[] grantResults) { 
  24.         super.onRequestPermissionsFromUserResult(requestCode, permissions, grantResults); 
  25.         // 權限的回調方法 
  26.         Postman.send(permissions, grantResults); 
  27.         terminateAbility(); 
  28.     } 
  29.  
  30.     @Override 
  31.     protected void onAbilityResult(int requestCode, int resultCode, Intent resultData) { 
  32.         super.onAbilityResult(requestCode, resultCode, resultData); 
  33.     } 

直接啟動一個Ability會發生頁面跳轉,為了不讓頁面發生跳轉,這里啟動了一個透明的Ability。如何將Ability設置透明,如下代碼。在abilities節點添加metaData,這里最關鍵的是Translucent,也就是透明。

  1. "abilities": [ 
  2.       { 
  3.         "orientation""unspecified"
  4.         "name""com.poetry.taoyao.ability.PermissionAbility"
  5.         "icon""$media:icon"
  6.         "description""$string:permissionability_description"
  7.         "label""$string:taoyao_PermissionAbility"
  8.         "type""page"
  9.         "launchType""standard"
  10.         "metaData": { 
  11.           "customizeData": [ 
  12.             { 
  13.               "name""hwc-theme"
  14.               "value""androidhwext:style/Theme.Emui.Translucent.NoTitleBar" 
  15.             } 
  16.           ] 
  17.         } 
  18.       } 

僅僅有上面的步驟好不夠,需要在Ability或者AbilitySlice里面將窗口設置成透明。如下代碼。

  1. getWindow().setTransparent(true); 

 經過上面兩步,也就是將Ability的主題和窗口都設置成透明,這樣就能將Ability變成透明的了,同時也不會發生頁面跳轉。

5、6 判斷用戶是否授予權限

判斷用戶是否授予權限,可以使用標準的方式來判斷。也就是通過grantResult來判斷用戶是否授予權限。

  1. @Override 
  2.  public boolean hasPermission(int[] grantResults, String... permissions) { 
  3.      if (grantResults == null || grantResults.length <= 0) { 
  4.          return false
  5.      } 
  6.      for (int grantResult : grantResults) { 
  7.          if (grantResult == IBundleManager.PERMISSION_DENIED) { 
  8.              return false
  9.          } 
  10.      } 
  11.      return true
  12.  } 

其實還有另外的方式來判斷用戶是否授予權限。也就是不管用戶是否授權,直接訪問相關業務。比如,申請錄音權限,當系統回調onRequestPermissionsFromUserResult方法時,直接去錄音,如果發生異常,捕獲異常說明沒有權限。如下代碼:

  1. /** 
  2.     * 通過直接錄音的方式來判斷是否有錄音權限 
  3.     *  
  4.     * @param context 
  5.     * @return 
  6.     * @throws Throwable 
  7.     */ 
  8.    @Override 
  9.    public boolean test(Context context) throws Throwable { 
  10.        AudioStreamInfo audioStreamInfo = new AudioStreamInfo.Builder().encodingFormat( 
  11.                AudioStreamInfo.EncodingFormat.ENCODING_PCM_16BIT) 
  12.                .channelMask(AudioStreamInfo.ChannelMask.CHANNEL_IN_STEREO) 
  13.                .sampleRate(AUDIO_SAMPLE_RATE) 
  14.                .build(); 
  15.        AudioCapturerInfo audioCapturerInfo = new AudioCapturerInfo.Builder().audioStreamInfo(audioStreamInfo).build(); 
  16.        try { 
  17.            AudioCapturer capturer = new AudioCapturer(audioCapturerInfo); 
  18.            // 錄音 
  19.            capturer.start(); 
  20.            new Timer().schedule(new TimerTask() { 
  21.                @Override 
  22.                public void run() { 
  23.                    capturer.stop(); 
  24.                } 
  25.            }, AUDIO_RECORDING_TIME); 
  26.            // 沒有發生異常,有權限 
  27.            return true
  28.        } catch (Exception e) { 
  29.            // 發生異常,無權限 
  30.            return false
  31.        } 
  32.    } 

桃夭在判斷用戶是否授權時,上面的兩種方式都使用了。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2024-07-26 16:17:22

2021-05-06 16:21:55

鴻蒙HarmonyOS應用開發

2012-07-30 09:32:00

Web

2017-04-21 16:00:09

2022-12-26 00:00:01

Go框架前端

2018-05-03 19:14:23

iOS開發框架API

2021-10-12 10:50:31

鴻蒙HarmonyOS應用

2024-02-18 12:44:22

2024-07-31 08:01:48

2025-01-07 08:20:00

2021-07-30 14:54:54

鴻蒙HarmonyOS應用

2010-03-02 10:59:04

2010-08-20 12:01:02

SNMP管理框架

2015-06-18 10:20:12

Swift初學者權限

2010-10-28 11:17:29

Oracle系統權限

2024-11-04 08:16:08

Go語言Web 框架

2020-11-26 10:08:17

Golang GinW

2017-07-11 09:21:40

quartzshiro權限框架

2024-12-16 00:48:39

Gin框架函數

2025-01-10 06:00:00

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一级黄色免费看 | 亚洲一区二区三区四区五区中文 | 国产精品久久99 | 在线一区二区三区 | av网址在线播放 | 欧美精品二区 | 成人毛片视频免费 | 欧美1区2区 | 日韩理论电影在线观看 | 午夜午夜精品一区二区三区文 | 日韩视频一区在线观看 | 精品乱子伦一区二区三区 | 91短视频网址| 中文在线日韩 | 亚洲精品9999| 国产一伦一伦一伦 | 一级高清免费毛片 | 2019天天操| 日本黄色不卡视频 | 久久久久一区 | 黄网站在线观看 | 国产伦精品一区二区三区视频金莲 | av在线播放一区二区 | 国产午夜av片 | 亚洲精品片 | 成人免费一区二区三区牛牛 | 99精品国产一区二区三区 | 在线国产欧美 | 欧美性久久 | 成人av免费在线观看 | 欧美在线精品一区 | 一区二区视频在线 | 国产精品久久久亚洲 | 国产精品毛片一区二区三区 | 97久久久久久久久 | 在线播放第一页 | 自拍偷拍视频网 | 精品欧美一区二区三区久久久 | 淫片一级国产 | 色本道| av在线免费观看网站 |