Router

Project Url: chenenyu/Router
Introduction: 🚀🚀🚀Simple and flexible router library for Android platform.
More: Author   ReportBugs   
Tags:

Build Status license PullRequest

建议浏览中文 wiki. It's better than you think.

screenshot

Getting started

  • Add dependencies by adding the following lines to your build.gradle:
android {
    defaultConfig {
        ...
        javaCompileOptions {
            annotationProcessorOptions {
                arguments = ["moduleName": project.name]
            }
        }
    }
}

dependencies {
    implementation 'com.chenenyu.router:router:版本号'
    // 每个使用了@Router 注解的 module 都要添加该注解处理器
    annotationProcessor 'com.chenenyu.router:compiler:版本号'
}

latest router version: Download

latest compiler version: compiler

基本用法

  1. 初始化
Router.initialize(new Configuration.Builder()
        // 调试模式,开启后会打印 log
        .setDebuggable(BuildConfig.DEBUG)
        // 模块名(即 project.name),每个使用 Router 的 module 都要在这里注册
        .registerModules("your app module", "your lib module", "other module")
        .build());
  1. 添加拦截器(可选)
@Interceptor("SampleInterceptor")
public class SampleInterceptor implements RouteInterceptor {
    @Override
    public boolean intercept(Context context, RouteRequest routeRequest) {
        // do something
        return false;
    }
}
  1. 添加注解
// 给 Activity 添加注解,指定了路径和拦截器(可选)
@Route(value = "test", interceptors = "SampleInterceptor")
public class TestActivity extends AppCompatActivity {
    @InjectParam(key="foo") // 参数映射
    String foo;

     @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Router.injectParams(this);  // 自动从 bundle 中获取并注入参数
        ...
    }
}

// 给 Fragment 添加注解
@Route("test")
public class TestFragment extends Fragment {
    ...
}
  1. 跳转
// 简单跳转
Router.build("test").go(this);
// startActivityForResult
Router.build("test").requestCode(0).go(this);
// 携带 bundle 参数
Router.build("test").with("key", Object).go(this);
// 添加回调
Router.build("test").go(this, new RouteCallback() {
        @Override
        public void callback(RouteResult state, Uri uri, String message) {
             // do something
        }
});
// 获取路由对应的 intent
Router.build("test").getIntent();
// 获取注解的 Fragment
Router.build("test").getFragment();

进阶用法

Please refer to the wiki for more information.

ProGuard

# Router
-keep class com.chenenyu.router.** {*;}
-keep class * implements com.chenenyu.router.template.ParamInjector {*;}

讨论

QQ group: 271849001

Click here.

License

Apache 2.0

Support Me
Apps
About Me
Google+: Trinea trinea
GitHub: Trinea