Google은 흑인 공동체를 위한 인종 간 평등을 진전시키기 위해 노력하고 있습니다. Google에서 어떤 노력을 하고 있는지 확인하세요.

Compose Runtime

Compose의 프로그래밍 모델과 상태 관리용 기본 구성요소 및 타겟팅용 Compose 컴파일러 플러그인 핵심 런타임입니다.
최근 업데이트 현재 버전
2020년 8월 19일 0.1.0-dev17

종속 항목 선언

Compose의 종속 항목을 추가하려면 프로젝트에 Google Maven 저장소를 추가해야 합니다. 자세한 내용을 알아보려면 Google Maven 저장소를 읽어보세요.

다음과 같이 앱 또는 모듈의 build.gradle 파일에 필요한 아티팩트의 종속 항목을 추가합니다.

dependencies {
    implementation "androidx.compose.runtime:runtime:0.1.0-dev17"
    implementation "androidx.compose.runtime:runtime-livedata:0.1.0-dev17"
    implementation "androidx.compose.runtime:runtime-rxjava2:0.1.0-dev17"
}

android {
    buildFeatures {
        compose true
    }

    composeOptions {
        kotlinCompilerVersion "1.4.0"
        kotlinCompilerExtensionVersion "0.1.0-dev17"
    }
}

tasks.withType(org.jetbrains.kotlin.gradle.tasks.KotlinCompile).configureEach {
    kotlinOptions {
        jvmTarget = "1.8"
        freeCompilerArgs += ["-Xallow-jvm-ir-dependencies", "-Xskip-prerelease-check"]
    }
}

종속 항목에 관한 자세한 내용은 빌드 종속 항목 추가를 참조하세요.

의견

제출하신 의견은 Jetpack을 개선하는 데 도움이 됩니다. 새로운 문제를 발견하거나 라이브러리 개선을 위한 아이디어가 있다면 Google에 알려 주세요. 새 문제를 만들기 전에 이 라이브러리의 기존 문제를 살펴보시기 바랍니다. 별표 버튼을 클릭하여 기존 문제에 표를 추가할 수 있습니다.

새 문제 만들기

자세한 내용은 Issue Tracker 문서를 참조하세요.

버전 0.1.0-dev

버전 0.1.0-dev17

2020년 8월 19일

androidx.compose.runtime:runtime-*:0.1.0-dev17이 출시되었습니다. 버전 0.1.0-dev17에 포함된 커밋을 확인하세요.

API 변경사항

  • 이제 맞춤 emit에서 하나 이상의 setter를 emit와 독립적으로 건너뛰고 재구성할 수 있음을 선언할 수 있습니다. (Ibbd13)
  • 지원 중단된 FrameManager 호출을 삭제했습니다.

    내부 Compose API를 변경하여 mutableStateof()와 같은 상태 객체를 추적하기 위한 오버헤드 양을 줄였습니다. (I80ba6)

  • 이제 state { ... } 컴포저블은 지원 중단되고 명확성을 위해 remember { mutableStateOf(...) }에 대한 명시적 호출로 대체됩니다. 이렇게 하면 전체 API 노출 영역 및 상태 관리를 위한 개념 수가 감소하고 클래스 속성 위임을 위한 by mutableStateOf() 패턴과 일치합니다. (Ia5727)

  • Flow.collectAsState는 이제 Dispatchers.Main으로 기본 설정되지 않고 구성 자체에서 기본 디스패처를 결정합니다. (I9c1d9)

  • 상태를 저장하는 요소가 for 루프 내에서 사용되었을 때 비정상 종료가 발생하는 문제를 수정했습니다. 이제 savedInstanceState()에서 동일한 키를 가질 수 있으며, UiSavedStateRegistry의 API가 이제 이 새로운 요구사항에 맞게 조정됩니다. (I4ab76, b/160042650, b/156853976, b/159026663, b/154920561)

버그 수정

  • emitView가 지원 중단되었습니다. Compose 내에서 뷰를 내보내기 위해서는 가능하면 AndroidView를 대신 사용합니다. View 및 ViewGroup을 직접 구성하는 것은 AndroidView를 사용하여 이를 달성할 수 있는 경우에 구성 트리에 남아있지 않는 한 향후에는 지원되지 않습니다. (I29b1e, b/163871221)

버전 0.1.0-dev16

2020년 8월 5일

androidx.compose.runtime:runtime-*:0.1.0-dev16이 출시되었습니다. 버전 0.1.0-dev16에 포함된 커밋을 확인하세요.

API 변경사항

  • mutableStateOf(), ambientOf()savedInstanceStateOf()의 기본 변형 정책이 referentialEqualityPolicy() 대신 structuralEqualityPolicy()로 변경되었습니다.

    mutableStateOf() 인스턴스에 할당된 새 값이 변경으로 간주되는지 여부를 결정하는 기본값은 이제 기본적으로 === 대신 ==를 사용하는 것입니다.

    https://kotlinlang.org/docs/reference/equality.html을 참조하세요.

    ambientOf()savedInstanceStateOf()는 구현에서 mutableStateOf()를 사용하므로 mutableStateOf()와 일치하도록 변경되었습니다.

    구조적 동등성을 사용하여 개발자 기대에 더욱 부응하게 되었습니다.

    예:

    val state = mutableStateOf(1f)
    

    그 뒤에 다음이 나올 경우

    state.value = 1f
    

    더 이상 state 변경으로 간주되지 않으며, 구성 중 state 사용을 더 이상 재구성할 필요가 없습니다.

    이는 브레이킹 체인지이지만 대부분의 경우(예: equals()를 재정의하지 않는 클래스를 사용할 때) 애플리케이션에 현저한 영향을 주지는 않습니다.

    data 클래스와 같이 equals()를 재정의하는 클래스는 성능이 저하될 수 있습니다. equals() 메서드가 mutableStateOf()에 할당될 때 이제 기본적으로 호출되기 때문입니다.

    mutableStateOf(), ambientOf()savedInstanceStateOf() 호출에 정책 매개변수 policy = referentialEqualityPolicy()를 추가하여 이전 동작을 복원할 수 있습니다. (Ic21a7)

  • RowColumn은 이제 인라인 함수이며 이러한 함수를 사용하는 오버헤드가 상당히 감소합니다. (I75c10)

버그 수정

  • setViewContent는 지원 중단되었습니다. 대신 setContent를 사용해야 합니다. (I7e497, b/160335130)
  • MonotonicFrameClock을 AnimationClockObservable로 사용할 수 있게 하는 MonotonicFrameAnimationClock을 추가하여 새로운 코루틴 기반 클록과 여전히 이전 콜백 기반 클록을 사용하는 API 간의 간극을 메웠습니다.

    ManualAnimationClock에 상응하는 MonotonicFrameClock은 이제 ManualFrameClock입니다. (I111c7, b/161247083)

  • Modifier.stateDraggable이 완전히 재작업되고 Modifier.swipeable로 이름이 바뀌었습니다. 새로운 SwipeableState 클래스가 도입되었으며 DrawerState 및 BottomDrawerState가 이 클래스에서 상속하도록 리팩터링되었습니다. [Modal/Bottom]DrawerLayout은 더 이상 onStateChange 매개변수를 사용하지 않습니다. (I72332, b/148023068)

  • Modifier.plus가 지원 중단되었습니다. 대신 Modifier.then을 사용해야 합니다. 'then'은 더 강력한 순서 지정 신호를 가지고 있지만 체인을 끊으며 읽기가 더 어려운 Modifier.padding().background() + anotherModifier 유형도 금지합니다. (Iedd58, b/161529964)

  • SubcomposeLayout이 추가되었습니다. 이는 나중에 하위 트리 구성에 관한 측정 중에만 제공되는 일부 값을 사용하려는 경우 측정 도중에 하위 요소를 구성할 수 있는 낮은 수준의 프리미티브입니다. 예를 들어 WithConstraints는 SubcomposeLayout을 사용하여 구현되지 않습니다. (I25cc8)

  • 머티리얼 FilledTextField는 TextField로 이름이 바뀌었으며 기본 TextField는 BaseTextField로 이름이 바뀌어 원하는 가장 간단한 API를 쉽게 찾고 사용할 수 있습니다. (Ia6242, b/155482676)

  • Modifier.drawBackground의 이름이 Modifier.background로 바뀌었습니다. (I13677)

버전 0.1.0-dev15

2020년 7월 22일

androidx.compose.runtime:runtime-*:0.1.0-dev15가 출시되었습니다. 버전 0.1.0-dev15에 포함된 커밋을 확인하세요.

종속 항목 업데이트

  • Compose의 0.1.0-dev15 버전을 사용하려면 위의 종속 항목 선언에 표시된 새로운 코드 스니펫에 따라 종속 항목을 업데이트해야 합니다.

API 변경사항

  • 이제 @Model 주석이 지원 중단됩니다. state 및 mutableStateOf를 대안으로 사용합니다. 이번 지원 중단은 여러 신중한 논의 끝에 결정되었습니다.

    근거

    근거에는 다음이 포함되지만 이에 국한되지는 않습니다.

    • 교육이 필요한 API 노출 영역 및 개념이 감소합니다.
    • 다른 유사한 툴킷(Swift UI, React, Flutter)과 더욱 원활하게 호환됩니다.
    • 되돌릴 수 있는 결정입니다. 나중에 언제든지 @Model을 가져올 수 있습니다.
    • @Model을 처리해야 할 작업으로 구성하는 데 있어서 발생하는 특수한 사용 및 답변하기 어려운 질문을 삭제합니다.
    • @Model 데이터 클래스, 등호, 해시코드 등
    • 일부 속성은 '관찰'되고 나머지는 관찰되지 않게 하려면 어떻게 해야 하나요?
    • 관찰에서 사용할 구조 동등성과 참조 동등성을 각각 지정하려면 어떻게 해야 하나요?
    • 시스템에서 '매직'을 줄입니다. 즉, 시스템이 실제보다 더 영리하다고(즉, 목록을 식별하는 방법을 알고 있다고) 가정할 가능성을 줄입니다.
    • 관찰의 세부사항을 더 직관적으로 파악할 수 있습니다.
    • 클래스의 변수에서 속성으로의 리팩터링 가능성을 개선합니다.
    • State별로 수동 최적화할 가능성이 잠재적으로 생깁니다.
    • 나머지 생태계와 더 원활하게 호환되고 불변 또는 '변경 가능한 상태를 허용'하는 데 모호성을 줄입니다.

    이전 참고사항

    @Model의 거의 모든 기존 사용법은 두 가지 방법 중 하나로 상당히 쉽게 변환됩니다. 아래 예에서는 속성이 두 개인 @Model 클래스가 호환 가능하게 사용됨을 보여줍니다.

    @Model class Position(
     var x: Int,
     var y: Int
    )
    
    @Composable fun Example() {
     var p = remember { Position(0, 0) }
     PositionChanger(
       position=p,
       onXChange={ p.x = it }
       onYChange={ p.y = it }
     )
    }
    

    대안 1: State<OriginalClass> 사용 및 사본 생성

    이 접근 방식은 Kotlin의 데이터 클래스를 사용하면 더 쉽습니다. 기본적으로 모든 이전 var 속성을 데이터 클래스의 val 속성으로 만들고 remember 대신 state를 사용한 다음 데이터 클래스 copy(...) 편의 메서드를 사용하여 상태 값을 원본을 복제한 사본에 할당합니다.

    데이터 클래스의 유일한 변형이 State 인스턴스가 만들어진 동일한 범위에서 실행된 경우에만 이 접근 방식이 효과가 있다는 데 유의해야 합니다. 데이터 클래스가 내부적으로 자신을 변형하여 사용 범위 밖에서 사용되고 있으며 이를 관찰하는 데 의존하고 있다면 다음 접근 방식을 사용하는 것이 좋습니다.

    data class Position(
     val x: Int,
     val y: Int
    )
    
    @Composable fun Example() {
     var p by state { Position(0, 0) }
     PositionChanger(
       position=p,
       onXChange={ p = p.copy(x=it) }
       onYChange={ p = p.copy(y=it) }
     )
    }
    

    대안 2: mutableStateOf 및 속성 위임 사용

    이 접근 방식은 Kotlin의 속성 위임과 개발자가 MutableState 인스턴스를 구성 밖에서 만들도록 허용하는 mutableStateOf API를 사용하면 더 쉽습니다. 기본적으로 원래 클래스의 모든 var 속성을 속성 위임으로 mutableStateOf가 있는 var 속성으로 교체합니다. 이렇게 하면 클래스 사용법이 전혀 변경되지 않고 클래스의 내부 구현만 변경되는 이점이 있습니다. 그러나 각 속성이 이제 개별적으로 관찰/작성되므로 동작은 원래 예와 완전히 동일하지는 않습니다. 따라서 리팩터링 후에 확인하는 재구성 범위가 더 좁아질 수 있는데 이는 좋은 현상입니다.

    class Position(x: Int, y: Int) {
     var x by mutableStateOf(x)
     var y by mutableStateOf(y)
    }
    
    // source of Example is identical to original
    @Composable fun Example() {
     var p = remember { Position(0, 0) }
     PositionChanger(
       position=p,
       onXChange={ p.x = it }
       onYChange={ p.y = it }
     )
    }
    

    (I409e8, b/152050010, b/146362815, b/146342522, b/143413369, b/135715219, b/143263925, b/139653744)

  • Compose 컴파일러의 코드 생성 전략을 변경했습니다. 변경하기 전에는 Compose 컴파일러에서 호출을 구성 가능한 함수로 변환했습니다. 이번 변경으로 이제 구성 가능한 함수의 본문은 변환하고 호출 사이트의 대부분은 변경하지 않고 그대로 둡니다.

    이는 Compose 런타임과 통신하는 로직이 대부분 호출 사이트가 아니라 함수 본문의 시작 부분에서 발생함을 의미합니다.

    이번 변경은 모든 Compose 사용에서 소스와 호환됩니다. 대부분의 Compose 사용자는 이번 변경으로 인해 어떤 코드도 업데이트할 필요가 없습니다.

    이 작업을 지원하기 위해 모든 구성 가능한 함수의 JVM 서명이 변경되었습니다. 단일 매개변수를 허용하는 구성 가능한 함수는 3개의 매개변수를 허용하는 함수로 변환됩니다. 추가 매개변수는 '키' 정수인 컴포저, 호출을 통한 메타데이터 전파에 사용되는 비트마스크 정수입니다.

    이제 Compose는 기본 인수를 구성 가능한 함수로도 변환합니다. 함수 자체의 추가 합성으로 인한 기본 오버로드 없이 기본 인수를 변환하므로 이러한 변경으로 인해 정의되는 함수의 수가 줄어듭니다.

    이로 인해 알려진 의도된 동작 변경사항은 다음과 같습니다.

    1. 일부 호출이 이전에는 건너뛰지 않던 곳을 건너뜁니다.
    2. 이제 기본 인수 표현식의 구성 가능한 표현식이 올바르게 작성 및 처리됩니다.

    이 작업에는 다음과 같은 최적화가 포함되어 있습니다. 1. 매개변수 비교 결과는 호출 그래프를 통해 다른 구성 가능한 함수로 전파됩니다. 이렇게 하면 런타임 시 비교 작업이 적게 발생하고 슬롯 표 크기가 줄며 이전에는 건너뛰지 않던 구성 가능한 함수를 더 많이 건너뜁니다. 2. 컴파일 시간에 '정적'이라고 판단된 매개변수는 더 이상 런타임에 비교되거나 저장되지 않습니다. 따라서 비교 횟수와 슬롯 표 크기가 줄어듭니다. 3. 함수 본문의 제어 흐름 구조는 생성되는 그룹 수를 최소화하는 데 사용되므로 슬롯 표 크기가 줄고 런타임 동안 작업도 줄어듭니다. 4. 함수의 사용되지 않은 전달 및 수신자 매개변수는 함수의 본문 안에서 사용되지 않으면 함수의 건너뛰기 가능성을 판단하는 데 포함되지 않습니다.

    대부분의 브레이킹 체인지는 다음과 같이 컴파일러가 직접 타겟팅하는 API로 인해 발생하며 Compose의 일반적인 사용에는 영향을 미치지 않습니다. 1. Composer::startExpr이 삭제되었습니다. 2. Composer::endExpr이 삭제되었습니다. 3. Composer::call이 지원 중단되었습니다. 4. key의 non-varargs 오버로드가 삭제되었습니다. 앞으로는 vararg 버전을 사용하세요. 5. Pivotal 주석이 지원 중단되었습니다. 대신 key를 사용하세요. 6. ScopeUpdateScope::updateScope가 함수 1이 아닌 함수 3을 예상하도록 변경되었습니다. 7. restartableFunction 및 restartableFunctionN이 추가 컴파일 시간 매개변수를 포함하도록 업데이트되었습니다. (I60756, b/143464846)

  • sortWith와 removeRange가 MutableVector에 추가되었습니다. (Icccf7)

  • CompositionLifecycleObserver의 기본 메서드 구현이 추가되었습니다. (I24289)

  • 이제 적용자를 사용하려면 구성을 삭제하기 위한 clear() 메서드가 필요합니다. (Ibe697)

  • 전체 목록을 복사하지 않고도 asMutableList()를 공개 API에 전달할 수 있도록 asMutableList()를 MutableVector에 추가했습니다. (I298df)

  • 이벤트에 대한 응답으로 작업을 실행할 때 구성에서 관리되는 CoroutineScope를 가져올 수 있도록 rememberCoroutineScope()를 추가했습니다. (I0e264)

  • MutableVector는 어떠한 표준 Collection 인터페이스도 구현하지 않는 새로운 컬렉션입니다. 이 컬렉션은 여타 요구사항보다 높은 속도를 제공하며 내부 구현에만 사용하도록 설계되었습니다. (I8ebd6)

  • Compose에 필요한 Kotlin 버전에서 문제가 발생하지 않도록 StableMutableListStableMutableMap을 일시적으로 삭제했습니다. 이러한 인터페이스는 문제가 없는 Kotlin 버전으로 Compose가 업데이트되면 다시 도입될 예정입니다.

    SnapshotStateListSnapshotStateMap이 이제 공개되지만 StableMutableListStableMutableMap이 복원되면 지원이 중단될 예정입니다. (Ia7769)

  • 애니메이션 타이밍을 위한 최상위 withFrameNanos 함수를 추가했습니다. (Ie34c5)

  • @Untracked 주석이 지원 중단되었습니다. @ComposableContract(tracked=false)를 대신 사용하세요. (Id211e)

  • RestartableFunction 및 관련 API의 이름이 ComposableLambda 등으로 변경되었습니다. 이러한 API는 컴파일러를 통해서만 타겟팅되었으므로 대개 소스 수준 호환성에는 영향을 미치지 않습니다. 이름 변경의 주된 이유는 이 클래스가 스택 트레이스에 표시될 때 더 나은 항목과 통신하도록 하기 위함입니다. (I7eb25)

  • @Composable 주석이 클래스에서 더 이상 유효하지 않습니다. (Ia5f02)

  • Ambient<T>는 이제 @Immutable이 아닌 @Stable입니다. (I0b4bb)

  • 이 변경 전에 Compose 컴파일러 플러그인은 @Composable 함수 내에 있는 생성자 호출(있는 경우)을 특별한 방식으로 가로챘습니다. (I5205a, b/158123804)

  • Recompose 컴포저블은 더 이상 유용한 추상화가 아닙니다. 대부분의 재구성은 MutableState 할당의 결과로 발생해야 합니다. 그 외의 경우에는 invalidate 함수를 사용하여 현재 범위의 재구성을 트리거하는 것이 좋습니다. (Ifc992)

  • 관찰은 더 이상 유용한 추상화가 아닙니다. 관찰을 복제해야 한다면 구성 가능한 람다 매개변수를 실행하는 구성 가능한 함수를 만들기만 하면 관찰의 구현을 복제할 수 있습니다. 예: @Composable fun Observe(body: @Composable () -> Unit) = body() (I40d37)

  • @Direct가 지원 중단되고 @ComposableContract(restartable=false)로 대체되었습니다. (If4708)

  • 최근 도입된 StateFlow를 위한 어댑터가 추가되었습니다(I61dd8, b/156233789). StateFlow는 초기 값을 미리 채워 반환된 State가 null이 허용되지 않는 항목이 되도록 합니다.

  • 흐름용 어댑터가 추가되었습니다. 사용 예: val value by flow.collectAsState() (If2198, b/153375923)

  • [변경 가능] 주 속성 위임 연산자가 Kotlin 1.4 속성 위임 최적화를 지원하기 위해 확장 프로그램으로 이동했습니다. by state { ... } 또는 by mutableStateOf(...)를 계속 사용하려면 호출자가 가져오기를 추가해야 합니다. (I5312c)

  • androidx.compose.ViewComposer가 androidx.ui.node.UiComposer로 이동했습니다. androidx.compose.Emittable은 삭제되었습니다. 이 항목은 ComponentNode와 중복되었습니다. androidx.compose.ViewAdapters는 삭제되었습니다. 더 이상 지원되지 않는 사용 사례입니다. Compose.composeInto가 지원 중단되었습니다. 대신 setContent 또는 setViewContent를 사용하세요. Compose.disposeComposition이 지원 중단되었습니다. 대신 setContent에서 반환되는 Composition에서 dispose 메서드를 사용하세요. androidx.compose.Compose.subcomposeInto를 androidx.ui.core.subcomposeInto로 이동했습니다. ComponentNode#emitInsertAt의 이름이 ComponentNode#insertAt로 변경되었습니다. ComponentNode#emitRemoveAt의 이름이 ComponentNode#removeAt로 변경되었습니다. ComponentNode#emitMode의 이름이 ComponentNode#move로 변경되었습니다. (Idef00)

  • ComposeFlags.COMPOSER_PARAM 플래그를 true로 업데이트했습니다. 이는 Compose 플러그인의 코드 생성 전략을 변경합니다. 높은 수준에서 이는 @Composable 함수가 추가 합성 매개변수와 함께 생성되어 후속 @Composable 호출로 전달되도록 합니다. 이는 실행을 적절히 관리하기 위한 런타임을 확보하기 위함입니다. 그러나, 이 기능은 중요한 바이너리 브레이킹 체인지이므로 승인된 모든 Compose 사용 시 소스 수준의 호환성을 유지해야 합니다. (I7971c)

  • ambients API에 브레이킹 체인지가 있습니다. 자세한 내용은 로그와 Ambient<T> 문서를 참조하세요. (I4c7ee, b/143769776)

  • LiveData용 어댑터가 있는 새로운 아티팩트인 ui-livedata를 추가했습니다. 사용 예: val value by liveData.observeAsState() (Ie9e8c, b/150465596)

  • 명시적 초기 값이 없는 Rx 어댑터가 지원이 중단되었습니다. null을 사용하는 것이 항상 최적의 기본값은 아닙니다. 예를 들어 List가 있는 경우 emptyList() 또는 기타 합당한 기본값으로 시작하는 것이 더 좋습니다. (I00025, b/161348384)

  • RxJava2용 어댑터가 있는 새 아티팩트인 ui-rxjava2를 추가했습니다. 사용 예: val value by observable.subscribeAsState() (Ifab4b, b/153369097)

  • 이제 null을 허용하는 유형과 함께 savedInstanceState()를 사용할 수 있습니다. (I6847f, b/153532190)

  • 맞춤 Saver 객체를 더 쉽게 작성할 수 있도록 새 listSaver() 및 mapSaver()가 추가되었습니다. (I8cf68, b/152331508)

  • 새 함수: savedInstanceState() 및 rememberSavedInstanceState(). state() 및 remember()와 유사하지만 저장된 인스턴스 상태 지원이 내장되어 있습니다. (If1987, b/152025209)

버그 수정

  • runOnIdleCompose의 이름이 runOnIdle로 변경되었습니다. (I83607)
  • LayoutNode 실험용 API가 제작되었습니다. (I4f2e9)
  • androidx.ui.foundation.TextFieldValue 및 androidx.ui.input.EditorValue는 지원 중단되었습니다. 이 유형을 사용하는 TextField, FilledTextField, CoreTextField 컴포저블도 지원 중단되었습니다. 대신 androidx.ui.input.TextFieldValue를 사용하세요. (I4066d, b/155211005)
  • 지원 중단된 DrawBackground API를 삭제하고 수정자의 drawBackground 확장 API로 대체했습니다. 코드 경로를 줄이고 수정자를 구성의 일부로 생성할 필요가 없도록 색상, 브러시 및 페인트 drawBackground 구현을 리팩터링했습니다. (I0343a)
  • 캔버스를 노출하여 CanvasScope를 대신 노출하는 상위 수준 Compose API를 업데이트했습니다. 따라서 소비자가 자체 Paint 객체를 유지하지 않아도 됩니다. 캔버스에 계속 액세스해야 하는 소비자의 경우 콜백을 제공하여 기본 캔버스에서 그리기 명령어를 실행하는 drawCanvas 확장 메서드를 사용하면 됩니다. (I80afd)
  • 람다 API 후행 WithConstraints가 변경되었습니다. 이제 두 매개변수 대신 제약 조건 및 layoutDirection 외에도 Dp에서 minWidth, maxWidth, minHeight 및 maxHeight 속성을 제공하는 수신기 범위가 있습니다. (I91b9a, b/149979702)
  • 대칭 패딩 수정자를 추가했습니다. (I39840)
  • 임의의 Alignment가 아닌 세로 또는 가로 Alignment를 예상하도록 wrapContentWidth 및 wrapContentHeight를 업데이트했습니다. 중력 수정자가 세로 또는 가로 Alignment를 허용하도록 업데이트되었습니다. 맞춤 연속 Alignment를 지원하기 위해 Row, Column, Stack이 업데이트되었습니다. (Ib0728)
  • ui-text 모듈의 이름이 ui-text-core로 변경되었습니다. (I57dec)
  • 다음과 같이 DrawModifier API가 개선됩니다.
    • 수신기 범위를 draw() ContentDrawScope로 설정했습니다.
    • draw()의 모든 매개변수를 삭제했습니다.
    • DrawScope는 이전 CanvasScope와 동일한 인터페이스를 사용합니다.
    • ContentDrawScope는 drawContent() 메서드를 사용합니다. (Ibaced, b/152919067)
  • ColoredRect가 지원 중단되었습니다. 대신 Box(Modifier.preferredSize(width, height).drawBackground(color))를 사용하세요. (I499fa, b/152753731)
  • 수정자와 연산자를 팩토리 확장 함수로 대체했습니다.(I225e4)
  • 행 및 열 외부에서 RowScope 및 ColumnScope 멤버에 액세스할 수 있습니다. (I3a641)
  • LayoutFlexible을 LayoutWeight로 이름을 변경했습니다. 채우기 위해 긴 매개변수의 이름을 변경했습니다. (If4738)
  • withConstraints에 LayoutDirection 매개변수가 있습니다. (I6d6f7)
  • 자연스럽게 기억할 수 있도록background의 이름을 DrawBackground로 변경했습니다. (Ia0bd3)
  • ButtonStyle을 고유 함수로 대체했으며 텍스트(문자열) 오버로드를 삭제했습니다. 사용량 정보는 업데이트된 샘플을 참조하세요. (If63ab, b/146478620, b/146482131)
  • 이제 runOnIdleComposerunOnUiThread는 ComposeTestRule의 메서드가 아닌 전역 함수입니다. (Icbe8f)

외부 기여

  • Compose Runtime 포팅 레이어에서 Looper, Handle 같은 불필요한 API를 삭제했습니다. (I6847d)
  • 초기 값이 없는 Flow<T>.collectAsState()가 지원 중단되었습니다. 대신 StateFlow<T>를 사용하거나 명시적인 초기 값을 전달하세요. (I63f98, b/157674865)