1.有關權限
- Normal Permission
這類權限一般不涉及用戶隱私,是無須用戶進行授權的,系統自動幫我們授權,只需要在AndroidMainfest.xml中聲明即可,如訪問網絡,安裝時就授權,無須每次使用時都檢查權限
- Dangerous Permission
一般會涉及用戶隱私,需要用戶進行授權,比如讀取sdcard、訪問通信錄等,在程序運行時要求手動點擊申請權限,也就是運行是時權限,如下:
以上同一組的任何一個權限被授權,其他權限也自動被授權
2.Dangerous Permission實例
對於Dangerous Permission,如:撥打電話時權限Action_CALL,使用時先調用checkSelfPermission檢查權限,沒有權限則申請權限requestPermissions,並回調onRequestPermissionsResult方法
2.1 申請權限
申請權限分以下兩個步驟:
- AndroidManifest.xml中申請權限,如下:
<uses-permission android:name="android.permission.CALL_PHONE" />
- 使用相應的API方法動態申請
採用如下流程:checkSelfPermission(檢查是否已被授予)—>requestPermissions(申請權限)—>onRequestPermissionsResult(自動回調),代碼如下:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button bt = findViewById(R.id.make_call);
bt.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"));
if (checkSelfPermission(Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {
return;
}
startActivity(intent);
} catch (Exception e) {
e.printStackTrace();
}
}
@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 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
call();
} else {
Toast.makeText(this, "Denied Permission", Toast.LENGTH_SHORT).show();
}
break;
default:
}
}
}
PS:如果在運行時授權了權限,但是想手動關閉,可以在設置----應用—找到對應的應用—權限,可以關閉對應的權限