使用EasyPermissions高效处理权限
16lz
2021-01-26
首语
- 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 { //权限申请成功,做相应功能 }}@Overridepublic 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方法
@Overridepublic 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处理权限被拒
@Overridepublic void onPermissionsDenied(int requestCode, List<String> perms) { /** * 若是在权限弹窗中,用户勾选了'不在提示',且拒绝权限。 * 这时候,需要跳转到设置界面去,让用户手动开启。 */ if (EasyPermissions.somePermissionPermanentlyDenied(this, perms)) { new AppSettingsDialog.Builder(this).build().show(); }}@Overridepublic 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能更好高效的处理权限,让开发者在平常开发过程中提升开发效率。
更多相关文章
- Android自动接听&挂断电话(包含怎么应对4.1以上版本的权限检查)
- Android(安卓)Root分析及防范
- 权限
- Android(安卓)桌面请求录屏权限不唤起App
- Android之Http通信——2.详解Http的消息头与响应头
- android使用主流库搭建应用框架
- Android(安卓)动态权限最全解析
- Android系统使用socket在Java层和native之间数据通信
- Android(安卓)通过URL scheme 实现点击浏览器中的URL链接,启动特