权限概要
权限大全:
https://blog.csdn.net/HardWorkingAnt/article/details/70952583
Android现在将所有的权限大致归成了两类, 一类是普通权限, 一类是危险权限。 普通权限指的是那些不会直接威胁到用户的安全和隐私的权限,对于这部分权限申请,系统会自动帮我们进行授权,而不需要用户再去手动操作了, 比如网络权限、通知权限;危险权限则表示那些可能会触及用户隐私或者对设备安全性造成影响的权限, 如获取设备联系人信息、 定位设备的地理位置等, 对于这部分权限申请, 必须要由用户手动点击授权才可以, 否则程序就无法使用相应的功能。
在程序运行时申请权限
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button makeCall = (Button) findViewById(R.id.make_call);
makeCall.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
call();
}
});
}
private void call() {
try {
Intent intent = new Intent(Intent.ACTION_CALL);
intent.setData(Uri.parse("tel:10086"));
startActivity(intent);
} catch (SecurityException e) {
e.printStackTrace();
}
}
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions,int[] grantResults) {
switch (requestCode) {
case 1:
if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED)
call();
else {
Toast.makeText(this, "You denied the permission", Toast.LENGTH_SHORT).show();
}
break;
default:
}
}
}
第一步就是要先判断用户是不是已经给过我们授权了, 借助的是ContextCompat.checkSelfPermission() 方法。 checkSelfPermission() 方法接收两个参数, 第一个参数是Context ,第二个参数是具体的权限名, 比如打电话的权限名就是Manifest.permission.CALL_PHONE,然后使用方法的返回值和PackageManager.PERMISSION_GRANTED 做比较, 相等就说明用户已经授权, 不等就表示用户没有授权。
- 如果授权直接执行拨打电话的逻辑操作
- 如果没有授权的话,则需要调用ActivityCompat.requestPermissions()方法来向用户申请授权,requestPermissions() 方法接收3个参数, 第一个参数要求是Activity的实例,第二个参数是一个String 数组,把要申请的权限名放在数组中, 第三个参数是请求码, 只要是唯一值就可以, 这里传入了1。
第二步就是要处理申请权限后的结果。调用完了requestPermissions() 方法之后,系统会弹出一个权限申请的对话框,然后用户可以选择同意或拒绝权限申请,不论是哪种结果,最终都会回调到onRequestPermissionsResult() 方法中, 而授权的结果则会封装在grantResults 参数当中。 然后只需要判断一下最后的授权结果, 如果用户同意的话就调用call() 方法来拨打电话, 如果用户拒绝的话放弃操作, 并弹出一条失败提示