ARouter 是 albaba 团队开源的一个 Android App 组件化改造的一个框架,支持模块之间的路由、通信、拦截功能,相比原生跳转来说更能适应组件化开发,本文主要通过实例总结一下 Arouter 的常用功能,具体如下:
- ARouter的配置
- 应用内跳转
- 应用内携带参数跳转
- Activity返回结果处理
- 通过Uri跳转及参数解析
- Module之间的跳转
- 服务调用
- 显示效果
ARouter的配置
在对应的 build.gradle 文件中配置 ARouter 的相关依赖如下:
android {
defaultConfig {
…
javaCompileOptions {
annotationProcessorOptions {
arguments = [AROUTER_MODULE_NAME: project.getName()]
}
}
}
}
dependencies {
//api与compiler匹配使用,使用最新版可以保证兼容
compile ‘com.alibaba:arouter-api:1.4.0’
annotationProcessor ‘com.alibaba:arouter-compiler:1.2.1’
…
}
可以选择配置路由表自动加载,在项目下面的 build.gradle 文件中进行配置,配置方式如下:
// 路由表自动加载插件
apply plugin: ‘com.alibaba.arouter’
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath ‘com.android.tools.build:gradle:3.0.1’
//ARouter
classpath “com.alibaba:arouter-register:1.0.2”
}
}
此外,还需在 Application 中初始化 ARouter,如下:
@Override
public void onCreate() {
super.onCreate();
// 必须在初始化ARouter之前配置
if (BuildConfig.DEBUG){
// 日志开启
ARouter.openLog();
// 调试模式开启,如果在install run模式下运行,则必须开启调试模式
ARouter.openDebug();
}
ARouter.init(this);
}
应用内跳转
使用 ARouter 进行应用内跳转非常简单,只需要在要跳转的 Activity 上添加 @Route 注解即可,具体如下:
// 配置的path至少需要两级,如/xx/xxx
@Route(path = FirstActivity.PATH)
public class FirstActivity extends AppCompatActivity {
public static final String PATH = “/test/firstActivity”;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_first);
}
}
然后使用 ARouter 提供的跳转方式来进行应用内部之间的跳转,具体如下:
// 应用内跳转
ARouter.getInstance()
.build(FirstActivity.PATH)
.navigation();
应用内携带参数跳转
ARouter 通过 withString 等一系列 with 开头的方法设置与之对应的参数来进行参数传递,具体如下:
// 应用内携带参数跳转
ARouter.getInstance()
.build(SecondActivity.PATH)
.withString(SecondActivity.PARAM, “这是跳转携带的参数”)
.navigation();
然后使用 Intent 在跳转到的 Activity 中使用 Intent 获取传递过来的参数,具体如下:
@Route(path = SecondActivity.PATH)
public class SecondActivity extends AppCompatActivity {
public static final String PATH = “/test/secondActivity”;
public static final String PARAM = “param”;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_second);
Intent intent = getIntent();
if (intent!=null){
String param = intent.getStringExtra(PARAM);
Toast.makeText(this, param, Toast.LENGTH_SHORT).show();
}
}
}
Activity返回结果处理
Activity 返回结果处理和原生几乎一致,即在跳转时携带 requestCode,具体如下:
// Activity返回结果处理
ARouter.getInstance()
.build(ThreeActivity.PATH)
.navigation(this, 100);
然后,在 Activity 返回的时候使用 Intent 携带参数 setResult 即可,具体如下:
@Route(path = ThreeActivity.PATH)
public class ThreeActivity extends AppCompatActivity {
public static final String PATH = “/test/threeActivity”;
public static final String PARAM_RESULT = “param_result”;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_three);
Intent intent = getIntent();
//setResult
intent.putExtra(PARAM_RESULT,“这是返回携带的参数”);
setResult(RESULT_OK,intent);
}
}
通过Uri跳转及参数解析
ARouter 还支持通过 Uri 进行跳转,首先创建一个*面的 Activity 用于监听 Scheme 事件,由该 Activity 进行统一转发 Uri,所有的 Uri 都要通过这里然后进行分发跳转,可以很好的进行 Uri 的控制,一定程度上提高了使用 Uri 跳转的安全性,实行一个*面的 Activiry 如下:
public class SchemeFilterActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Uri uri = getIntent().getData();
// 统一外部跳转的Uri,实现路由器统一分发,减少只依靠Intent属性匹配带来的安全风险
ARouter.getInstance().build(uri).navigation(this, new NavCallback() {
@Override
public void onArrival(Postcard postcard) {
finish();
}
});
}
}
在 AndroidManifest 文件中配置 host、scheme 以及 Action,具体如下:
然后,在 assets 文件夹中创建一个 html 文件,通过点击跳转链接完成 Uri 的跳转,html 内容如下:
跳转测试
自定义Scheme
arouter://test111.manu.com/test/fiveActivity<
《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享
/a>