使用EasyPermissions高效處理權限

首語

  • Android現在將所有的權限歸爲了兩類,一類是普通權限,一類是危險權限。對於普通權限,系統會自動幫我們進行授權,不需要手動操作。對於危險權限,必須要由用戶手動進行點擊授權纔可以,否則程序無法完成相應的功能。
  • Android 6.0系統中加入了運行時權限功能,在使用過程中再對危險權限進行授權。羅列Android中所有的危險權限,一共是9組24個權限,如圖:
    在這裏插入圖片描述
Android申請權限
  • 首先必須在AndroidManifest文件中添加對應權限。
if(ContextCompat.checkSelfPermission(this,Manifest.permission.CAMERA)!=PackageManager.PERMISSION_GRANTED){
        ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.CAMERA},10001);
    }else {
        //權限申請成功,做相應功能
    }
}

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    switch (requestCode){
        case 10001:
            if (grantResults.length>0&&grantResults[0]==PackageManager.PERMISSION_GRANTED){
                //做相應功能
            }else {
                Toast.makeText(this, "權限申請成功!", Toast.LENGTH_SHORT).show();
            }
            break;
    }
}

第三方庫EasyPermissions

  • EasyPermissions庫是一個方便開發者爲App高效處理危險權限的庫,可用於在Android M或者更高版本上。

GitHub地址:https://github.com/googlesamples/easypermissions

依賴:implementation 'pub.devrel:easypermissions:2.0.1

使用步驟

1.申請權限
String PERMISSION_STORAGE_MSG = "請授予權限,否則影響部分使用功能";
int PERMISSION_STORAGE_CODE = 10001;
String[] PERMS = {Manifest.permission.CAMERA, Manifest.permission.ACCESS_FINE_LOCATION};
if (EasyPermissions.hasPermissions(this, PERMS)) {
    // 已經申請過權限,做想做的事

} else {
    // 沒有申請過權限,現在去申請
    /**
     *@param host Context對象
     *@param rationale  權限彈窗上的提示語。
     *@param requestCode 請求權限的唯一標識碼
     *@param perms 一系列權限
     */
    EasyPermissions.requestPermissions(this, PERMISSION_STORAGE_MSG, PERMISSION_STORAGE_CODE, PERMS);
}
2.重寫Activity或Fragment的onRequestPermissionsResult方法
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    //將結果轉發給EasyPermissions
    EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
}
3.實現EasyPermissions.PermissionCallbacks接口,重寫兩個方法
public class MainActivity extends AppCompatActivity implements EasyPermissions.PermissionCallbacks {
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
    
    /**
     * 申請成功時調用
     * @param requestCode 請求權限的唯一標識碼
     * @param perms 一系列權限
     */
    @Override
    public void onPermissionsGranted(int requestCode,List<String> perms) {

    }

    /**
     * 申請拒絕時調用
     * @param requestCode 請求權限的唯一標識碼
     * @param perms 一系列權限
     */
    @Override
    public void onPermissionsDenied(int requestCode,List<String> perms) {

    }
4. @AfterPermissionGranted註解
  • 使用了該註解,當權限請求被用戶同意後,會根據請求code來執行,相應的含有@AfterPermissionGranted註解的方法。

  • 簡化了請求成功操作流程,不需要在EasyPermissions.onRequestPermissionsResult()的回調監聽器中請求成功的方法中,再次手動調用,獲取權限後需要操作的邏輯代碼。

@AfterPermissionGranted(10001)
public void onPermissionSuccess(){
    Toast.makeText(this,"AfterPermission調用成功了",Toast.LENGTH_SHORT).show();
}
5.使用EasyPermissions處理權限被拒
@Override
public void onPermissionsDenied(int requestCode, List<String> perms) {
    /**
     * 若是在權限彈窗中,用戶勾選了'不在提示',且拒絕權限。
     * 這時候,需要跳轉到設置界面去,讓用戶手動開啓。
     */
    if (EasyPermissions.somePermissionPermanentlyDenied(this, perms)) {
        new AppSettingsDialog.Builder(this).build().show();
    }
}

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if (requestCode == AppSettingsDialog.DEFAULT_SETTINGS_REQ_CODE) {
	    //從設置頁面返回,判斷權限是否申請。
        if (EasyPermissions.hasPermissions(this, PERMS)) {
            Toast.makeText(this, "權限申請成功!", Toast.LENGTH_SHORT).show();
        } else {
            Toast.makeText(this, "權限申請失敗!", Toast.LENGTH_SHORT).show();

        }
    }
}

總結

  • 使用EasyPermissions能更好高效的處理權限,讓開發者在平常開發過程中提升開發效率。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章