优秀的编程知识分享平台

网站首页 > 技术文章 正文

Android 菜鸟的学习之路——MVVMHabit(一)

nanyue 2024-09-12 15:50:36 技术文章 9 ℃

Android 菜鸟的学习之路----MVVMHabit(一)

这是github上的一个开源框架项目地址:https://github.com/goldze/MVVMHabit

MVVMHabit

话说作为一个菜鸟,刚开始我还不知道有MVVMHabit这个框架,由于工作的原因遇见了一个其他公司的大佬,在交流的过程中听到了这个框架,大佬告诉我这个框架用熟了还可以!我就满怀激动的搜了一下这个框架!

目前,android流行的MVC、MVP模式的开发框架很多,然而一款基于MVVM模式开发框架却很少。是很少,大佬告诉我这个框架只有一个Demo供人们学习!其他的还得靠自己摸索,那就开启咱们的踏坑之旅呗!

MVVMHabit是以谷歌DataBinding+LiveData+ViewModel框架为基础,整合Okhttp+RxJava+Retrofit+Glide等流行模块,加上各种原生控件自定义的BindingAdapter,让事件与数据源完美绑定的一款容易上瘾的实用性MVVM快速开发框架。从此告别findViewById(),告别setText(),告别setOnClickListener()...我靠,作为一个菜鸟告别告别findViewById(),告别setText(),告别setOnClickListener(),听大佬说就连Adapter都不用写,想想就鸡激动!

MVVM框架流程

MVVM框架特点

  1. 快速开发:作为一个新型框架,用框架的目的就是为了方便,为了提高工作效率。。。。
  2. 维护方便:MVVM开发模式,低耦合,逻辑分明。Model层负责将请求的数据交给 ViewModel;ViewModel层负责将请求到的数据做业务逻辑处理,最后交给View层去展示,与View一一对应;View层只负责界面绘制刷新,不处理业务逻辑,非常适合分配独立模块开发
  3. 流行框架:retrofit+okhttp+rxJava负责网络请求;gson负责解析json数据;glide负责加载图片;rxlifecycle负责管理view的生命周期;与网络请求共存亡;rxbinding结合databinding扩展UI事件;rxpermissions负责Android 6.0权限申请;material-dialogs一个漂亮的、流畅的、可定制的material design风格的对话框。
  4. 数据绑定:满足google目前控件支持的databinding双向绑定,并扩展原控件一些不支持的数据绑定。例如将图片的url路径绑定到ImageView控件中,在BindingAdapter方法里面则使用Glide加载图片;View的OnClick事件在BindingAdapter中方法使用RxView防重复点击,再把事件回调到ViewModel层,实现xml与ViewModel之间数据和事件的绑定(框架里面部分扩展控件和回调命令使用的是@kelin原创的)。
  5. 基类封装:专门针对MVVM模式打造的BaseActivity、BaseFragment、BaseViewModel,在View层中不再需要定义ViewDataBinding和ViewModel,直接在BaseActivity、BaseFragment上限定泛型即可使用。普通界面只需要编写Fragment,然后使用ContainerActivity盛装(代理),这样就不需要每个界面都在AndroidManifest中注册一遍。
  6. 全局的Activity堆栈式管理,在程序任何地方可以打开、结束指定的Activity,一键退出应用程序。
  7. LoggingInterceptor全局拦截网络请求,打印Request和Response,格式化json、xml数据显示,方便与后台调试接口。
  8. 全局Cookie,支持SharedPreferences和内存两种管理模式。
  9. 通用的网络请求异常监听,根据不同的状态码或异常设置相应的message。
  10. 全局的异常捕获,程序发生异常时不会崩溃,可跳入异常界面重启应用。(这个很好用,方便后期的测试)
  11. 全局事件回调,提供RxBus、Messenger两种回调方式。
  12. 全局任意位置一行代码实现文件下载。作为一个菜又鸟,想想就觉得很赞!

话不多说 咱这就开始干!

1.准备工作

1.1启用dataBindding

在主工程app的build.gradle的android{}中加入:

dataBinding {

enabled true

}

1.2 依赖Library

从远程依赖:

在根目录的build.gradle中加入

allprojects {

repositories {

...

google()

jcenter()

maven { url 'https://jitpack.io' }

}

}

在主项目app的build.gradle中依赖

dependencies {
 ...
 implementation 'com.github.goldze:MVVMHabit:3.0.6'
}

或下载例子程序,在主项目app的build.gradle中依赖例子程序中的mvvmhabit:

dependencies {	
 ...
 implementation project(':mvvmhabit')
}

1.3、配置config.gradle

如果不是远程依赖,而是下载的例子程序,那么还需要将例子程序中的config.gradle放入你的主项目根目录中,然后在根目录build.gradle的第一行加入:

apply from: "config.gradle"

注意: config.gradle中的

android = [] 是你的开发相关版本配置,可自行修改

support = [] 是你的support相关配置,可自行修改

dependencies = [] 是依赖第三方库的配置,可以加新库,但不要去修改原有第三方库的版本号,不然可能会编译不过

1.4、配置AndroidManifest

添加权限:网络和读写内存的权限

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

配置Application:

继承mvvmhabit中的BaseApplication,或者调用

BaseApplication.setApplication(this);

来初始化你的Application

可以在你的自己AppApplication中配置

//是否开启日志打印
KLog.init(true);
//配置全局异常崩溃操作
CaocConfig.Builder.create()
 .backgroundMode(CaocConfig.BACKGROUND_MODE_SILENT) //背景模式,开启沉浸式
 .enabled(true) //是否启动全局异常捕获
 .showErrorDetails(true) //是否显示错误详细信息
 .showRestartButton(true) //是否显示重启按钮
 .trackActivities(true) //是否跟踪Activity
 .minTimeBetweenCrashesMs(2000) //崩溃的间隔时间(毫秒)
 .errorDrawable(R.mipmap.ic_launcher) //错误图标
 .restartActivity(LoginActivity.class) //重新启动后的activity
 //.errorActivity(YourCustomErrorActivity.class) //崩溃后的错误activity
 //.eventListener(new YourCustomEventListener()) //崩溃后的错误监听
 .apply();

一就先给大家说到这....欢迎大家加入程序员集结地这个群群号679293162

最近发表
标签列表