一、概述
上一篇主要介绍了dagger的基本使用方法,这篇则分享一下我之前基于mvp架构的项目中的简单应用,也作为一个记录;最近才了解到mvpclean,把dagger的依赖注入部分放在presentation层比较合适。
二、dagger架构思路
由于还不算很熟悉dagger,所以只是将网络请求的httpclient以及数据库采用依赖注入的方式,并没有涉及到一些对象的作用域甚至包含、继承等更复杂的组织形式,适合一些简单的小型项目。
- 提供一个AppComponent,暴露出全局Context、数据中心、http请求帮助对象、数据库帮助对象以及SharedPreferences帮助对象
- 提供一个ActivityComponent,依赖AppComponent,获取暴露的依赖实例,同时暴露出activity对象实例
- 提供一个FragmentComponent,依赖AppComponent,获取暴露的依赖实例,也暴露activity对象实例
注意:此处fragment直接依赖于AppComponent而并没有采取上篇所述的依赖于ActivityComponent,并提供AppModule的形式,复杂的大型应用应考虑差异性,此处目的只是拿到一些全局的依赖实例
三、环境与版本
当时开发时没有采取最新的版本,所以可能和现在有所差别,使用时应灵活调整。
Project的build.gradle如下:
dependencies {
classpath 'com.android.tools.build:gradle:2.3.3'
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
classpath "io.realm:realm-gradle-plugin:3.1.1"
}
module的gradle文件:
apply plugin: 'com.android.application'
apply plugin: 'android-apt'
apply plugin: 'realm-android'
android {
compileSdkVersion rootProject.ext.android.compileSdkVersion
buildToolsVersion rootProject.ext.android.buildToolsVersion
defaultConfig {
……
// realm所需,应该是跟.so文件有关
ndk {
abiFilters = ["armeabi"]
}
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
productFlavors {
google {
manifestPlaceholders = [UMENG_CHANNEL_VALUE: "google"]
}
}
// realm所需
packagingOptions {
exclude "lib/mips/librealm-jni.so"
exclude "lib/x86/librealm-jni.so"
exclude "lib/x86_64/librealm-jni.so"
}
// realm所需,请根据需要选择
splits {
abi {
enable true
reset()
include 'armeabi', 'armeabi-v7a', 'arm64-v8a'
universalApk true
}
}
}
dependencies {
……
//network
compile "com.google.code.gson:gson:2.7"
compile "com.squareup.retrofit2:retrofit:2.2.0"
compile "com.squareup.retrofit2:converter-gson:2.2.0"
compile "com.squareup.retrofit2:adapter-rxjava2:2.2.0"
compile "com.squareup.okhttp3:okhttp:3.6.0"
compile "com.squareup.okhttp3:logging-interceptor:3.6.0"
compile "com.github.bumptech.glide:glide:3.7.0"
compile "com.github.bumptech.glide:okhttp3-integration:1.4.0@aar"
compile "org.jsoup:jsoup:1.10.1"
//di
compile "com.google.dagger:dagger:2.0.2"
apt "com.google.dagger:dagger-compiler:2.0.2"
provided "org.glassfish:javax.annotation:10.0-b28"
}
realm的配置也并没有弄清楚,个人建议可以使用room或者greendao在配置方面更简单。编译有问题的话请百度下realm相关。
四、dagger编码—AppComponent相关
AppComponent暴露全局的依赖实例,把依赖分为两块,AppModule负责暴露的依赖实例,HttpModule负责网络请求帮助类的依赖实例。
HttpModule代码如下:
@Module
public class HttpModule {
@Singleton
@Provides
GsonBuilder provideGsonBuilder() {
return new GsonBuilder();
}
@Provides
@Singleton
public Gson getGson(GsonBuilder builder) {
return builder
.setDateFormat("yyyy-MM-dd HH:mm:ss")
.serializeNulls()
.setLenient()
.setFieldNamingStrategy(new AnnotateNaming())
.create();
}
@Singleton
@Provides