android动态权限申请编译版本,android6.0权限动态申请框架permissiondispatcher的方法...

1,添加依赖

在project的build.gradle文件中添加

dependencies {

classpath 'com.android.tools.build:gradle:2.1.2'

classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'

}

在module的build.gradle中添加

apply plugin: 'android-apt'

。。。。。。。

dependencies {

。。。。

compile 'com.github.hotchemi:permissionsdispatcher:2.3.1'

apt 'com.github.hotchemi:permissionsdispatcher-processor:2.3.1'

}

2,添加注解

package com.shilian.yibo;

import ....

/**

* 主页面

*/

@RuntimePermissions

public class MainActivity extends BaseActivity implements CompoundButton.OnCheckedChangeListener, View.OnClickListener {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

ButterKnife.bind(this);

.....

}

@OnClick(R.id.textView_scan_code_home)

public void onClick(View view) {

switch (view.getId()){

case R.id.textView_scan_code_home:

MainActivityPermissionsDispatcher.startScanWithCheck(this);

break;

}

}

@NeedsPermission(android.Manifest.permission.CAMERA)

void startScan() {

startActivityForResult(new Intent(this, CaptureActivity.class), 1);

}

/**

* OnShowRationale注解获取权限时给出提示的方法

* */

@OnShowRationale(android.Manifest.permission.CAMERA)

void showRationaleForCamera(final PermissionRequest request) {

new AlertDialog.Builder(this).setPositiveButton("知道了", new DialogInterface.OnClickListener() {

@Override

public void onClick(DialogInterface dialog, int which) {

request.proceed();

}

}).setMessage("扫码需要获取相机权限").setCancelable(true).show();

}

/**

* OnPermissionDenied注解拒绝授权时回调的方法

* */

@OnPermissionDenied(android.Manifest.permission.CAMERA)

void onCameraDenied() {

toast("相机权限未开启");

}

/**

* OnNeverAskAgain注解当用户选择拒绝且不再询问时的回调方法

* */

@OnNeverAskAgain(android.Manifest.permission.CAMERA)

void onCameraNeverAskAgain() {

toast("相机权限未开启");

}

@Override

public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {

super.onRequestPermissionsResult(requestCode, permissions, grantResults);

MainActivityPermissionsDispatcher.onRequestPermissionsResult(this,requestCode,grantResults);

}

}

注释说明

RuntimePermissions:必须的注释,用来注释要获取权限的activity或fragment

NeedsPermission:必须的注释,用来注释需要获取权限的方法

OnShowRationale:非必须的注释,提示用户为何要开启此权限,当用户拒绝后在册需要访问权限时调用

OnPermissionDenied:非必须的注释,用户选择拒绝时的提示

OnNeverAskAgain:非必须的注释,用户选择不再询问后的提示

获取权限的调用:从新编译程序会生成辅助类xxxPermissionsDispatcher,通过xxxPermissionsDispatcher.xxxWithCheck方法调用,同时重写onRequestPermissionsResult方法,在其中调用onRequestPermissionsResult的onRequestPermissionsResult方法,传回获取权限的结果。

以上这篇android6.0权限动态申请框架permissiondispatcher的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android是一个开放的移动操作系统,爱好者和开发者可以根据自己的需求进行定制和开发。在Android开发中,JavaPoet是一个非常有用的库,可以动态生成Java代码,简化一些重复的工作。而AOP(面向切面编程)则是一种编程范式,可以将横切关注点与业务逻辑分离,提高代码的可复用性和可维护性。 动态权限申请Android开发中经常遇到的一个问题。在Android系统中,一些敏感的操作和资源访问需要动态申请权限,以确保用户的隐私和安全。传统的权限申请方式是在每个需要权限的地方都进行判断和申请,这样会导致代码的冗余和可读性的下降。使用AOP结合JavaPoet可以实现动态权限申请的解决方案。 首先,我们可以通过AOP在需要权限方法周围添加一个切面,用于检查和申请权限。通过AspectJ等AOP框架,我们可以定义一个切面,在方法执行之前和之后执行相应的逻辑。 然后,利用JavaPoet动态生成申请权限的代码。我们可以定义一个注解,用于标识需要权限方法。在AOP切面中,当检测到方法上有该注解时,生成相应的权限申请代码。 最后,在代码编译阶段,通过JavaPoet生成的代码会自动插入到原始代码中。这样,我们就可以在运行时动态地进行权限申请了。 通过以上的实践,我们可以实现动态权限申请的功能,同时可以减少重复的代码,并提高代码的可维护性。使用JavaPoet和AOP相结合的方式,可以使我们的开发变得更加高效和便捷。它们为Android开发带来了更多的灵活性和扩展性,帮助我们更好地应对权限申请的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值