사진: Unsplash의Vidar Nordli-Mathisen 이번 게시글에서 Compose Navigation을 사용하면서 발생한 Recomposition 문제, 그리고 그 원인과 해결방안에 대해 이야기해보려고 합니다. Recomposition으로 인한 문제 발생어느 때와 같이 안드로이드 개발을 하던 도중 문제가 발생했습니다. 바로 NavHost에 리컴포지션 되면, 현재 화면이 계속 startDestination으로 되돌아간다는 문제였습니다. 제가 정의한 NavHost는 다음과 같습니다.NavHost( navController = navigator.navController, startDestination = navigator.startDestination,) { composabl..
사진: Unsplash의Kelly Sikkema 최근 개발을 하면서 다른 사람들의 GitHub을 뒤져보다가, TextField를 너무나도 간단하게 사용하는 사례를 발견했습니다. 제가 기존에 사용하던 방식과 비교했을 때 너무 간단해져서 사용을 고려했지만, 결국 어떠한 이유로 사용하지 않게 되었기에, 이 경험을 공유해보고자 합니다. 기존 방식제가 이전에 사용했던 방식은 ViewModel에서 상태를 관리하는 형태였습니다.@HiltViewModelclass NameViewModel @Inject constructor() : ViewModel() { private val _name = MutableStateFlow("") val name: StateFlow get() = _name fun se..
사진: Unsplash의April Walker 안드로이드 개발을 할 때, ViewModel을 사용하는 것은 이제 옵션이 아닌 필수일 정도로 ViewModel을 사용하는 것은 매우 당연해 졌습니다. 시간이 지나며 새로운 기술일이 나오게 되면서, 이에 대응하여 ViewModel의 사용 방법은 우리가 눈치채지도 못하게 자연스럽게 바뀌었습니다. 그러면서 모르고 지나갔던 부분들을 톺아보고자 이번 게시글에서는 ViewModel을 어떻게 사용하고 있는지 살펴보고자 합니다. 이 게시글은 3가지의 시리즈로 구성되어 있습니다. (1) - ViewModel의 생성과 관리 [현재 게시글](2) - ViewModel과 SaveStateHandle (3) - Hilt와 함께 ViewModel 가져오기 ViewModel의 ..
사진: Unsplash의Pawel Czerwinski 이 게시글은 Type-Safe Compose Navigation을 사용하고 있다는 것을 전제합니다. 만약 아직 Migration을 하지 않으셨다면 아래의 게시글을 통해 진행해 보세요! Type Safety를 지원하는 Compose Navigation으로 이전하기사진: Unsplash의Dan Chung 드디어 Compose Navigation에서 Type Safety를 지원합니다! 이전에 Compose를 해보지 않으셨다면 모르시겠지만, 이전의 Compose Navigation을 해보셨다면 해당 방식이 마음에 안드셨던everyday-develop-myself.tistory.com Compose Navigation을 사용하면서 화면 이동간 데이터를 전..
사진: Unsplash의Paul Green Compose를 사용해보셨다면 Side-effect에 대해 들어보셨을 겁니다. 이를 한글로 번역하면 부작용입니다. 말 그대로 Side-effect는 Compose를 사용할 때 발생하는 부작용을 말합니다. 부작용이란 말을 들으면 부정적인 반응이 오기 마련이지만, Compose는 이러한 부작용을 예측가능한 방식으로 실행되도록 다양한 방법을 제공합니다. 부작용을 예측가능하게 사용하면 더 강력한 기능을 합니다. 이번 게시글에서는 공식 문서를 읽어보면서 Side-effect에 대응하는 방법에 대해 알아보고자 합니다. Compose와 Side-effectSide-effect의 정의는 컴포저블 함수의 범위 밖에서 발생하는 상태 변화를 말합니다. 기본적으로 컴포저블..
사진: Unsplash의Dan Chung 드디어 Compose Navigation에서 Type Safety를 지원합니다! 이전에 Compose를 해보지 않으셨다면 모르시겠지만, 이전의 Compose Navigation을 해보셨다면 해당 방식이 마음에 안드셨던 분들이 많았을 겁니다. 불만이 많으셨던 분들을 위해 Type Safety Compose Navigation에 대해 간략히 살펴보고 제가 작성한 코드를 마이그레이션 해보고자 합니다. 필요한 Gradle은 아래와 같습니다.[versions]...kotlinxSerializationJson = "1.6.3"kotlinxSerialization = "1.9.0"navigationCompose = "2.8.0-alpha08" [libraries]...a..
사진: Unsplash의R Mo 이번 게시글에서는 Compose에서 어떻게 WindowInsets에 대응하는지 아래의 공식문서로 공부해보고자 합니다. Compose의 창 인셋 | Jetpack Compose | Android Developers 이 페이지는 Cloud Translation API를 통해 번역되었습니다. Compose의 창 인셋 컬렉션을 사용해 정리하기 내 환경설정을 기준으로 콘텐츠를 저장하고 분류하세요. Android 플랫폼은 상태 표시줄 및 탐색 developer.android.com WindowInsets? `WindowInsets`에 대해서 잘 알지 못하는 분들을 위해 먼저 설명해 보겠습니다. WindowInsets은 `Window`와 `Insets`으로 나눠 설명하면 매우 쉽게 이..
사진: Unsplash의Malcolm Lightbody 컴포즈는 너무나도 편리하지만, 배우면 배울수록 내부의 동작을 알지 못하면 안 된다는 생각이 듭니다. View 시스템과는 다른 방식으로 UI를 그리고 있기 때문에 자칫 잘못하면 부분별 한 남용으로 퍼포먼스가 매우 떨어지게 될 수 있습니다. 그렇기 때문에 이번 게시글에서는 컴포즈의 Snapshot에 대해서 배우고 공부해보고자 합니다. 이 게시글은 아래의 글을 보고 공부한 내용을 다룹니다. Introduction to the Compose Snapshot system Jetpack Compose introduces a novel way to handle observable state. For an introduction that adds some... d..