Android学习笔记-Android6.0运行时权限(续)

如果在项目开发中,像上篇blog那样,每次需要权限的时候,就申请一下,那未免也太麻烦了,运行时权限依附于Activity,所以,我们尝试着封装一下。
首先来看看之前的代码:

public class MainActivity extends AppCompatActivity {

    private Button buttonCall;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        buttonCall = (Button) findViewById(R.id.ButtonCall);
        buttonCall.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //判断时候是否有“打电话权限”
                if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {
                    //没有权限,就申请权限
                    ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.CALL_PHONE}, 1);
                } else {
                    //有权限,调用打电话方法
                    MakeCall();
                }
            }
        });
    }
    public void MakeCall(){
       try {
           Intent intent = new Intent(Intent.ACTION_CALL);
           intent.setData(Uri.parse("tel:0123456789"));
           startActivity(intent);
       }catch (SecurityException e){
           e.printStackTrace();
       }
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        switch (requestCode){
            case 1:
                //判断时候是否有“打电话权限”
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){

                    //有权限,调用打电话方法
                    MakeCall();
                }else{
                    //没有权限,给一个Toast提示
                    Toast.makeText(this,"您拒绝了权限",Toast.LENGTH_SHORT).show();
                }
                break;
            default:
                break;
        }
    }
}

前面的好封装,但是,onRequestPermissionsResult()就很难搞定了,因为它是重写了Activity的方法,(AppCompatActivity是Activity的子类),它必须依附于Activity。那么怎么搞定呢?

这里,有三种途径:

1. 弄一个透明的Activity,它覆盖于当前Activity之上,专门用于权限申请

2. 通过Fragment,我们都知道,碎片依附于Activity,在Fragment中也有onRequestPermissionsResult()的方法

3. 写一个BaseActivity,所有的Activity都继承这个父类

今天要重点说的,就是第三种方法:

首先,BaseActivity中写一个申请权限的Requrst方法,然后重写onRequestPermissionsResult()
其次,写一个接口,用来实现回调机制,是否授权
最后,在需要授权的地方调用前面写的Requrst方法。

PermissionListener接口:

public interface PermissionListener {
    void onGranted();
    void onDenied(List<String> DeniedPermissionList);
}

BaseActivity:

public class BaseActivity extends AppCompatActivity {

    private  PermissionListener mlistener;
    public void RequestPermission(String [] permissions,PermissionListener listener){
        mlistener = listener;
        List<String> ListPermission = new ArrayList<>();
        for (String permission: permissions) {

            if (ContextCompat.checkSelfPermission(this,permission) != PackageManager.PERMISSION_GRANTED){
                ListPermission.add(permission);
            }
        }
        if (!ListPermission.isEmpty()){

            ActivityCompat.requestPermissions(this,ListPermission.toArray(new String[ListPermission.size()]),1);

        }else{
            listener.onGranted();
        }
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        switch (requestCode){
            case 1:
                if (grantResults.length>0){
                    List<String> deniedPermission = new ArrayList<>();
                    for (int i = 0; i <grantResults.length ; i++) {
                        int grantResult = grantResults[i];
                        String permissoin = permissions[i];
                        if (grantResult != PackageManager.PERMISSION_GRANTED){
                            deniedPermission.add(permissoin);
                        }
                    }
                    if (deniedPermission.isEmpty()){
                        mlistener.onGranted();
                    }else{
                        mlistener.onDenied(deniedPermission);
                    }
                }
                break;
            default:
                break;
        }
    }
}

最后,调用的时候,干净利落

public class MainActivity extends BaseActivity {
  @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        findViewById(R.id.buttonOnClick).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                RequestPermission(new String[]{Manifest.permission.CALL_PHONE,Manifest.permission.ACCESS_FINE_LOCATION}, new PermissionListener() {
                @Override
                    public void onGranted() {
                        makeCall();
                    }

                    @Override
                    public void onDenied(List<String> DeniedPermissionList) {

                        for (String permission:DeniedPermissionList) {
                            Toast.makeText(MainActivity.this,"拒绝了权限:"+permission,Toast.LENGTH_SHORT).show();
                        }
                    }
                });
            }
        });
    }
    private  void makeCall(){

        try {
            Intent intent = new Intent(Intent.ACTION_CALL);
            intent.setData(Uri.parse("tel:123456789"));
            startActivity(intent);
        } catch (SecurityException e) {
            e.printStackTrace();
        }
    }
}

到这里,封装就结束了。


后记:

其实,把BaseActivity中的RequestPermission()方法设置成静态,在其他非Activity中也能调用,只是获取当前Activity有点困难,解决方法就是写一个ActivityCollector,作为活动管理器,当CreateActivity时候,添加到这个活动管理器中,然后回事随地就可以知道当前活动的Activity。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值