반응형
1. Module-App gradle Setting
implementation (libs.hilt.android)
kapt (libs.hilt.android.compiler)
implementation(libs.androidx.hilt.navigation.compose)
plugins {
id ("com.google.dagger.hilt.android")
id ("kotlin-kapt")
kotlin("kapt")
}
나는 아직 옛날인간이라 예전 Gradle 스타일이 익숙하지만 요즘에는 저렇게 버전을 명시해 주지 않는가 보다.
그래서 버전이 어디 명시되어 있나 타고 가보면
libs.versions.toml 이라는 곳에 정리가 되어 있는 것을 알 수 있었다.
[versions]
agp = "8.5.0"
hiltAndroid = "2.49"
hiltAndroidCompiler = "2.44"
hiltNavigationCompose = "1.2.0"
kotlin = "1.9.0"
coreKtx = "1.13.1"
junit = "4.13.2"
junitVersion = "1.2.1"
espressoCore = "3.6.1"
lifecycleRuntimeKtx = "2.8.4"
activityCompose = "1.9.1"
composeBom = "2024.04.01"
[libraries]
androidx-core-ktx = { group = "androidx.core", name = "core-ktx", version.ref = "coreKtx" }
androidx-hilt-navigation-compose = { module = "androidx.hilt:hilt-navigation-compose", version.ref = "hiltNavigationCompose" }
hilt-android = { module = "com.google.dagger:hilt-android", version.ref = "hiltAndroid" }
hilt-android-compiler = { module = "com.google.dagger:hilt-android-compiler", version.ref = "hiltAndroidCompiler" }
junit = { group = "junit", name = "junit", version.ref = "junit" }
androidx-junit = { group = "androidx.test.ext", name = "junit", version.ref = "junitVersion" }
androidx-espresso-core = { group = "androidx.test.espresso", name = "espresso-core", version.ref = "espressoCore" }
androidx-lifecycle-runtime-ktx = { group = "androidx.lifecycle", name = "lifecycle-runtime-ktx", version.ref = "lifecycleRuntimeKtx" }
androidx-activity-compose = { group = "androidx.activity", name = "activity-compose", version.ref = "activityCompose" }
androidx-compose-bom = { group = "androidx.compose", name = "compose-bom", version.ref = "composeBom" }
androidx-ui = { group = "androidx.compose.ui", name = "ui" }
androidx-ui-graphics = { group = "androidx.compose.ui", name = "ui-graphics" }
androidx-ui-tooling = { group = "androidx.compose.ui", name = "ui-tooling" }
androidx-ui-tooling-preview = { group = "androidx.compose.ui", name = "ui-tooling-preview" }
androidx-ui-test-manifest = { group = "androidx.compose.ui", name = "ui-test-manifest" }
androidx-ui-test-junit4 = { group = "androidx.compose.ui", name = "ui-test-junit4" }
androidx-material3 = { group = "androidx.compose.material3", name = "material3" }
[plugins]
android-application = { id = "com.android.application", version.ref = "agp" }
jetbrains-kotlin-android = { id = "org.jetbrains.kotlin.android", version.ref = "kotlin" }
위와 같이 되어 있는데 아직은 좀 더 알아보야 겠다
2. Project gradle Setting
plugins {
id("com.google.dagger.hilt.android") version "2.44" apply false
}
위 버전의 hiltAndroidCompiler가 2.44로 되어 있는 것을 보면 프로젝트 Gradle에서 셋팅을 해주는 것 같은데
그럼 hiltNavigationCompose의 버전은 어디서 셋팅된것인지 .. 알아보아야 겠다.
3. Application Setting
위 Gradle의 sync가 제대로 되어 있다면 Application 클래스 파일을 새로 만들어서 Hilt를 적용해야 한다.
@HiltAndroidApp
class TestApplication: Application() {
override fun onCreate() {
super.onCreate()
Log.d("TestApplication", "TestApplication_onCreate")
}
}
새로운 Application 클래스를 만들었다면 @HiltAndroidApp 어노테이션을 달아주도록 하자
<application
android:name=".TestApplication"
그리고 Manifest에 등록을 해주자
4. Activity Setting
@AndroidEntryPoint
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
}
}
}
}
위대로 Activity로 들어와서 Application과 동일하게 @AndroidEntryPoint 어노테이션을 달아준다.
반응형
'[# 2]…My DevelopStory' 카테고리의 다른 글
[Android Compose] BasicTextField을 이용한 커스텀 사투기 (2) | 2024.08.27 |
---|---|
[Android Compose] Scaffold Content padding parameter it is not use (0) | 2024.08.26 |
[Android] Di 주입, Dagger 라이브러리 Hilt의 핵심개념 (1) | 2024.05.08 |
[Android] Flow에 대하여, Flow란 무엇인가 (0) | 2024.05.08 |
[Android] Keyboard show/hide detect Listener Utile (0) | 2023.06.02 |