下表列舉了所有的運行時權限,我們在運行時權限處理使用的是權限名,但是一旦某一個權限被授權了,那麼該權限組中的所有權限都會被授權。
權限組名 | 權限名 |
CALENDAR | READ_CALENDAR |
WRITE_CALENDAR | |
CAMERA | CAMERA |
LOCATION | ACCESS_FINE_LOCATION |
ACCESS_COARSE_LOCATION | |
CONTACTS | READ_CONTACTS |
WRITE_CONTACTS | |
GET_ACCOUNTS | |
PHONE | READ_HPONE_STATE |
CALL_PHONE | |
READ_CALL_LOG | |
WRITE_CALL_LOG | |
ADD_VOICEMAIL | |
USE_SIP | |
PROCESS_OUTGOING_CALLS | |
SENSORS | BODY_SENSORS |
SMS | SEND_SMS |
RECEIVE_SENSORS | |
READ_SENSORS | |
RECEIVE_WAP_PUSH | |
RECEIVE_MMS | |
MICROPHONE | RECORD_AUDIO |
STORAGE | READ_EXTERNAL_STORAGE |
WRITE_EXTERNAL_STORAGE |
示例:打電話權限
首先在manifest中需要配置權限
<uses-permission android:name="android.permission.CALL_PHONE"/>
然後在MainActivity中進行檢測
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();
}
}
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(MainActivity.this, "You denied the permission", Toast.LENGTH_SHORT).show();
}
break;
default:
}
}