Android开发

easypermissions -- 谷歌权限管理框架

2020-03-20  本文已影响0人  一缕阳忆往昔

是什么?

EasyPermissions是一个包装器库,用于简化针对Android M或更高版本的基本系统权限逻辑。

引入

dependencies {
    //  AndroidX 的应用
    implementation 'pub.devrel:easypermissions:3.0.0'
 
    //  Android 
    implementation 'pub.devrel:easypermissions:2.0.1'
}

使用

基础

要开始使用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);

        // 将结果转发给 EasyPermissions
        EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
    }
}

请求权限

下面的示例显示了如何同时请求同时具有CAMERAACCESS_FINE_LOCATION权限的方法的权限。 有几件事要注意:

@AfterPermissionGranted(RC_CAMERA_AND_LOCATION)
private void methodRequiresTwoPermission() {
    String[] perms = {Manifest.permission.CAMERA, Manifest.permission.ACCESS_FINE_LOCATION};
    if (EasyPermissions.hasPermissions(this, perms)) {
        // 已经有权限,进行相关操作
        // ...
    } else {
        // 没有权限,进行权限请求
        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实现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);

        // 将结果转发给 EasyPermissions
        EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
    }

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

    @Override
    public void onPermissionsDenied(int requestCode, List<String> list) {
        // 请求权限被拒
        // ...
    }
}

拒绝权限的情况下

在某些情况下,如果没有某些权限,您的应用将无法正常运行。 如果用户使用“不再询问”选项拒绝这些权限,则您将无法从用户那里请求这些权限,因此必须在应用程序设置中进行更改。 您可以使用方法EasyPermissions.somePermissionPermanentlyDenied(...)在这种情况下向用户显示对话框,并将其定向到您应用的系统设置屏幕:

注意:由于Android框架权限API提供的信息的限制,somePermissionPermanentlyDenied方法仅在权限被拒绝并且您的应用程序已收到onPermissionsDenied回调后才有效。 否则,库无法将永久拒绝与“尚未拒绝”情况区分开。

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

    // 可选)检查用户是否拒绝了任何权限并选中了“永不再次询问”。
    //这将显示一个对话框,指导他们启用应用程序设置中的权限。
    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) {
        //用户从应用设置屏幕返回后,执行一些操作,例如显示Toast.
        Toast.makeText(this, R.string.returned_from_app_settings_to_activity, Toast.LENGTH_SHORT)
                .show();
    }
}

与对话框交互

如果要与基本对话框进行交互,请实现EasyPermissions.RationaleCallbacks。

@Override
public void onRationaleAccepted(int requestCode) {
    // 请求权限被允许
    // ...
}

@Override
public void onRationaleDenied(int requestCode) {
    // 请求权限被拒绝
    // ...
}

基本原理回调不一定意味着权限更改。 要检查这些内容,请参见EasyPermissions.PermissionCallbacks

上一篇 下一篇

猜你喜欢

热点阅读