setContentView(R.layout.activity_one);
}
}
第二步:调用 navigation 方法实现跳转
ARouter.getInstance().build(ARouterConstants.COM_ACTIVITY1).navigation();
这样,从 A 跳转到 B 的功能便实现了。
Arouter 的跳转页非常简单,我们可以调用 PostCard 的 withX 等方法传递相应的参数
比如,我们想传递 String,可以调用 withString,想传递 int,可以调用 withInt ,想传递 Parceable 对象,可以调用 withParcelable。
ARouter.getInstance().build(ARouterConstants.COM_PARSE_ACTIVITY).withString(NAME,“jun”)
.withInt(AGE,1).withParcelable(PERSON,person).withObject(TEST_OBJ,testObj)
同时 ARouter 还支持传递 Object 对象,只需调用 withObject 方法,同时需要在我们的 moudle 下面增加相关的类。实际上,它的原理是通过将 object 转化成 String,然后存进 intent 中,在解析参数的时候,再通过相应的 key 去除 String,然后转化成 object。
如果你的项目使用的是 Gson,那可以使用下面的类
@Route(path = “/service/json”)
public class JsonServiceImpl implements SerializationService {
private Gson mGson;
@Override
public void init(Context context) {
mGson = new Gson();
}
@Override
public T json2Object(String text, Class clazz) {
checkJson();
return mGson.fromJson(text, clazz);
}
@Override
public String object2Json(Object instance) {
checkJson();
return mGson.toJson(instance);
}
@Override
public T parseObject(String input, Type clazz) {
checkJson();
return mGson.fromJson(input, clazz);
}
public void checkJson() {
if (mGson == null) {
mGson = new Gson();
}
}
}
如果你的项目使用的是阿里巴巴的 fastjson,那可以在你的项目增加该类。
@Route(path = “/service/json”)
public class JsonServiceImpl implements SerializationService {
@Override
public void init(Context context) {
}
@Override
public T json2Object(String text, Class clazz) {
return JSON.parseObject(text, clazz);
}
@Override
public String object2Json(Object instance) {
return JSON.toJSONString(instance);
}
@Override
public T parseObject(String input, Type clazz) {
return JSON.parseObject(input, clazz);
}
}
在 ActivityB 中获取参数有两种方式
一种是普通 Activity 那样 getIntent().getXXX,这里就不展开了
另外一种是使用 @Autowired 注解的方式
@Route(path = ARouterConstants.COM_PARSE_ACTIVITY)
public class ParseActivity extends AppCompatActivity {
private static final String TAG = “ParseActivity”;
@Autowired
String name;
@Autowired
int age;
@Autowired
Person person;
@Autowired
TestObj mTestObj;
@Autowired // 注意字段的名称必须与 withObject 的 key 一致
TestObj testObj;
private android.widget.TextView tv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_parse);
// 调用 inject 方法,如果传递过来的参数含有,这样使用 @Autowired 的会自动解析
ARouter.getInstance().inject(this);
}
在 activity 的跳转中,我们知道,我们可以用 startActivityForResult 来获取返回结果,那在 ARouter 中要怎么实现呢。
ARouter 中并没有提供这样的接口,但是我们可以采用曲线救国的原理,通过 Postcard 实现
Postcard postcard = ARouter.getInstance().build(ARouterConstants.COM_ACTIVITY_RESULT);
LogisticsCenter.completion(postcard);
Class> destination = postcard.getDestination();
这里得到的 destination 类就是我们要跳转的类,这样 fragment 的 startActivityForResult 就好办了
Intent intent = new Intent(getContext(),destination);
startActivityForResult(intent,requestCode);
暴露服务
这里说到的服务不是 Android 四大组件中的 Service,这里的服务是接口开发的概念。即把部分功能或者业务封装起来。
比如,我们想调用某个接口,一般来说,可以这样做。
public interface HelloService extends IProvider {
String sayHello(String name);
}
// 实现接口
@Route(path = ARouterConstants.SERVICE_HELLO, name = “test service”)
public class HelloServiceImpl implements HelloService {
private Context mContext;
@Override
public String sayHello(String name) {
Toast.makeText(mContext,this.getClass().getSimpleName()+": sayHello"+" "+name,Toast.LENGTH_SHORT).show();
return "hello, " + name;
}
@Override
public void init(Context context) {
mContext = context;
}
}
HelloService helloService = (HelloService) ARouter.getInstance().build(ARouterConstants.SERVICE_HELLO).navigation();
String result = helloService.sayHello(“xujun”);
URL 跳转
我们先来看一下我们 URL 跳转的设计
从图中可以看到,我们是用一个中间跳转页面来管理所有 Activity 的跳转的,当接受到跳转指令的时候,中转 Activity 会进行相应的处理,从而跳转到响应的页面。
这样设计的好处是:
中转 Activity:
public class UrlSchemeActivity extends AppCompatActivity {
private static final String TAG = “UrlSchemeActivity”;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_url);
// 直接通过ARouter处理外部Uri
final Uri uri = getIntent().getData();
Log.i(TAG, “onCreate: uri=” + uri);
ARouter.getInstance().
build(uri).navigation(this, new NavCallback() {
@Override
public void onArrival(Postcard postcard) {
finish();
}
@Override
public void onLost(Postcard postcard) {
super.onLost(postcard);
Log.i(TAG, “onLost: uri=” + uri);
// Toast.makeText(UrlSchemeActivity.this,String.format("找不到可以处理该
// URI %s 的 Activity",uri),Toast.LENGTH_SHORT).show();
// 找不到的时候 finish 掉当前 activity
finish();
}
});
}
}
当我们接收到跳转 uri 的时候,我们将它交给路由 ARouter,去进行分发。
接下来我们来看一下我们在 AndroidManifest 的配置
android:host=“m.aliyun.com” android:scheme=“arouter”/> 这里面的 host 、scheme 字段很重要。点击 url 会根据这两个字段会调起本地的 Activity 。 接下来,看一下我们的 HTML arouter://m.aliyun.com/test/activity1 测试URL Encode情况 E"/> 这里面的 host 、scheme 字段很重要。点击 url 会根据这两个字段会调起本地的 Activity 。 接下来,看一下我们的 HTML arouter://m.aliyun.com/test/activity1 测试URL Encode情况 跳转测试
自定义Scheme[通常来说都是这样的]
跳转测试
自定义Scheme[通常来说都是这样的]