EasyPermissions的流程,更加详细

看到很多老铁,都在看我写的第一篇文章《EasyPermissions的流程简介和记录》,但是当时也是第一次写文章,有很多不完善的地方,这一次,又对EasyPermissions,进行了一次更加详细的说明,可以直接复制代码测试的,下面看代码吧:
在app的build.gradle文件的dependencies中,添加依赖:
compile 'pub.devrel:easypermissions:0.3.0'

import android.Manifest;
import android.content.Intent;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.widget.Toast;

import java.util.List;

import pub.devrel.easypermissions.AfterPermissionGranted;
import pub.devrel.easypermissions.AppSettingsDialog;
import pub.devrel.easypermissions.EasyPermissions;

public class MainActivity extends AppCompatActivity implements EasyPermissions.PermissionCallbacks{

    private static final int RC_LOCATION = 100;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //进来之后,手动调用申请权限的方法,
        //建议在用到相关功能的时候,才去请求相关权限,提高用户体验
        RequestLocationAndCallPermission();
    }

    //带有这个注释的方法,会在某一次请求的所有权限都通过后,才回调
    @AfterPermissionGranted(RC_LOCATION)
    private void RequestLocationAndCallPermission() {
//        Toast.makeText(this, "RequestLocationAndCallPermission,out", Toast.LENGTH_SHORT).show();
        String[] perms = {Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.ACCESS_COARSE_LOCATION,Manifest.permission.CALL_PHONE};
        if (EasyPermissions.hasPermissions(this, perms)) {
            //用户同意了权限
            //进行后面的操作
        } else {
            //用户拒绝了权限
            //正常情况(没有勾选《拒绝后不再询问》)会先弹下面这个框一,点击确定会出现系统的框二
            //非正常情况(有勾选《拒绝后不再询问》)框一和系统的框二都不会出现
            //无论哪种情况,最终,都会根据用户的选择同意还是拒绝,而回调对应的方法;(勾选过《拒绝后不再询问》,这种情况也是属于拒绝,所以他也会走拒绝的回调)
            EasyPermissions.requestPermissions(this, "请求定位权限和拨打电话权限",RC_LOCATION, perms);
        }
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        // Forward results to EasyPermissions
        // 把请求权限的操作转交给EasyPermissions
        EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
    }


    //一次请求中,只要有一个权限允许了,就会走这个方法
    @Override
    public void onPermissionsGranted(int requestCode, List perms) {
        //用户同意了部分权限,你可以对权限做判断,根据通过的权限,开放相应功能
    }

    //一次请求中,只要有一个权限拒绝了,就会走这个方法
    @Override
    public void onPermissionsDenied(int requestCode, List perms) {
        //如果曾经有勾选《拒绝后不再询问》,则会进入下面这个条件
        //建议做一个判断,判断用户是不是刚刚勾选的《拒绝后不再询问》,如果是,就不做下面这个判断,而只进行相应提示,这样就可以避免再一次弹框,影响用户体验
        //否则就是用户可能在之前曾经勾选过《拒绝后不再询问》,那就可以用下面这个判断,强制弹出一个对话框
        if(EasyPermissions.somePermissionPermanentlyDenied(this,perms)){
            //但是这个api有个问题,他会显示一个对话框,但是这个对话框,点空白区域是可以取消的,如果用户点了空白区域,你就没办法进行后续操作了
            new AppSettingsDialog.Builder(this).build().show();
        }

    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        //EasyPermissions会有一个默认的请求码,根据这个请求码,就可以判断是不是从APP的设置界面过来的
        if (requestCode == AppSettingsDialog.DEFAULT_SETTINGS_REQ_CODE) {
            // Do something after user returned from app settings screen, like showing a Toast.
            //在这儿,你可以再对权限进行检查,从而给出提示,或进行下一步操作
            Toast.makeText(this,"从设置中返回", Toast.LENGTH_SHORT).show();
        }
    }
}

注意,要在清单文件中,添加权限:


你可能感兴趣的:(EasyPermissions的流程,更加详细)