Android框架——dagger简单实践使用

一、概述

上一篇主要介绍了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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值