Android Architecture Components 已经比较稳定了,一直有关注,刚好上周项目2.0.0上架,重构一下项目。今天已经重构完成,所以在这里记录下,如果您发现有什么不妥的地方,请留言指出,不胜感激。
AAC(Android Architecture Components)架构主要包括:
- LiveData
- ViewModel
Room
相信你一定在很多技术文章里见到过这三个单词。当然由于我们app刚刚起步到2.0.0所以我没有用Room,所本篇不会讲解Room,想了解的可以去看官网的。
架构草图:
这是我用ProcessOn 工具做的,我感觉这个工具还不错,可以做UML、思维导图。。。好多的。
我下面根据这个草图讲下我的思路,并且会贴出源码:
首先从左上角的View看:
View也就是我们的视图层(Activity/Fragment)他们会各自集成LifecycleActivity/LifecycleFragment,且View视图会持有ViewModel的引用,下面看代码:
以我的收藏api为例:
红框代码第一行代码拿到ViewModel对象,MineViewModel是ViewModel的子类,第二行代码是注册接口监听,先不要管干什么的,等会走完调用流程,我会回来再次解释。
接着我们去MineViewModel类:
这是收藏api,Viewmodel会持有Repository类、IBaseView接口的引用,并且会实现IPresenter接口的方法,用来干什么?看代码你应该会明白的,回头再说,继续去Repository类:
Repository类其实就像一个仓库一样,在这里做请求服务的操作,并且会在拿到相应结果,看得出,回调就在DataCallBack类,继续:
注意看圈中的代码,我们拿到返回值后,通过LiveData传递给我们的view视图,那我们在View视图的哪里会看到呢?我们回到view的代码:
没错,你会在onchange()方法拿到回显得数据,是不是很清晰?接着我们回到DataCallBack看下我们的回调方法:
@Override
public void onResponse(Call<BaseBean> call, Response<BaseBean> response) {
Log.i("callback", "onChanged: " + new Gson().toJson(response.body()));
if(response.body().isSuccess()){
mData.setValue(response.body());
mainPresnter.loadDataSuccess(call,response);
}else {
mainPresnter.loadDataError(call,response);
}
}
@Override
public void onFailure(Call<BaseBean> call, Throwable throwable) {
Log.i("callback", "onChanged: " + throwable);
mainPresnter.loadDataFailure(call,throwable);
}
你一定很疑惑为什么?都已经拿到数据了,那还写回调干什么?因为我要统一处理:你想下,服务器的响应你就晓得了。
服务器返回如下:
1、请求返回true
2、请求返回false
3、请求超时、网络异常、服务器异常(就是挂了~)
当然每个项目都不一样,我们的返回true还有如下:
1、登录token超时
2、账号被迫下线(多端登录)
你说这么多返回类型,我不统一在基类处理,我难道一个一个去写!mmp~所以我就结合了MVP的模式,用IBaseView、IPresenter接口回调到基类处理。
回调过程:
1、DataCallBack 类通过IPresenter的引用回调到ViewModel
2、然后ViewModel实现IPresenter的方法,交给IBaseView接口
3、我们的View视图基类实现IBaseView接口,这样我们的回调就到了View,接着我们的view在实现回调方法,就这样我们就可以在基类处理各种情况了。
这就是我们刚开始的时候会看到子view会注册IBaseView的监听了。
至于什么是LiveData、ViewModel、Room,我真的不想说,因为网上出现了太多教程,而没有实际运用到项目中的,所以希望小伙伴们赶快用起来,让我看下你们的想法。