Conheça o Hilt - Dependency Injection (DI) no JetPack, mas isso não é verdade, pois o Hilt é apenas um invólucro em torno do Dagger2. Para pequenos projetos, ele será capaz de se destacar como uma ferramenta mais conveniente e se integrar bem com o resto dos produtos JetPack.
Não vou descrever como agregar ao projeto, tudo está bem descrito no artigo
Pelo que?
Dagger2 é um DI bastante complexo, você pode facilmente confundir o que e onde colocá-lo. Chegando a um número infinito de componentes e aumentando o número de abstrações. E quanto maior o projeto, mais confusão aumenta.
E se você quiser usar o Dagger2, mas com o mínimo de esforço, o Hilt foi inventado para isso.
O que foi simplificado para nós:
- Componentes prontos (pelos nomes fica claro a que se referem)
- ApplicationComponent
- ActivityRetainedComponent
- ActivityComponent
- FragmentComponent
- ViewComponent
- ViewWithFragmentComponent
- ServiceComponent
- No módulo, você especifica qual componente adicionar
- Por meio do @AndroidEntryPoint Hilt, o compilador gera todo o bolierplate para a criação e armazenamento do componente (por exemplo, ActivityRetainedComponent salvará a entidade após a rotação da tela, ActivityComponent será recriado).
Este código parece muito elegante (todo o boilerplate será gerado para nós)
@AndroidEntryPoint
class ExampleActivity : AppCompatActivity() {
@Inject lateinit var testService: TestService
}
Recursos:
Requer aplicação
Você precisa declarar Application e marcar @HiltAndroidApp, sem ele o Hilt não funcionará.
@HiltAndroidApp
class App : Application() { }
Dependência hierárquica
Hilt , Activity @AndroidEntryPoint
View @WithFragmentBindings Fragment @AndroidEntryPoint, Activity Fragment
Dagger2, , @InstallIn. , .
@InstallIn(ApplicationComponent::class)
@Module
class NetworkModule {
@Singleton
@Provides
fun provideHttpService(): HttpService {
return object : HttpService {
init {
Log.e("Tester", "HttpService initialized")
}
override fun request() {
Log.e("Tester", "HttpService::request")
}
}
}
}
Hilt, @InstallIn, , .
Component Subcomponent
, Dagger2, Hilt . :
DaggerLoginComponent.builder()
.context(this)
.appDependencies(
EntryPointsAccessors.fromApplication(
applicationContext,
LoginModuleDependencies::class.java
)
)
.build()
.inject(this)
@AndroidEntryPoint
- Activity ComponentActivity AppCompatActivity
- Fragment androidx.Fragment
- Retain
Hilt :
- Dagger Component-
- Application, Activity, Fragment, View ., @AndroidEntryPoint
- Dagger
ActivityRetainedComponent
ViewModel arch :
this.viewModelProvider =
new ViewModelProvider(
activity,
new ViewModelProvider.Factory() {
@NonNull
@Override
@SuppressWarnings("unchecked")
public <T extends ViewModel> T create(@NonNull Class<T> aClass) {
ActivityRetainedComponent component =
((GeneratedComponentManager<LifecycleComponentBuilderEntryPoint>)
activity.getApplication())
.generatedComponent()
.retainedComponentBuilder()
.build();
return (T) new ActivityRetainedComponentViewModel(component);
}
});
:
- Dagger2
- ( )
- boilerpate .
- Dagger2 ( , ..)
:
- , , Dagger2
- ,
- Dagger2
- , , Fragment Activity c @AndroidEntryPoint
:
- https://developer.android.com/training/dependency-injection/hilt-android
- https://developer.android.com/training/dependency-injection/hilt-multi-module
- https://medium.com/androiddevelopers/dependency-injection-on-android-with-hilt-67b6031e62d
- https://codelabs.developers.google.com/codelabs/android-dagger-to-hilt/