一个轻量级的AOP(Android)应用框架。囊括了最实用的AOP应用。
-
支持快速点击切片
@SingleClick
,支持设置快速点击的时间间隔。 -
支持动态申请权限切片
@Permission
,支持自定义响应动作。 -
支持主线程切片
@MainThread
。 -
支持IO线程切片
@IOThread
,支持多种线程池类型。 -
支持日志打印切片
@DebugLog
,支持自定义日志记录方式。 -
支持内存缓存切片
@MemoryCache
,支持设置缓存大小。 -
支持磁盘缓存切片
@DiskCache
,支持自定义磁盘缓存,缓存有效时间等。 -
支持自动捕获异常的拦截切片
@Safe
,支持设置自定义异常处理者。 -
支持自定义拦截切片
@Intercept
,支持自定义切片拦截。
1.先在项目根目录的 build.gradle 的 repositories 添加:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
2.再在项目根目录的 build.gradle 的 dependencies 添加xaop插件:
buildscript {
···
dependencies {
···
classpath 'com.github.xuexiangjys.XAOP:xaop-plugin:1.1.0'
}
}
3.在项目的 build.gradle 中增加依赖并引用xaop插件
apply plugin: 'com.xuexiang.xaop' //引用xaop插件
dependencies {
···
//如果是androidx项目,使用1.1.0版本及以上
implementation 'com.github.xuexiangjys.XAOP:xaop-runtime:1.1.0'
//如果是support项目,请使用1.0.5版本
implementation 'com.github.xuexiangjys.XAOP:xaop-runtime:1.0.5'
}
4.在Application中进行初始化
XAOP.init(this); //初始化插件
XAOP.debug(true); //日志打印切片开启
XAOP.setPriority(Log.INFO); //设置日志打印的等级,默认为0
//设置动态申请权限切片 申请权限被拒绝的事件响应监听
XAOP.setOnPermissionDeniedListener(new PermissionUtils.OnPermissionDeniedListener() {
@Override
public void onDenied(List<String> permissionsDenied) {
//申请权限被拒绝的处理
}
});
//设置自定义拦截切片的处理拦截器
XAOP.setInterceptor(new Interceptor() {
@Override
public boolean intercept(int type, JoinPoint joinPoint) throws Throwable {
XLogger.d("正在进行拦截,拦截类型:" + type);
switch(type) {
case 1:
//做你想要的拦截
break;
case 2:
return true; //return true,直接拦截切片的执行
default:
break;
}
return false;
}
});
//设置自动捕获异常的处理者
XAOP.setIThrowableHandler(new IThrowableHandler() {
@Override
public Object handleThrowable(String flag, Throwable throwable) {
XLogger.d("捕获到异常,异常的flag:" + flag);
if (flag.equals(TRY_CATCH_KEY)) {
return 100;
}
return null;
}
});
1.在项目根目录的 build.gradle 的 dependencies 添加aspectjx插件:
buildscript {
···
dependencies {
···
classpath 'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.10'
}
}
2.在项目的 build.gradle 中增加依赖并引用aspectjx插件
apply plugin: 'android-aspectjx' //引用aspectjx插件
aspectjx {
include '项目的applicationId'
}
详细使用可参见kotlin-test项目进行使用.