• Android 6.0+ 运行时权限


    1.权限被分为了普通和危险两种

    2.打电话的Demo

    import android.Manifest;
    import android.app.Activity;
    import android.content.Intent;
    import android.content.pm.PackageManager;
    import android.net.Uri;
    import android.os.Bundle;
    import android.provider.Settings;
    import android.support.v4.app.ActivityCompat;
    import android.support.v4.content.ContextCompat;
    import android.text.TextUtils;
    import android.view.View;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;
    
    public class MainActivity extends Activity {
    
        private static final int MY_PERMISSIONS_REQUEST_CALL_PHONE = 1;
        private Button btn_dial;
        private EditText et_number;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            // 找到控件
            et_number = (EditText) findViewById(R.id.et_number);
            btn_dial = (Button) findViewById(R.id.btn_dial);
    
            // 给按钮设置监听(点击事件)
            btn_dial.setOnClickListener(new View.OnClickListener() { // 匿名内部类
                // 按钮点击时回调
                @Override
                public void onClick(View view) {
                    // 检查是否获得了权限(Android6.0运行时权限)
                    if (ContextCompat.checkSelfPermission(MainActivity.this,
                            Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED){
                        // 没有获得授权,申请授权
                        if (ActivityCompat.shouldShowRequestPermissionRationale(MainActivity.this,
                                Manifest.permission.CALL_PHONE)) {
                            // 返回值:
    //                          如果app之前请求过该权限,被用户拒绝, 这个方法就会返回true.
    //                          如果用户之前拒绝权限的时候勾选了对话框中”Don’t ask again”的选项,那么这个方法会返回false.
    //                          如果设备策略禁止应用拥有这条权限, 这个方法也返回false.
                            // 弹窗需要解释为何需要该权限,再次请求授权
                            Toast.makeText(MainActivity.this, "请授权!", Toast.LENGTH_LONG).show();
    
                            // 帮跳转到该应用的设置界面,让用户手动授权
                            Intent intent = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
                            Uri uri = Uri.fromParts("package", getPackageName(), null);
                            intent.setData(uri);
                            startActivity(intent);
                        }else{
                            // 不需要解释为何需要该权限,直接请求授权
                            ActivityCompat.requestPermissions(MainActivity.this,
                                    new String[]{Manifest.permission.CALL_PHONE},
                                    MY_PERMISSIONS_REQUEST_CALL_PHONE);
                        }
                    }else {
                        // 已经获得授权,可以打电话
                        CallPhone();
                    }
                }
            });
        }
    
        private void CallPhone() {
            String number = et_number.getText().toString();
            if (TextUtils.isEmpty(number)) {
                // 提醒用户
                // 注意:在这个匿名内部类中如果用this则表示是View.OnClickListener类的对象,
                // 所以必须用MainActivity.this来指定上下文环境。
                Toast.makeText(MainActivity.this, "号码不能为空!", Toast.LENGTH_SHORT).show();
            } else {
                // 拨号:激活系统的拨号组件
                Intent intent = new Intent(); // 意图对象:动作 + 数据
                intent.setAction(Intent.ACTION_CALL); // 设置动作
                Uri data = Uri.parse("tel:" + number); // 设置数据
                intent.setData(data);
                startActivity(intent); // 激活Activity组件
            }
        }
    
        // 处理权限申请的回调
        @Override
        public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
            switch (requestCode){
                case MY_PERMISSIONS_REQUEST_CALL_PHONE: {
                    if (grantResults.length > 0
                            && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                        // 授权成功,继续打电话
                        CallPhone();
                    } else {
                        // 授权失败!
                        Toast.makeText(this, "授权失败!", Toast.LENGTH_LONG).show();
                    }
                    break;
                }
            }
    
        }
    }
    

      

  • 相关阅读:
    s3c2440——按键中断
    s3c2440——swi异常
    S3C2440的七种模式之——未定义模式(去掉bl print1 bug解决)
    Entity Framework DBContext 增删改查深度解析
    Git换行符是如何精确控制的
    Entity Framework 乐观并发处理
    Session, Token and SSO 有什么区别
    2017让我受益最大的那些书--别找了,都在这里
    GDB scheduler-locking 命令详解
    Java web servers 间是如何实现 session 同步的
  • 原文地址:https://www.cnblogs.com/ganchuanpu/p/7123664.html
Copyright © 2020-2023  润新知