首先感谢 JessYan 开源的 MVPArms,学到了很多知识,也方便了公司项目的开发! 在 Google I/O 2017 大会上,Google 推出了新的组件库 - Android Architecture Components,官方文档做的很详细,分别介绍了各个组件的应用场景和使用方式,这无疑会推进 Android MVVM 模式的发展。关于 MVVM 这里不做过多介绍,如果有需要可以自行搜索。
先来看一下 Android Architecture Components 包含哪些内容:
加上之前推出的 Data Binding Library
如果想要引用 Components,可参考以下链接:
注意:如果你无法访问 Google Maven 库,可以使用以下地址代替:
maven { url "https://dl.google.com/dl/android/maven2" }
这里需要特别说明的是,ViewModel 相当于 MVVM 的 VM 层,它和 View 是通过 Data Binding 双向绑定的,ViewModel 不再持有 View 的引用,而是存储UI相关的数据;而且 ViewModel 是生命周期感知的,当创建它的 Activity/Fragment 销毁时,ViewModel 会自动销毁。
这里引用 官方 架构图,参考 MVPArms 做了一些修改。
整个框架采用 Dagger 进行依赖注入,并使用了最新的 Dagger.Android,组织好 Module 和 Components,框架会自动注入。具体可参考 demo。
框架中,数据的获取是通过 Model 层获取的,在 Model 中持有一个数据管理类对象- RepositoryManager(实现了 IRepositoryManager 接口),分别可以通过 Retrofit 获取网络数据,通过 Room 获取 SQLite 数据库中的持久化数据。具体实现可查看源码链接:
Room 的使用需要在 gradle 中添加:
android {
...
//Room
javaCompileOptions {
annotationProcessorOptions {
arguments = ["room.schemaLocation":
"$projectDir/schemas".toString()]
}
}
}
ViewModel 是整个框架比较新颖和重要的部分,BaseViewModel 继承于 Components 中的 AndroidViewModel,并实现了 LifecycleObserver 接口;它持有 Model 的引用,主要的业务逻辑都是在 ViewModel 中实现的;ViewModel 中UI相关的数据通过 LiveData 包装,使得当数据变化时,自动反映到UI上,实现了数据UI。在 xml 布局文件中,通过 Data Binding 绑定对应的 ViewModel。 BaseViewModel 源码如下:
框架封装了 ArmsActivity 和 ArmsFragment,它们都实现了 Components 中的 LifecycleRegistryOwner 接口来处理生命周期。上面提到在 xml 布局中绑定 ViewModel,而 ViewModel 的创建和生命周期绑定是在 Activity/Fragment 中进行的,具体是通过 Components 中提供的 ViewModelProviders 类完成的。下面是创建 ViewModel 的实例:
//创建ViewModel
mViewModel = ViewModelProviders.of(this, mViewModelFactory).get(WeatherViewModel.class);
- mViewModel 是通过泛型封装在 ArmsActivity 和 ArmsFragment 中的;
- 同样,mViewModelFactory 是通过 Dagger 将 ViewModelFactory 注入在 ArmsActivity 和 ArmsFragment 中的。
- ViewModelProviders.of() 是一个重载的方法,通过传入的第一个参数,限定该 ViewModel 与 哪个 Activity/Fragment 进行生命周期绑定。
创建好了 ViewModel 后,在 ArmsActivity 和 ArmsFragment 设置 ViewModel 监听 Lifecyle 的回调:
if (mViewModel != null)
getLifecycle().addObserver((LifecycleObserver) mViewModel);
同时,需要将上述提到的 xml 中绑定的 ViewModel 进行设置,这就很简单了,示例代码如下:
mBinding.setViewModel(mViewModel);
源码链接:
以下引用谷歌开发者微信公众号的介绍:
Lifecycles: 每个 Android 开发者都应该面对过生命周期问题,即操作系统启动、停止和销毁 Activity。 这意味着开发者需要根据生命周期的不同阶段,有针对性地管理组件状态,比如用于更新用户界面的可观察对象。 生命周期管理(Lifecycles)帮助开发者创建 “可感知生命周期的” 组件,让其自己管理自己的生命周期, 从而减少内存泄露和崩溃的可能性。生命周期库是其他架构组件(如 LiveData)的基础。
LiveData: LiveData 是一款基于观察者模式的可感知生命周期的核心组件。 LiveData 为界面代码 (Observer)的监视对象 (Observable),当 LiveData 所持有的数据改变时, 它会通知相应的界面代码进行更新。同时,LiveData 持有界面代码 Lifecycle 的引用, 这意味着它会在界面代码(LifecycleOwner)的生命周期处于 started 或 resumed 时作出相应更新, 而在 LifecycleOwner 被销毁时停止更新。通过 LiveData,开发者可以方便地构建安全性更高、性能更好的高响应度用户界面。
ViewModel: ViewModel 将视图的数据和逻辑从具有生命周期特性的实体(如 Activity 和 Fragment)中剥离开来。 直到关联的 Activity 或 Fragment 完全销毁时,ViewModel 才会随之消失, 也就是说,即使在旋转屏幕导致 Fragment 被重新创建等事件中,视图数据依旧会被保留。 ViewModels 不仅消除了常见的生命周期问题,而且可以帮助构建更为模块化、更方便测试的用户界面。
Room: 几乎所有 App 都需要在本地储存数据。 自从最早版本开始,Android 就提供了 SQLite,但是直接使用 SQLite是件苦差事。 因此,我们推出了 Room,一款简单好用的对象映射层。它和 SQLite 有一样强大的功能,但是节省了很多重复编码的麻烦事儿。 它的一些功能,如编译时的数据查询验证、内置迁移支持等,让开发者能够更简单地构建健壮的持久层。 而且 Room 可以和 LiveData 集成在一起,提供可观测数据库并感知生命周期的对象。 Room 集简洁、强大和可靠性为一身,在管理本地储存上表现卓越,我们强烈推荐各位开发者试用一下。
更多细节请移步 Github,写了一个简单的 demo,欢迎 star、fork,issue、pr,希望可以一起交流: