第三方库EasyPermissions
参考链接:
https://blog.csdn.net/yang_study_first/article/details/101023919(原文地址)
https://jingyan.baidu.com/article/afd8f4de4688af34e386e976.html(权限详解)
GitHub地址:https://github.com/googlesamples/easypermissions
//-------------第一步 引用---------------
AndroidX 需要引用
implementation 'pub.devrel:easypermissions:3.0.0'及以上
其他低版本:
implementation 'pub.devrel:easypermissions:2.0.1
//-------------第二步 设置代码---------------
2.1申请权限
//1.写在顶部, 全局调用
String PERMISSION_STORAGE_MSG = "请授予权限,否则影响部分使用功能";
int PERMISSION_STORAGE_CODE = 10001;//可以自定义
String[] PERMS = {Manifest.permission.CAMERA, Manifest.permission.ACCESS_FINE_LOCATION};//相机权限;允许一个程序访问精良位置权限(如GPS)
或者 如果爆红就写下面这个
String[] PERMS = {android.Manifest.permission.CAMERA, android.Manifest.permission.ACCESS_FINE_LOCATION};//相机权限;允许一个程序访问精良位置权限(如GPS)
//2.写在调用的位置
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.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);
}
2.3实现第三方插件 EasyPermissions.PermissionCallbacks 的接口,重写两个方法
public class 你的Activity extends 继承的Activity 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) {
}
2.4
@AfterPermissionGranted注解
-
使用了该注解,当权限请求被用户同意后,会根据请求code来执行,相应的含有@AfterPermissionGranted注解的方法
-
这个插件的新版本简化了请求成功操作流程,不需要在EasyPermissions.onRequestPermissionsResult()的回调监听器中请求成功的方法中,再次手动调用,获取权限后需要操作的逻辑代码。
@AfterPermissionGranted(10001)//与上面的 PERMISSION_STORAGE_CODE= 10001; 保持一致
public void onPermissionSuccess(){
Toast.makeText(this,"AfterPermission调用成功了",Toast.LENGTH_SHORT).show();
}
2.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();
}
}
}
//到这里就完成了, 删除原来的包重启试一下