温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Android基于注解6.0权限动态请求框架的示例分析

发布时间:2021-08-09 09:31:25 来源:亿速云 阅读:102 作者:小新 栏目:移动开发

这篇文章主要介绍Android基于注解6.0权限动态请求框架的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

先上图,看看效果。。。第一次录制,效果比较差,请将就下。可下载源码进行亲自操作。

Android基于注解6.0权限动态请求框架的示例分析

示例图

如何接入

1、在项目的gradle中添加如下代码

buildscript {
  repositories {
    google()
    jcenter()
  }
  dependencies {
    classpath 'com.android.tools.build:gradle:3.0.0'
    classpath 'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:1.1.0' //添加这一行
  }
}

allprojects {
  repositories {
    google()
    jcenter()
    maven { url 'https://jitpack.io' }   //添加这一行
  }
}

值得一提:如果你的工程里gradle版本是3.0.0以上,请使用aspectjx:1.1.0以上版本,否则会报Required: PROJECT, SUB_PROJECTS, EXTERNAL_LIBRARIES. Found: EXTERNAL_LIBRARIES, PROJECT, PROJECT_LOCAL_DEPS, SUB_PROJECTS, SUB_PROJECTS_LOCAL_DEPS

aspectjx历史版本查看地址:https://github.com/HujiangTechnology/gradle_plugin_android_aspectjx/blob/master/CHANGELOG.md

2、在app的module中增加如下

代码

apply plugin: 'com.android.application'
apply plugin: 'android-aspectjx' //添加这一行

在依赖中增加:

compile 'com.github.zincPower:JPermission:0.1'

简单使用

1、在需要请求权限的方法加上注解 @Permission,请求权限可以多个,如下

//requestCode可设可不设,框架自带默认值。在取消和拒绝回调中,会将这个值返回,用于各自请求逻辑处理
@Permission({Manifest.permission.WRITE_EXTERNAL_STORAGE}, requestCode = 100)
private void requestOnePermission() {
  //do something
}

2、编写取消和拒绝(即点击了“不再提示”)回调,如下:

@PermissionCanceled()
private void cancel(CancelInfo cancelInfo) {
  //do something when the permission was canceled.
}

@PermissionDenied()
private void deny(DenyInfo denyInfo) {
  //do something when the permission was denied.
}

值得一提:如果被拒绝,可以弹一个对话框,询问是否要前往系统权限页面让用户自己手动开启。如果需要的话,可以通过以下代码前往(对话框自行解决,本框架不包含):

//前往开启权限的界面
JPermissionUtil.goToMenu(context);

高级使用

1、请求manifest中的所有权限(主要用于app开启时,进行一次权限请求)

//不需要回调监听
JPermissionUtil.requestAllPermission(this);

//需要回调监听
JPermissionUtil.requestAllPermission(this, new IPermission() {
      @Override
      public void ganted() {
        Log.i(JPermissionHelper.TAG, "ganted====》申请manifest的全部");
      }

      @Override
      public void denied(int requestCode, List<String> denyList) {
        Log.i(JPermissionHelper.TAG, "denied====》申请manifest的全部{code=" + requestCode + ";denyList=" + denyList + "}");
      }

      @Override
      public void canceled(int requestCode) {
        Log.i(JPermissionHelper.TAG, "canceled===》申请manifest的全部{code= " + requestCode + "}");
      }
    });

某些特殊情况,初始请求中比较敏感(例如:读取手机短信 或 定位权限 等),可以使用以下代码进行剔除初始请求中所包含的权限

List<String> excluePermission = new ArrayList<>();
excluePermission.add(Manifest.permission.CAMERA);
excluePermission.add(Manifest.permission.ACCESS_FINE_LOCATION);
//不需要回调
JPermissionUtil.requestAllPermission(this, excluePermission);

//需要回调
JPermissionUtil.requestAllPermission(this, excluePermission, new IPermission() {
  @Override
  public void ganted() {
    
  }

  @Override
  public void denied(int requestCode, List<String> denyList) {

  }

  @Override
  public void canceled(int requestCode) {

  }
});

2、配置前往的系统权限页,框架自带了默认的系统权限页,但如需根据不同品牌进行个性化设置,可在代码增加如下代码

//第一个参数为品牌,框架会根据Build.MANUFACTURER进行匹配(大小写均可)
//第二个参数为需要处理的类class文件,需要实现IMenu接口
JPermissionUtil.setManuFacturer("genymotion", MyTestGenymotionMenu.class);

3、设置有回调值的取消和拒绝回调。如果请求权限时,填了requestCode=200,则取消或拒绝时会调用requestCode相同(此处即为200)的方法。

@PermissionCanceled(requestCode = 200)
private void cancelCode200(CancelInfo cancelInfo){
  Toast.makeText(this, "cancel__200", Toast.LENGTH_SHORT).show();
}

@PermissionDenied(requestCode = 200)
private void denyCode200(DenyInfo denyInfo){
  Toast.makeText(this, "deny__200", Toast.LENGTH_SHORT).show();
}

值得一提:调用了requestCode相同的方法,同时也会调用不设置requestCode的方法。

4、service和fragment中均可使用

以上是“Android基于注解6.0权限动态请求框架的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI