Назад к вопросам
Middle
109
questionbank

Как создать и настроить Dagger Hilt в Android-приложении?

Sobes Copilot

Получайте ответы в реальном времени

Ответ от нейросети

sobes.tech AI

  1. Добавление зависимостей в build.gradle (Project):
// project-level build.gradle
buildscript {
    ext {
        hilt_version = '2.48' // Используйте актуальную версию Hilt
    }
    repositories {
        google()
        mavenCentral()
    }
    dependencies {
        classpath "com.google.dagger:hilt-android-gradle-plugin:$hilt_version"
        // ... другие зависимости
    }
}

allprojects {
    repositories {
        google()
        mavenCentral()
        // ... другие репозитории
    }
}
  1. Добавление зависимостей в build.gradle (Module):
// app-level build.gradle
plugins {
    id 'com.android.application'
    id 'kotlin-android'
    id 'kotlin-kapt' // Для генерации кода Kapt
    id 'dagger.hilt.android.plugin'
}

android {
    // ...
}

dependencies {
    implementation "com.google.dagger:hilt-android:$hilt_version"
    kapt "com.google.dagger:hilt-compiler:$hilt_version"
    kapt "androidx.hilt:hilt-compiler:1.0.0" // Опционально, для Android-специфичных расширений Hilt
    // ... другие зависимости
}
  1. Создание основного класса приложения с аннотацией @HiltAndroidApp:
// MyAndroidApp.kt
import android.app.Application
import dagger.hilt.android.HiltAndroidApp

@HiltAndroidApp
class MyAndroidApp : Application() {
    // Дополнительная инициализация при необходимости
}
  1. Регистрация созданного класса в AndroidManifest.xml:
<!-- AndroidManifest.xml -->
<application
    android:name=".MyAndroidApp"
    ...>
    <!-- ... -->
</application>
  1. Аннотирование Android-компонентов (Activity, Fragment, Service и т.д.) с помощью @AndroidEntryPoint:
// MyActivity.kt
import androidx.appcompat.app.AppCompatActivity
import dagger.hilt.android.AndroidEntryPoint

@AndroidEntryPoint
class MyActivity : AppCompatActivity() {
    // ...
}

Теперь Hilt готов к использованию для внедрения зависимостей в аннотированные классы. Далее можно создавать модули (@Module), предоставлять зависимости (@Provides или @Binds) внутри модулей, и внедрять их в компоненты с помощью @Inject.

Пример модуля:

// NetworkModule.kt
import dagger.Module
import dagger.Provides
import dagger.hilt.InstallIn
import dagger.hilt.components.SingletonComponent
import retrofit2.Retrofit
import javax.inject.Singleton

@Module
@InstallIn(SingletonComponent::class) // Установка модуля в Scope приложения
object NetworkModule {

    @Provides
    @Singleton
    fun provideRetrofit(): Retrofit {
        return Retrofit.Builder()
            // ... конфигурация Retrofit
            .build()
    }

    // Другие предоставления зависимостей
}

Пример внедрения зависимости:

// MyActivity.kt
import androidx.appcompat.app.AppCompatActivity
import dagger.hilt.android.AndroidEntryPoint
import retrofit2.Retrofit
import javax.inject.Inject

@AndroidEntryPoint
class MyActivity : AppCompatActivity() {

    @Inject
    lateinit var retrofit: Retrofit // Внедрение зависимости Retrofit

    // ... использование retrofit
}