Android6.0权限封装使用

Android6.0权限封装使用

随着 Android6.0发布以及普及,我们开发者所要应对的主要就是新版本SDK带来的一些变化,首先关注的就是权限机制的变化。对于6.0的几个主要的变化,查看查看官网的这篇文章 http://developer.android.com/intl/zh-cn/about/versions/marshmallow/android-6.0-changes.html,其中当然包含 Runtime Permissions

运行时权限的变化及特点

对于6.0以下的权限及在安装的时候,根据权限声明产生一个权限列表,用户只有在同意之后才能完成app的安装,造成了我们想要使用某个app,就要默默忍受其一些不必要的权限(比如是个app都要访问通讯录、短信等)。而在6.0以后,我们可以直接安装,当app需要我们授予不恰当的权限的时候,我们可以予以拒绝(比如:单机的象棋对战,请求访问任何权限,我都是不同意的)。当然你也可以在设置界面对每个app的权限进行查看,以及对单个权限进行授权或者解除授权。

新的权限机制更好的保护了用户的隐私,Google将权限分为两类,一类是Normal Permissions,这类权限一般不涉及用户隐私,是不需要用户进行授权的,比如手机震动、访问网络等;另一类是Dangerous Permission,一般是涉及到用户隐私的,需要用户进行授权,比如读取sdcard、访问通讯录等。

权限的封装:

我们可以在BaseActivity的去封装使用的权限,然后子Activity可以直接使用。

分为下面几个步骤:

1、检查SDK版本

2、判断是否有权限

3、请求权限

4、权限回调

代码如下:

BaseActivity.java

public class BaseActivity extends AppCompatActivity{


    public static final int CODE_CAMERA = 1;
    public static final int CODE_READ_EXTERNAL_STORAGE = 2;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    //检查SDK版本是否大于6.0
    public boolean checkSDKVersion(){

        if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.M){
            return true;
        }else {
            return false;
        }
    }

    //判断是否有权限
    public boolean hasPermession(String... permissions){
        for (String permission:permissions){
            if (ContextCompat.checkSelfPermission(this,permission)!= PackageManager.PERMISSION_GRANTED){
                return false;
            }
        }
        return true;
    }


    //没有权限,进行请求
    protected void requestPermissoin(int code,String... permission){
        if (checkSDKVersion()) {
            ActivityCompat.requestPermissions(this, permission, code);
            Toast.makeText(this, "如果拒绝授权,会导致应用无法正常使用", Toast.LENGTH_SHORT).show();
        }
    }

    //请求权限之后的回调
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        switch (requestCode){
            case CODE_CAMERA:
                //请求相机回调
                if (grantResults[0] == PackageManager.PERMISSION_GRANTED){
                    Toast.makeText(this, "现在你已经拥有的权限", Toast.LENGTH_SHORT).show();
                    //这里写业务逻辑
                    text();
                }else {
                    Toast.makeText(this, "你拒绝的授权此权限", Toast.LENGTH_SHORT).show();
                }
                break;
            case CODE_READ_EXTERNAL_STORAGE:
                //另一个权限回调
                break;


        }
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    }

    public void text() {
    }

MainActivity.java

public class MainActivity extends BaseActivity {

    private TextView tvPermission;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);

        tvPermission = (TextView) findViewById(R.id.tv_permission);

        if (hasPermession(Manifest.permission.CAMERA, Manifest.permission.READ_EXTERNAL_STORAGE)) {
            text();
        } else {
            requestPermissoin(CODE_CAMERA, Manifest.permission.CAMERA);
        }
    }
    @Override
    public void text() {
        super.text();
        tvPermission.setText("已经获取权限");
    }
}

如图:



猜你喜欢

转载自blog.csdn.net/q1454739828/article/details/63252345
今日推荐