首语
- Android现在将所有的权限归为了两类,一类是普通权限,一类是危险权限。对于普通权限,系统会自动帮我们进行授权,不需要手动操作。对于危险权限,必须要由用户手动进行点击授权才可以,否则程序无法完成相应的功能。
- Android 6.0系统中加入了运行时权限功能,在使用过程中再对危险权限进行授权。罗列Android中所有的危险权限,一共是9组24个权限,如图:
Android申请权限
- 首先必须在AndroidManifest文件中添加对应权限。
if(ContextCompat.checkSelfPermission(this,Manifest.permission.CAMERA)!=PackageManager.PERMISSION_GRANTED){
ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.CAMERA},10001);
}else {
//权限申请成功,做相应功能
}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
switch (requestCode){
case 10001:
if (grantResults.length>0&&grantResults[0]==PackageManager.PERMISSION_GRANTED){
//做相应功能
}else {
Toast.makeText(this, "权限申请成功!", Toast.LENGTH_SHORT).show();
}
break;
}
}
第三方库EasyPermissions
- EasyPermissions库是一个方便开发者为App高效处理危险权限的库,可用于在Android M或者更高版本上。
GitHub地址:https://github.com/googlesamples/easypermissions
依赖:implementation 'pub.devrel:easypermissions:2.0.1
'
使用步骤
1.申请权限
String PERMISSION_STORAGE_MSG = "请授予权限,否则影响部分使用功能";
int PERMISSION_STORAGE_CODE = 10001;
String[] PERMS = {Manifest.permission.CAMERA, Manifest.permission.ACCESS_FINE_LOCATION};
if (EasyPermissions.hasPermissions(this, PERMS)) {
// 已经申请过权限,做想做的事
} else {
// 没有申请过权限,现在去申请
/**
*@param host Context对象
*@param rationale 权限弹窗上的提示语。
*@param requestCode 请求权限的唯一标识码
*@param perms 一系列权限
*/
EasyPermissions.requestPermissions(this, PERMISSION_STORAGE_MSG, PERMISSION_STORAGE_CODE, PERMS);
}
2.重写Activity或Fragment的onRequestPermissionsResult方法
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
//将结果转发给EasyPermissions
EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);
}
3.实现EasyPermissions.PermissionCallbacks接口,重写两个方法
public class MainActivity extends AppCompatActivity implements EasyPermissions.PermissionCallbacks {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
/**
* 申请成功时调用
* @param requestCode 请求权限的唯一标识码
* @param perms 一系列权限
*/
@Override
public void onPermissionsGranted(int requestCode,List<String> perms) {
}
/**
* 申请拒绝时调用
* @param requestCode 请求权限的唯一标识码
* @param perms 一系列权限
*/
@Override
public void onPermissionsDenied(int requestCode,List<String> perms) {
}
4. @AfterPermissionGranted注解
-
使用了该注解,当权限请求被用户同意后,会根据请求code来执行,相应的含有@AfterPermissionGranted注解的方法。
-
简化了请求成功操作流程,不需要在EasyPermissions.onRequestPermissionsResult()的回调监听器中请求成功的方法中,再次手动调用,获取权限后需要操作的逻辑代码。
@AfterPermissionGranted(10001)
public void onPermissionSuccess(){
Toast.makeText(this,"AfterPermission调用成功了",Toast.LENGTH_SHORT).show();
}
5.使用EasyPermissions处理权限被拒
@Override
public void onPermissionsDenied(int requestCode, List<String> perms) {
/**
* 若是在权限弹窗中,用户勾选了'不在提示',且拒绝权限。
* 这时候,需要跳转到设置界面去,让用户手动开启。
*/
if (EasyPermissions.somePermissionPermanentlyDenied(this, perms)) {
new AppSettingsDialog.Builder(this).build().show();
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == AppSettingsDialog.DEFAULT_SETTINGS_REQ_CODE) {
//从设置页面返回,判断权限是否申请。
if (EasyPermissions.hasPermissions(this, PERMS)) {
Toast.makeText(this, "权限申请成功!", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(this, "权限申请失败!", Toast.LENGTH_SHORT).show();
}
}
}
总结
- 使用EasyPermissions能更好高效的处理权限,让开发者在平常开发过程中提升开发效率。