Android 6.0动态申请权限(超简洁)

本文介绍了Android 6.0及更高版本中动态申请权限的方法,通过`shouldShowRequestPermissionRationale`函数分析了权限请求的几种响应情况,并提供了相关代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上图
在这里插入图片描述
上代码:

public class MainActivity extends AppCompatActivity {
    private static final String TAG = "MainActivity";
    Button btn;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn=findViewById(R.id.gain_permission);
        btn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                if (hasPermisson()){
                    Toast.makeText(MainActivity.this, "我有权限", Toast.LENGTH_SHORT).show();
                }else {
                    requestPermission();
                }
            }
        });
    }
    /*
    * 判断是否有权限
    * */
    private boolean hasPermisson(){
        if (Build.VERSION.SDK_INT>=Build.VERSION_CODES.M){
            return checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE)== PackageManager.PERMISSION_GRANTED;
        }else {
            return true;
        }
    }
    /*
    *
    * 请求权限
    * */
    private void requestPermission(){
        if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.M){
          /*  if (shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE)!=true){
                Toast.makeText(this, "请在设置中配置授权", Toast.LENGTH_SHORT).show();
            }*/
            requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE,},1);
        }
    }
}

shouldShowRequestPermissionRationale(String permission):
根据测试shouldShowRequestPermissionRationale的返回值主要以下几种情况 :

第一次打开App时	                                false
上次弹出权限点击了禁止(但没有勾选“下次不在询问”)	true
上次选择禁止并勾选:下次不在询问	                false

把注释部分取消掉注释在运行一次,效果图:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值