NavRouter
简介
git地址:点我传送
支持给activity绑定url,从而利用url唤起activity,并支持浏览器跳应用页面。可结合Android Studio 2.3 自带的App Links Assistant对url和activity的映射关系进行统一管理,使用详情可参见我的上一篇文章Android Studio 2.3 特性:生成Android App Links
使用
1.集成
由于暂时未将库上传至jCenter,目前需要手动引入navrouter模块进行调用(后期补上)
2.使用
2.1 配置映射关系
在AndroidManifest中配置activity与url的映射关系,其中data标签配置的scheme、host、path即为给定url的相关信息。
可利用Android Studio 2.3中的App Links Assistant进行统一管理,并直接输入url测试是否关联成功。
2.2 调用跳转
直接调用下来方法,传入context和对应的url即可跳转指定的页面
NavRouter.from(context).toUri("http://blog-debug.leozheng.com/test");
2.3 支持获取参数
在activity的oncreate可以通过intent拿到原始的uri,而uri包含了所有参数的信息,使用uri.getQueryParameter(key)就能得到对应的值。
Intent appLinkIntent = getIntent();
String appLinkAction = appLinkIntent.getAction();
Uri appLinkData = appLinkIntent.getData(); //传递原始信息的Uri
由于取出的为String类型,为了方便使用,通过ParamUtils工具类能简单获取给定类型的值。例如:
int year = ParamUtils.getIntExtra(appLinkData, "year", 0);
同样,使用者也可以根据个人的需求,封装其他的方法(如将jsonString转换为对应的实体,这里也就不展开了)。
2.4 支持CallBack
使用者可以利用两种方法实现CallBack
1.在Application中实现NavRouterCallBackFactory,即可实现全局统一控制
public class RouterApplication extends Application implements NavRouterCallBackFactory {
@Override
public NavRouterCallBack provideNavRouterCallBack() {
return new NavRouterCallBack() {
@Override
public boolean beforeOpen() {
Log.d("NavRouter", "beforeOpen from Application");
return true; //此处可添加跳转前置判断
}
@Override
public void afterOpen() {
Log.d("NavRouter", "afterOpen from Application");
}
@Override
public void onError(Intent intent) {
Toast.makeText(getApplicationContext(), "There is no activity matched for " + intent, Toast.LENGTH_SHORT).show();
}
};
}
}
2.在Activity中使用,可根据某一特定activity进行专门配置
* Show the custom NavRouterCallBack.Compared with default callback {@link RouterApplication}
*/
NavRouter.from(MainActivity.this).toUri(((TextView) v).getText().toString(), -1, new NavRouterCallBack() {
@Override
public boolean beforeOpen() {
Log.d("NavRouter", "beforeOpen from " + MainActivity.class.getSimpleName());
Toast.makeText(MainActivity.this, MainActivity.class.getSimpleName() + " was reject in Activity", Toast.LENGTH_SHORT).show();
return false;
}
@Override
public void afterOpen() {
Log.d("NavRouter", "afterOpen from " + MainActivity.class.getSimpleName());
}
@Override
public void onError(Intent intent) {
Log.d("NavRouter", "beforeOpen from " + MainActivity.class.getSimpleName());
}
});
2.5 支持传Bundle
调用NavRouter.from(context).putExtra(key,bundle).toUri(Uri) 可传递Bundle给对应的activity,并用getIntent().getBundleExtra(key)取得对应的Bundle。
2.6 支持外部浏览器及WebView唤起
WebView中唤起可参考Demo中的NavWebViewClient进行自定义定制。而从浏览器唤起时,可通过控制需要唤起的activity的launchMode修改页面的启动模式
开源协议
Apache License 2.0
联系作者
git直接提issue
邮件 zkt713@gmail.com