Hilt
什么是Hilt
Hilt是google提供的jectpack組件中的其中一種,是一個依賴注入的框架,是基于dagger的。
能做什么
Hilt能夠?qū)崿F(xiàn)自動注入,數(shù)據(jù)共享
用法
- 首先引入gradle中引入依賴
implementation 'com.google.dagger:hilt-android:2.28-alpha'
如果是kotlin需要加入
kapt 'com.google.dagger:hilt-android-compiler:2.28-alpha'
如果使用的java
annotationProcessor 'com.google.dagger:hilt-android-compiler:2.28-alpha'
另外支持了對ViewModel的擴(kuò)展
implementation 'androidx.hilt:hilt-lifecycle-viewmodel:1.0.0-alpha01'
// When using Kotlin.
kapt 'androidx.hilt:hilt-compiler:1.0.0-alpha01'
// When using Java.
annotationProcessor 'androidx.hilt:hilt-compiler:1.0.0-alpha01'
- 在自定義的Application類上加入注解@HiltAndroidApp表示要使用以來注入了
@HiltAndroidApp
class BaseApp : Application() {
}
- 自定義的實體類
data class Driver constructor(var name:String) {
//帶參數(shù)的
@Inject constructor():this("張三")
}
class Truck @Inject constructor(private val driver: Driver) {
}
- 在Activity中需要注入,在Activity類上加入注解@AndroidEntryPoint
@AndroidEntryPoint
class MainActivity : AppCompatActivity() {
@Inject
lateinit var truck: Truck
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
button.setOnClickListener {
truck.driverTruck()
}
}
}
- 如果是第三方框架我們要如何注入呢?這里使用Retrofit來示例
@Module
@InstallIn(ApplicationComponent::class)
class NetworkModule{
@Provides
@Singleton
fun providerOkHttpClient():OkHttpClient =OkHttpClient.Builder().build()
@Provides
@Singleton
fun providerRetrofit(okHttpClient: OkHttpClient):Retrofit{
return Retrofit.Builder()
.client(okHttpClient)
.baseUrl("https://www.wanandroid.com/")
.build()
}
@Provides
@Singleton
fun providerService(retrofit: Retrofit):Api= retrofit.create(Api::class.java)
}
@Module表示當(dāng)前類可以提供注入組件
@Provides標(biāo)識當(dāng)類型可以被注入
@Singleton當(dāng)前注入對象的作用域
@InstallIn(ApplicationComponent::class) 當(dāng)前組件的作用域
- 如果使用ViewModel我們?nèi)绾巫⑷肽谸ViewModelInject
class SecondViewModel @ViewModelInject constructor(val user:User): ViewModel() {
fun showUser(){
Log.e("TAG", "showUser: ${user.userName}")
}
}
在activity或者fragment中就可以使用
val viewModel by lazy{
ViewModelProvider(this).get(SecondViewModel::class.java)
}
- 接口使用依賴注入用法
先定義一個Animal的接口
interface Animal {
fun eat()
fun run()
}
創(chuàng)建兩個接口的實現(xiàn)類
class Cat @Inject constructor() :Animal {
override fun eat() {
Log.e("TAG","Cat is Eating")
}
override fun run() {
Log.e("TAG","Cat is Running")
}
}
class Dog @Inject constructor() :Animal {
override fun eat() {
Log.e("TAG","Dog is Eating")
}
override fun run() {
Log.e("TAG","Dog is Running")
}
}
創(chuàng)建一個抽象類
@Module
@InstallIn(ApplicationComponent::class)
abstract class AnimalModule {
@Binds
@BindDogAnimal
abstract fun getDog(dog: Dog):Animal
@Binds
@BindCatAnimal
abstract fun getCat(cat: Cat):Animal
}
@Qualifier
@Retention(AnnotationRetention.BINARY)
annotation class BindDogAnimal
@Qualifier
@Retention(AnnotationRetention.BINARY)
annotation class BindCatAnimal
在Activity中使用
@AndroidEntryPoint
class AnimalActivity : AppCompatActivity() {
@BindDogAnimal
@Inject
lateinit var dog: Animal
@BindCatAnimal
@Inject
lateinit var cat: Animal
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val binding =
DataBindingUtil.setContentView<ActivityAnimalBinding>(this, R.layout.activity_animal)
binding.btDog.setOnClickListener {
dog.eat()
dog.run()
}
binding.btCat.setOnClickListener {
cat.eat()
cat.run()
}
}
}