easypermissions -- 谷歌權(quán)限管理框架

是什么?

EasyPermissions是一個包裝器庫,用于簡化針對Android M或更高版本的基本系統(tǒng)權(quán)限邏輯。

引入

dependencies {
    //  AndroidX 的應(yīng)用
    implementation 'pub.devrel:easypermissions:3.0.0'
 
    //  Android 
    implementation 'pub.devrel:easypermissions:2.0.1'
}

使用

基礎(chǔ)

要開始使用EasyPermissions,請讓您的Activity(或Fragment)覆蓋onRequestPermissionsResult方法:

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

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

        // 將結(jié)果轉(zhuǎn)發(fā)給 EasyPermissions
        EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
    }
}

請求權(quán)限

下面的示例顯示了如何同時請求同時具有CAMERAACCESS_FINE_LOCATION權(quán)限的方法的權(quán)限。 有幾件事要注意:

  • 使用EasyPermissions#hasPermissions(...)檢查應(yīng)用程序是否已具有所需的權(quán)限。 此方法可以將任意數(shù)量的權(quán)限作為其最終參數(shù)。
  • 使用EasyPermissions#requestPermissions請求權(quán)限。 此方法將請求系統(tǒng)權(quán)限,并在必要時顯示提供的基本原理字符串。 提供的請求代碼對于該請求應(yīng)該是唯一的,并且該方法可以將任何數(shù)量的權(quán)限作為其最終參數(shù)。
  • 使用AfterPermissionGranted注解。 這是可選的,但為方便起見而提供。 如果授予了給定請求中的所有權(quán)限,則將執(zhí)行所有帶有正確請求代碼注釋的方法(確保具有唯一的請求代碼)。 帶注釋的方法必須為空并且沒有輸入?yún)?shù)(相反,可以使用onSaveInstanceState來保留被抑制參數(shù)的狀態(tài))。 這是為了簡化在授予所有許可權(quán)后需要運行請求方法的常見流程。 也可以通過在onPermissionsGranted回調(diào)上添加邏輯來實現(xiàn)。
@AfterPermissionGranted(RC_CAMERA_AND_LOCATION)
private void methodRequiresTwoPermission() {
    String[] perms = {Manifest.permission.CAMERA, Manifest.permission.ACCESS_FINE_LOCATION};
    if (EasyPermissions.hasPermissions(this, perms)) {
        // 已經(jīng)有權(quán)限,進(jìn)行相關(guān)操作
        // ...
    } else {
        // 沒有權(quán)限,進(jìn)行權(quán)限請求
        EasyPermissions.requestPermissions(this, getString(R.string.camera_and_location_rationale),
                RC_CAMERA_AND_LOCATION, perms);
    }
}

或者,為了更好地控制對話框,請使用PermissionRequest:

EasyPermissions.requestPermissions(
        new PermissionRequest.Builder(this, RC_CAMERA_AND_LOCATION, perms)
                .setRationale(R.string.camera_and_location_rationale)
                .setPositiveButtonText(R.string.rationale_ask_ok)
                .setNegativeButtonText(R.string.rationale_ask_cancel)
                .setTheme(R.style.my_fancy_style)
                .build());

(可選)為獲得更好的控件,您可以讓Activity / Fragment實現(xiàn)PermissionCallbacks接口。

public class MainActivity extends AppCompatActivity implements EasyPermissions.PermissionCallbacks {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

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

        // 將結(jié)果轉(zhuǎn)發(fā)給 EasyPermissions
        EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
    }

    @Override
    public void onPermissionsGranted(int requestCode, List<String> list) {
        // 授予權(quán)限
        // ...
    }

    @Override
    public void onPermissionsDenied(int requestCode, List<String> list) {
        // 請求權(quán)限被拒
        // ...
    }
}

拒絕權(quán)限的情況下

在某些情況下,如果沒有某些權(quán)限,您的應(yīng)用將無法正常運行。 如果用戶使用“不再詢問”選項拒絕這些權(quán)限,則您將無法從用戶那里請求這些權(quán)限,因此必須在應(yīng)用程序設(shè)置中進(jìn)行更改。 您可以使用方法EasyPermissions.somePermissionPermanentlyDenied(...)在這種情況下向用戶顯示對話框,并將其定向到您應(yīng)用的系統(tǒng)設(shè)置屏幕:

注意:由于Android框架權(quán)限API提供的信息的限制,somePermissionPermanentlyDenied方法僅在權(quán)限被拒絕并且您的應(yīng)用程序已收到onPermissionsDenied回調(diào)后才有效。 否則,庫無法將永久拒絕與“尚未拒絕”情況區(qū)分開。

@Override
public void onPermissionsDenied(int requestCode, List<String> perms) {
    Log.d(TAG, "onPermissionsDenied:" + requestCode + ":" + perms.size());

    // 可選)檢查用戶是否拒絕了任何權(quán)限并選中了“永不再次詢問”。
    //這將顯示一個對話框,指導(dǎo)他們啟用應(yīng)用程序設(shè)置中的權(quán)限。
    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) {
        //用戶從應(yīng)用設(shè)置屏幕返回后,執(zhí)行一些操作,例如顯示Toast.
        Toast.makeText(this, R.string.returned_from_app_settings_to_activity, Toast.LENGTH_SHORT)
                .show();
    }
}

與對話框交互

如果要與基本對話框進(jìn)行交互,請實現(xiàn)EasyPermissions.RationaleCallbacks。

@Override
public void onRationaleAccepted(int requestCode) {
    // 請求權(quán)限被允許
    // ...
}

@Override
public void onRationaleDenied(int requestCode) {
    // 請求權(quán)限被拒絕
    // ...
}

基本原理回調(diào)不一定意味著權(quán)限更改。 要檢查這些內(nèi)容,請參見EasyPermissions.PermissionCallbacks

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容