compose
-
[안드로이드] Compose architectural layering안드로이드 2021. 9. 16. 02:57
개요 이번에는 Compose의 아키텍처 레이어링에 대해 알아보자. 내용은 안드로이드 개발자 사이트를 기반으로 작성하였다. Jetpack Compose 아키텍처 레이어링 Jetpack Compose는 모놀리식 프로젝트가 아닌 완전한 스택을 만들기 위한 여러가지 모듈의 조합으로 만들어졌다. Jetpack Compose를 구성하는 모듈을 이해한다면 아래와 같은 기능을 개발하는데 용이하다. 적절한 수준의 추상화를 사용하여 앱 및 라이브러리를 빌드 할 수 있다. 보다 세부적인 제어나 맞춤 설정을 위한 낮은 수준으로 드롭다운 할 수 있는 경우를 파악할 수 있다. 종속 항목을 최소화 할 수 있다. 레이어 각 레이어는 하위 수준 기반으로 상위수준의 구성요소를 만들기 위해 기능을 결합한다. 각 레이어는 하위 레이어의 공..
-
[Android] Compose Side Effect안드로이드 2021. 8. 20. 17:09
개요 Compose에서 Side Effect를 어떻게 사용하는지 알아보자 Side Effect란 Composable 외부에서 발생하는 앱의 상태 변경사항을 말한다. Effect란 UI에 방출하지 않으며 Composition이 완료될 때 Side Effect를 실행하는 Composable 함수이다. State 및 Effect 사용 사례 Composable은 Side Effect에 Free 해야한다. 앱의 상태 변경이 필요할 때 Composable의 생명주기를 알고 있는 제어되는 환경으로 부터 호출해야 한다. Compose에서 가능성 있는 Effect들을 열어두기 때문에 쉽게 과하게 사용할 수있다. 그래서 UI와 관련되고 단방향 데이터 플로우를 중단시켜서는 안된다. LaunchedEffect Launched..
-
[Android] Compose Lifecycle(안드로이드 개발자 사이트 번역)안드로이드 2021. 8. 3. 17:08
개요 Composable의 생명주기와 Recomposition이 필요한 Composable을 Compose가 어떻게 결정하는지 알아보자. Lifecycle State 관리에서 본것 처럼 Composition은 UI를 설명하고 Composable 실행에 의해 생성된다. Composition은 UI를 설명하는 Composable의 트리구조로 되어있다. Jetpacke Compose가 Composable들을 처음 실행할 때(Initial composition동안) Composition에서 UI를 설명하기 위해 호출하는 Composable을 추적한다. 그러고나서 앱의 State가 변경될때 Jetpack Compose는 Recomposition을 예약한다. Recomposition은 Jetpack Compose가..
-
[Android] Compose State 관리 - 2안드로이드 2021. 8. 2. 17:45
개요 Compose State 관리를 이전 포스팅에 이어 정리해보자. (안드로이드 개발자 사이트 참고) 2021.08.02 - [안드로이드] - [Android] Compose State 관리 - 1 [Android] Compose State 관리 - 1 State와 Composition Compose는 선언적이므로 Compose를 업데이트하는 유일한 방법은 새 파라메터로 동일한 Composable을 호출하는 것이다. 이 파라메터는 UI 상태를 나타난다. 상태가 업데이트될때마다 재 growup-lee.tistory.com ViewModel 과 State ViewModel은 UI 트리 위에 있는 Composable이나 Navigation 라이브러리의 도착지에 있는 Composable을 위해 권장하는 Sta..
-
[Android] Compose State 관리 - 1안드로이드 2021. 8. 2. 14:31
State와 Composition Compose는 선언적이므로 Compose를 업데이트하는 유일한 방법은 새 파라메터로 동일한 Composable을 호출하는 것이다. 이 파라메터는 UI 상태를 나타난다. 상태가 업데이트될때마다 재구성이 실행된다. 따라서 TextField와 같은 항목은 명령형 XML 기반 뷰에서 처럼 자동으로 업데이트 되지 않는다. Composable이 새 상태에 따라 업데이트되면서 새 상태를 명시적으로 알려줘야 한다. @Composable fun HelloContent() { Column(modifier = Modifier.padding(16.dp)) { Text( text = "Hello!", modifier = Modifier.padding(bottom = 8.dp), style =..
-
[Android] Compose 이해하기안드로이드 2021. 7. 30. 14:28
Compose란 Jetpack Compose는 Android를 위한 선언형 UI 도구 Kit이다. 앱 UI를 선언형 API를 제공하여 더 쉽게 작성하고 유지관리할 수 있도록 지원한다. 선언형 프로그래밍 패러다임 지금까지 Android의 뷰 계층구조는 UI 위젯의 트리로 표시할 수 있었다. 앱의 상태가 변경되어 현재 데이터를 변경하려면 findViewById()와 같은 함수로 트리를 탐색하고 setText, addChild, setImageBitmap등의 메소드를 호출하여 노드를 변경했다. View는 수동으로 조작하면 오류가 발생할 가능성이 높아진다. 데이터를 여러 위치에서 렌더링한다면 데이터를 표시하는 뷰 중 하나를 업데이트하는 것을 잊기 쉽다. 또 여러 뷰의 상태를 변경하다 보면 예기치 않은 crash..