Router

Additional

Language
Java
Version
1.4.0-beta1 (Feb 9, 2018)
Created
Dec 28, 2016
Updated
Feb 9, 2018
Owner
Half Stack (chenenyu)
Contributors
Half Stack (chenenyu)
leiMsnow
2
Activity
Badge
Generate
Download
Source code
APK file

Promotion

Router

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

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:版本号'
    annotationProcessor 'com.chenenyu.router:compiler:版本号'
}

latest router version:

latest compiler version:

基本用法

  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 {
    ...
}

// 给方法添加注解(类必须实现MethodCallable接口)
public class Foo implements MethodCallable {
    private Context mContext;

    public CallToast(Context context) {
        mContext = context;
    }

    @Route("showToast") // 注解到方法上,方法若有参数,则每个参数必须
    public void toast(@InjectParam(key = "param") String msg) {
        Toast.makeText(mContext, msg, Toast.LENGTH_SHORT).show();
    }
  
    @Route({"showLog"})
    public static void log() {
        Log.i("Foo", "a log shows how to call native static method.");
    }
}
  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(content);
// 获取注解的Fragment
Router.build("test").getFragment(context);

// 通过对象调用方法
Foo foo = new Foo(context);
Router.build("showToast").with("param", "Hello, Router!").go(context, foo); // 调用非静态方法
Router.build("showLog").go(context, foo); // 调用静态方法
// 通过类调用方法(只能调用静态方法)
Router.build("showLog").go(context, MethodCallable.class);

进阶用法

Please refer to the wiki for more informations.

ProGuard

See wiki.

讨论

QQ group: 271849001

License

Apache 2.0