一個用於幫助組件化解耦的輕量框架java
按照慣例,反手就是一個超連接: github地址android
是否會以爲ARouter太過繁雜,功能太多,HEasyRoute即是將ARouter中大部分功能剔除,只留下了Activity的頁面跳轉的一個庫git
以下添加依賴到各模塊的build.gradle:github
1、添加依賴
dependencies {
annotationProcessor 'com.hooyee:easyroute-compile:1.0.1'
compile 'com.hooyee:easyroute-lib:1.0.1'
}
2、添加區分各模塊的參數
android {
...
defaultConfig {
javaCompileOptions {
annotationProcessorOptions {
arguments = [ moduleName : project.getName() ]
}
}
}
...
}
複製代碼
-keepnames class * {
@com.moly.hooyee.annocation.Route <fields>;
}
-keep public class com.moly.hooyee.model.**{*;}
複製代碼
在Application#onCreate()中調用EasyRoute.init(this);bash
在須要路由配置的Activity的類定義上加上註解:@Route(path = "/test")框架
在須要跳轉到路由所標註的Activity的地方調用:EasyRoute.navigation(context, "/test");ide
// 在Application中初始化
public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
EasyRoute.init(this);
}
}
// 具體調用代碼
@Route(path = "test")
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViewById(R.id.btn_test).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
EasyRoute.navigation(getApplicationContext(), "/test/a1");
}
});
findViewById(R.id.btn_test2).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
EasyRoute.navigation(getApplicationContext(), "moudle2/t2");
}
});
}
}
複製代碼
完成以上三步便可跳轉到指定的Activity,跨模塊調用一樣可行組件化
須要注意的是,每一個moudle都須要配置 javaCompileOptions參數gradle