Compose Foundation

透過現成可用的建構區塊編寫 Jetpack Compose 應用程式,並擴充基礎以建構您自己的設計系統元件。
最近更新時間 穩定版 候選版 Beta 版 Alpha 版
2024 年 3 月 20 日 1.6.4 - - 1.7.0-alpha05

結構

Compose 是由 androidx 中的 7 個 Maven 群組 ID 所組成。每個群組都包含一個指定功能子集,且各有一組專屬的版本資訊。

下表提供各群組的說明和每組版本資訊的連結。

群組說明
compose.animation在 Jetpack Compose 應用程式中建構動畫,提供豐富的使用者體驗。
compose.compiler透過 Kotlin 編譯器外掛程式轉換 @Composable 函式,並啟用最佳化功能。
compose.foundation透過現成的構成元素編寫 Jetpack Compose 應用程式,然後進一步擴充基礎,建構出自己的設計系統元件。
compose.material運用現成的 Material Design 元件建構 Jetpack Compose UI。這是更高層級的 Compose 進入點,用意是確保提供的元件與 www.material.io 上所述元件相符。
compose.material3運用新一代的 Material Design 3 元件建構 Jetpack Compose UI。Material 3 提供新的主題設定和元件,以及動態色彩等 Material You 個人化功能,可呼應全新的 Android 12 視覺風格和系統 UI。
compose.runtimeCompose 程式設計模型和狀態管理的基本構成元素,以及 Compose Compiler 外掛程式指定的核心執行階段。
compose.ui與裝置互動所需的 Compose UI 基礎元件,包括版面配置、繪圖及輸入。

宣告依附元件

如要新增 Compose 的依附元件,必須將 Google Maven 存放區新增至您的專案。詳情請參閱「Google 的 Maven 存放區」一節。

在應用程式或模組的 build.gradle 檔案中,新增所需構件的依附元件:

Groovy

dependencies {
    implementation "androidx.compose.foundation:foundation:1.6.4"
}

android {
    buildFeatures {
        compose true
    }

    composeOptions {
        kotlinCompilerExtensionVersion = "1.5.11"
    }

    kotlinOptions {
        jvmTarget = "1.8"
    }
}

Kotlin

dependencies {
    implementation("androidx.compose.foundation:foundation:1.6.4")
}

android {
    buildFeatures {
        compose = true
    }

    composeOptions {
        kotlinCompilerExtensionVersion = "1.5.11"
    }

    kotlinOptions {
        jvmTarget = "1.8"
    }
}

如要進一步瞭解依附元件,請參閱「新增建構依附元件」一文。

意見回饋

您的意見可協助我們改善 Jetpack。如果您發現新問題,或是有改進這個程式庫的建議,請告訴我們。回報新問題前,請先查看這個程式庫的現有問題。只要按一下星號按鈕,即可投票給現有的問題。

建立新問題

詳情請參閱 Issue Tracker 說明文件

1.7 版

1.7.0-alpha05 版

2024 年 3 月 20 日

發布 androidx.compose.foundation:foundation-*:1.7.0-alpha05。1.7.0-alpha05 版包含這些修訂版本

API 變更

  • 移除了樣式超連結適用的實驗性 LocalTextLinkStyle 組合本機。(Iebfa7)。
  • 已移除使用 onLinkClicked 引數的 BasicText 實驗性覆寫設定。我們之後會更換支援超連結的 API。(I107d5)。
  • 移除 TextFieldStateTextFieldBuffer 下的程式碼點相關方法和屬性。同時從其餘選取項目和組合相關 API 中移除 inChars 後置字串。(Ief7ce)。
  • 現在 AnchoredDraggablecurrentValue 會在傳遞錨點時更新使用 settledValue 接收先前的 currentValue 語意,且只會在錨點設定時更新。進度現在會以函式的形式顯示 (需要起點和終點),而非屬性。(Ibe6e8b/318707189b/298271489b/294991954)
  • BasicTextField(state)TextFieldStateInputTransformationOutputTransformationTextFieldLineLimitsTextFieldDecorator 已升級為穩定版。(I9582b)。
  • 推出了 InterceptPlatformTextInput,協助編寫低階輸入法編輯器相關測試和其他低階輸入法編輯器用途。淘汰了 PlatformTextInputTestOverride。(I862edb/322680547)
  • restrictedConstraints() 分割為兩個方法:fitPrioritizingWidth()fitPrioritizingHeight() (I6d7fd)

外部貢獻

  • 新增了 2 個 API isLastScrollForward/isLastScrollBackward,用於檢查最新捲動動作的捲動方向;如果沒有捲動動作,則傳回 false。(I63a0e)。

1.7.0-alpha04 版

2024 年 3 月 6 日

發布 androidx.compose.foundation:foundation-*:1.7.0-alpha04。1.7.0-alpha04 版包含這些修訂版本

API 變更

  • 支援 Android U 之後的裝置支援觸控筆手寫功能。(I002e4)。
  • hintLocales 新增至 KeyboardOptions,讓 TextFields 能夠提示特定語言代碼的輸入法編輯器,以預設偏好語言。(Id18c2)。
  • 已移除採用 value: StringonValueChange: () -> String 參數的實驗性 BasicTextField2BasicSecureTextField 超載。(I568b4)。
  • InputTransformation 中新增選用的 applySemantics 函式,藉此影響所套用的 BasicTextField2 語意。(I74a2fb/170648072)
  • 在本 CL 中,我們新增了 GetScrollViewportLength 語意動作,以便針對在 Compose 中捲動的元件,提供管道至 a11y 系統。這個 CL 也會應用在 Foundation Scrollable 清單中使用上述屬性。(Ic5fa2)。
  • BasicTextField2 已重新命名為 BasicTextField。(Ie5713)。
  • FocusRequester.createRefs 現在是穩定版 (I4d92cb/261436820)
  • 推出 DelegatableNode.scrollIntoView(),允許修飾符節點直接發出 scrollIntoView 要求。(I2b3b7b/299939840)
  • 推出 DelegatableNode.requireView(),允許修飾符節點在不讀取本機組合的情況下取得目前的 Android View(I40768)。
  • 推出內容比對流程列範圍與內容流程欄範圍中的結構定義資訊,在寬度和高度的最大寬度和高度上提供行索引、位置和限制。超出寬度/高度上限的項目可能會移至下一行,或根據溢位設定略過。(Id13f8b/292114798)

修正錯誤

  • 修正錯誤:在某些情況下,切換 TextFieldenabledreadOnly 屬性會導致當機。(Iae17b)。

1.7.0-alpha03 版

2024 年 2 月 21 日

發布 androidx.compose.foundation:foundation-*:1.7.0-alpha031.7.0-alpha03 版包含此連結所列的修訂項目。

API 變更

  • 推出了 DelegatableNode.requireLayoutCoordinates(),藉此取得 Modifier.Node 目前的 LayoutCoordinates,而無需覆寫 onPlaced,並自行將座標儲存在屬性中。(Ia8657)。
  • 推出了 DelegatableNode.currentLayoutCoordinates,藉此取得 Modifier.Node 目前的 LayoutCoordinates,而無需覆寫 onPlaced,並自行將座標儲存在屬性中。(Iaebaa)。
  • AnchoredDraggable 使用的 DraggableAnchors 效能最佳化。(I89cff)。
  • BasicTextField2androidx.compose.foundation.text2 套件下的相關 API 已移至 androidx.compose.foundation.text。(I9f635)。
  • BasicTextField2 不再接受 CodepointTransformation 參數。使用 BasicSecureTextFieldOutputTransformation。(Id34ff)。
  • 新增只比較兩個 AnnotatedStrings 註解的方法。(I32659)。
  • 隆重推出 ContextualFlowRow 和強化 FlowRow/Column 搭配 MaxLinesOverflow。很高興在此宣布,實驗性 FlowRowFlowColumn 現已推出強化版本,現在除了 ContextualFlowRowContextualFlowColumn 外,還提供 maxLines 和溢位支援。這項更新旨在提供效能最佳元件,其中 ContextualFlow* 非常適合大量使用少量 maxLines 設定,且動態 +N 會看到更多按鈕的項目,FlowRowFlowColumn 則適用於少量項目 (少於 100 個項目)。重要事項:如要在 FlowRowFlowColumn 中維持現有行為,讓所有項目 (無論項目是否符合交叉軸上限) 都存在,請在初始化期間將 overflow 設為 FlowRowOverflow.VisibleFlowColumnOverflow.Visible。歡迎瀏覽 ContextualFlowRowSampleFlowRowSample,瞭解這些新功能的實際應用範例。(Ib9135b/293577082)

修正錯誤

  • 遊標動畫不會再要求開啟和關閉狀態之間的影格。(Ia2253)。
  • KeyboardOptions 已淘汰的複製建構函式現在會正確複製所有屬性。(If12de)。

1.7.0-alpha02 版

2024 年 2 月 7 日

發布 androidx.compose.foundation:foundation-*:1.7.0-alpha021.7.0-alpha02 版包含此連結所列的修訂項目。

API 變更

  • HorizontalPagerVerticalPagerPagerState 已升級為穩定版。(I67660b/316966909)
  • 新增了 LocalTextLinkStyle 本機組合,可讓您在應用程式中變更文字中連結的樣式。如果您在應用程式中使用自己的主題,則應根據主題設定在本機設定這個組合。使用 Material Design 主題時,連結的顏色會預設為 Material 的主要顏色。(I7eb10)。
  • 推出了 receiveContent 修飾符,可讓開發人員在 Jetpack Compose 中接收多媒體內容
  • receiveContent 整合了 BasicTextField2,可接受軟體鍵盤或透過剪貼簿貼上動作提供的多媒體內容。(I81b72)。
  • 在本次異動中,我們將將頁面器中的 SnapFlingBehavior 替換為 TargetedFlingBehavior,藉此解鎖其他用途,並提供更靈活的彈性。(I762ea)。
  • 這項變更會將 Snapping API 變成穩定版。我們也將清除部分測試程式碼,並新增更多範例至 Snapping。(Id8da9)。
  • 導入 TargetedFlingBehavior,這個 FlingBehavior 允許傳播目前動畫狀態及其目標捲動偏移的相關資訊。(I6a207)。

修正錯誤

  • BasicTextField2 現在會在輸入內容時將遊標保留在檢視畫面中,如果因為輸入內容而遭捲動,則遊標會停留在檢視畫面中。(Ieb856b/237190748)

外部貢獻

  • 新增實驗性 API,用於設定 LazyLists 的預先擷取行為。(I022a4)。

1.7.0-alpha01 版

2024 年 1 月 24 日

發布 androidx.compose.foundation:foundation-*:1.7.0-alpha011.7.0-alpha01 版包含此連結所列的修訂項目。

新功能

  • 新增了 Indication APIIndicationNodeFactory。與先前 (現已淘汰) API 相比,Indication實作成效更佳rememberUpdatedInstance。如需遷移資訊,請前往 developer.android.com
  • clickable / combinedClickable / selectable / toggleable 現在接受可為空值的 MutableInteractionSource 參數。如果為空值,且提供的 IndicationIndicationNodeFactory,則只能在需要時延遲建立 Indication,如此可改善效能。如果您未提升並使用 MutableInteractionSource,建議傳遞空值。

API 變更

  • AnchoredDraggable 中導入 DecayAnimation,這項變更會在 AnchoredDraggable 中新增 decayAnimationSpec 參數,以便在設為其中一個錨定標記時使用衰減動畫。這項變更也包括將現有的 animationSpec 重新命名為 snapAnimationSpec,以協助您瞭解每個規格的用途。
  • BasicTextField2 適用於實驗功能。此版本應大致與 BasicTextField 的功能一致,且行為應可用於實際工作環境。但這個 API 目前仍處於實驗階段。穩定版之前,系統會將其重新命名為 BasicTextField,並移至同一個套件中。
  • 推出了適用於 BasicTextField2OutputTransformation API 第一個草稿。這個 API 會取代舊版 BasicTextFieldVisualTransformation 的大多數用途。但這項服務尚未完成,有些功能也無法正常運作。不過,歡迎你針對 API 可用性提出意見回饋,告訴我們你的用途。(aosp/2708848)。
  • 推出了 LinkAnnotation,可讓您在文字中加入連結和可點擊屬性。連結功能尚未全面完成,我們將陸續推出更多 API 變更。
  • 推出了 receiveContent 修飾符,可讓開發人員在 Jetpack Compose 中接收多媒體內容
  • receiveContent 整合了 BasicTextField2,可接受軟體鍵盤或剪貼簿貼上功能提供的多媒體內容。
  • KeyboardOptions.shouldShowKeyboardOnFocus 可讓您停用 BasicTextField 的預設行為,要求聚焦螢幕鍵盤。
  • TextInputServiceLocalTextInputService 現已淘汰。請改用 PlatformTextInputModifierNode 直接與平台 IME API 整合。(aosp/2862698)。
  • 淘汰了 Indication#rememberUpdatedInstance。對成效造成極大的負面影響,且會妨礙其他最佳化作業。請改用新的 IndicationNodeFactory API。

修正錯誤

  • 現在 BasicTextField 會在傳遞 VisualTransformation 時,預先驗證一小部分的偏移對應這有助於找出在稍後評估或繪製票證時,導致無法復原的常見程式碼錯誤。藉由在組合期間擲回,開發人員較有可能在開發期間看到這些錯誤,以免造成實際工作環境的當機。(I0fd42)。
  • VisualTransformation如果傳回無效索引的索引 (b/316401857 ),系統不會擲回

1.6 版本

1.6.4 版

2024 年 3 月 20 日

發布 androidx.compose.foundation:foundation-*:1.6.4。1.6.4 版包含這些修訂版本

修正錯誤

  • 在拖曳的第一個影格中,長按並拖曳選取手勢,不會再發生當機情形。(Icdf90b/325307463)

1.6.3 版

2024 年 3 月 6 日

發布 androidx.compose.foundation:foundation-*:1.6.3。1.6.3 版包含這些修訂版本

1.6.2 版

2024 年 2 月 21 日

發布 androidx.compose.foundation:foundation-*:1.6.21.6.2 版包含此連結所列的修訂項目。

修正錯誤

  • 修正 AnimateContentSize 無法正確重設的問題。(I07051)。
  • 修正在某些情況下,intrinsicHeight 文字會過度快取的問題。(3cd398b/217910352)

1.6.1 版

2024 年 2 月 7 日

發布 androidx.compose.foundation:foundation-*:1.6.11.6.1 版包含此連結所列的修訂項目。

修正錯誤

  • 修正捲動超出限制時的傾斜格線度量。(bffc39)。
  • 新增檢查大型尺寸版面配置的檢查。(e74af5)。
  • 修正傾斜格線起始處以 0 個尺寸項目的位置。(785f94)。
  • 依照 onforgotten 的順序呼叫 onRelease 回呼。(31ce3b)。

1.6.0 版

2024 年 1 月 24 日

發布 androidx.compose.foundation:foundation-*:1.6.01.6.0 版包含此連結所列的修訂項目。

自 1.5.0 版之後的重要變更

  • 新增修飾符 Modifier.anchoredDraggable,具備在預先定義的錨點組合之間拖曳和動畫效果的功能。這個修飾符是用來取代 Modifier.swipeable。請參閱遷移指南,瞭解如何使用這個 API 並從 Modifier.swipeable 遷移。
  • 新增應用程式和元件之間的拖曳功能。如要開始使用,請參閱 DragAndDropTargetModifier.dragAndDropSource 和其他 API
  • Modifier.draggable2D 是一種新的修飾符,可讓使用者輕鬆進行 2D 拖曳操作。請參閱範例
  • 新增了 AndroidExternalSurfaceAndroidEmbeddedExternalSurface,以便在 Compose 中新增介面導向元件
  • PagersnapFlingBehaviour 中的各種 API 變更和改善項目
  • 多項重點、文字和插邊 API 已升級為穩定版 API

1.6.0-rc01 版

2024 年 1 月 10 日

發布 androidx.compose.foundation:foundation-*:1.6.0-rc011.6.0-rc01 版包含以下修訂項目。

API 變更

  • 移除 DragAndDropTarget() 擴充功能建構函式。使用 object: DragAndDropTarget {} 建立新的執行個體。(I32318)。

1.6.0-beta03 版

2023 年 12 月 13 日

發布 androidx.compose.foundation:foundation-*:1.6.0-beta031.6.0-beta03 版包含以下修訂項目。

修正錯誤

  • 修正影響以無限限制測量極大型文字的當機問題。(I1a7dfb/312294386)
  • PlatformImeOptions 現在是具體類別,而不是介面。(If40a4)。

1.6.0-beta02 版

2023 年 11 月 29 日

發布 androidx.compose.foundation:foundation-*:1.6.0-beta021.6.0-beta02 版包含以下修訂項目。

修正錯誤

  • 修正僅經過重新版面配置捲動後,canScroll 無法更新的問題(I60a86)。
  • 修正小捲動後的 Modifier.animateItemPlacement()LookaheadScope 問題。(I3a2b7)。

1.6.0-beta01 版

2023 年 11 月 15 日

發布 androidx.compose.foundation:foundation-*:1.6.0-beta011.6.0-beta01 版包含此連結所列的修訂項目。

API 變更

  • DragAndDropTarget 修飾符現在可明確接收接收的 DragAndDropTarget,並提供 lambda,可選擇加入拖曳工作階段。DragAndDropModifierNode 有兩個工廠函式。一個用於接收傳輸作業,另一個則用於轉移資料 (I69481)
  • maximumFlingVelocity 更新為以 Float 表示。更新說明文件,進一步釐清 maximumFlingVelocity 這個單位。(I8adc7)。
  • DragAndDropModifierNode 工廠中的 onDragAndDropStart 已重新命名為 acceptDragAndDropTransfer

    已將 acceptsDragAndDropTransfer 新增至 dragAndDropTarget Modifier,以便從拖曳工作階段接受。如果對拖曳工作階段感興趣,這個 lambda 會傳回可行的 DragAndDropTarget。其他用於處理拖曳事件的 lambda 已取代為

    新增了 DragAndDropTarget 工廠函式,可從拖曳工作階段接收 (Iebf3a)

  • AnchoredDraggable 中公開 startDragImmediately,即可控制使用該手勢時如何偵測拖曳手勢。在小工具為目標錨定標記建立動畫時,設定此項目非常實用。請參閱範例。(Ie6d13b/285139987)

  • 基礎工具提示 API 現已更名為 @ExperimentalFoundationApi (I30b0b)

  • 移除了 DragAndDropInfo 做為類型 DragAndDropModifierNode.drag,現在會採用 transferData、裝飾大小和拖曳裝飾 DrawScope lambda

    DragAndDropTarget 提供特定拖曳事件的方法,而非單一抽象方法

    DragAndDropModifierNode 工廠函式中的 onDragAndDropEvent 已重新命名為 onDragAndDropStart,以更明確的方式說明提供的 DragAndDropTarget 僅適用於特定拖曳工作階段

    移除了 DragAndDropEventType (I645b1)

  • PlatformTextInputModifierNode.runTextInputSession 已重新命名為 establishTextInputSession。(I03cd0)。

  • TextSubstitution 取代 OriginalText。(Ifa5a8)。

  • PlatformTextInputModifierNode.textInputSession 已重新命名為 runTextInputSession。(Ie9c6b)。

  • SubcomposeLayout 的子項 (以及以其為基礎的版面配置,例如 LazyColumn) 會視為停用。推出了新的 assertIsDeactivated() 測試 API 來測試這類節點。根據預設,其他測試 API 會篩除已停用的節點。(I2ef84b/187188981)

  • Modifier.magnifierclippingEnabled 參數已重新命名為 clip

  • Modifier.magnifiermagnifierCenter 參數設為可為空值並保留相同的預設行為。(I6aa66)。

  • Material SwipeToReveal API (適用於資訊卡和方塊) 現在必須使用以運算單元為基礎的 API (如 Compose 建議),而非以資料類別為基礎的執行個體來建立這些版位。這是一項破壞性變更,請參閱示範和程式碼範例,瞭解如何使用新版 API。(Ia8943)。

修正錯誤

  • PageSize.Fixed 實作 equals 和雜湊碼。(Ie3edeb/300134276)
  • 修正錯誤:當 minWidth 變更時,BasicText 版面配置不會縮小,且 minWidth 低於初始測量限制 maxWidth (Idb19c)
  • ArcLine 中新增對「Sweep Gradient」的轉譯器支援。(I4d5bb)。
  • 修正視窗插邊變更的二進位檔相容性問題 (Iee695)
  • 移除 Material3 方塊/按鈕的 Material 核心層,因為 Microbenchmark 可以在沒有效果的情況下顯示更好的效能。(I55555)。

1.6.0-alpha08 版

2023 年 10 月 18 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha081.6.0-alpha08 版包含此連結所列的修訂項目。

新功能

  • Modifier.draggable2D 是一種新的修飾符,可讓使用者輕鬆進行 2D 拖曳操作。請參閱範例 (Id95f5b/214412658)

API 變更

  • Modifier.dragAndDrawSourceonDrawDragShadow lambda 重新命名為 drawDragDecoration,而 DragAndDropInfo 將大小參數重新命名為 dragDecorationSize。(Id0e30b/303904810)
  • BasicTextField2decorationBox 參數已重新命名為 decorator。其類型也變更為對等的趣味介面 TextFieldDecorator。(I23c1c)。

修正錯誤

  • 改善 BasicTextField 有關 onValueChange 規定的說明文件。(I90fc9b/160257648)

1.6.0-alpha07 版

2023 年 10 月 4 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha071.6.0-alpha07 版包含此連結所列的修訂項目。

API 變更

  • 推出 PlatformTextInputMethodTestOverride,以便編寫自訂文字編輯器的測試。(Id159b)。
  • GraphicsSurface 重新命名為 AndroidExternalSurface (I11680)
  • 新增 DisableNonLinearFontScalingInCompose 臨時標記,以停用非線性字型縮放功能。如果需要更多時間進行清理,請在測試中設定 DisableNonLinearFontScalingInCompose = true。這個旗標將從 Compose 1.6.0-beta01 中移除。(Ic9486)。
  • 新增 ColorListColorSet 集合以避免分配。(I744bd)。
  • 這項變更移除已轉換成 SnapLayoutInfoProvider 實作詳細資料的 shortSnapVelocityThreshold。(I65f6d)。
  • 新增用於啟動拖曳工作階段的 dragAndDropSource 修飾符,以及接收來自拖曳工作階段的 dragAndDropTarget 修飾符 (Ib7828b/286038936)
  • 更新 SnapPositionInLayout 說明文件和位置方法。在 SnapPositionInLayout 中的位置方法加入內容邊框間距。(Id7938b/300116110)
  • UndoState 新增至 TextFieldState,可讓您復原/重做使用者所做的變更。(Icc024)。

修正錯誤

  • 修正了 basicMarquee 在速率變更後不會產生動畫效果的問題。(Id2e77b/297974036)

1.6.0-alpha06 版

2023 年 9 月 20 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha061.6.0-alpha06 版包含此連結所列的修訂項目。

新功能

  • SurfaceViewTextureView: GraphicsSurface()EmbeddedGraphicsSurface() 新增可組合的包裝函式。這是實驗性 API,可能會隨時變更和修改。(I9ddb2)。
  • Modifier.magnifier() 現在是穩定版 API。包括移除 MagnifierStyle,改用修飾符本身的內嵌參數。(I83becb/298381260b/262367109b/261438887)

API 變更

  • ScrollScope 中引入 updateCurrentPageupdateTargetPage,這是允許自訂透過 PagerState.scroll 自訂動畫捲動所需的最後一部分。(I9cad5b/267744105b/243786897)
  • SnapFlingBehavior 移除密度。所有 SnapLayoutInfoProvider 的實作都已取得存取密度,因此可能會移除接收器範圍,進而降低 SnapFlingBehaviorSnapLayoutInfoProviders 的複雜實作。(I153c3)。
  • 更多標示為穩定版的修飾符。(I56af1b/298046462)
  • 已將 SnapStepSizeSnapLayoutInfoProvider 中移除。計算方法是使用版面配置資訊,並透過方法或貼齊位移提供。(If320c)。

行為變更

  • Compose 現在使用非線性字型縮放功能,以提升可讀性和無障礙功能。在系統設定中,當字型大小大於 100% 時,小型文字通常會放大,但已經放大的文字只會稍微增加一點。此外,SP 中定義的行高會自動調整,以符合 100% 比例的預期高度。詳情請參閱字型縮放最佳做法。(I11518)

修正錯誤

1.6.0-alpha05 版

2023 年 9 月 6 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha051.6.0-alpha05 版包含此連結所列的修訂項目。

API 變更

  • 為接受不可變動值的 BasicSecureTextField 新增超載,以及用於變更該值的回呼,就像目前的 BasicTextField API 一樣。(Ia4882)。
  • 新增 Modifier.preferKeepClear() 以標示為優先,以便避免 API 33 以上版本中的浮動視窗。(Ib51d5b/297260115)
  • ScrollViewRecyclerView 等檢視畫面元件中的快速滑過速率上限為 ViewConfiguration.ScaledMaximumFlingVelocity。Compose 現在包含自己的 maximumFlingVelocity 版本,現在適用於 Draggable。(Ibf974)。
  • 移除了已淘汰的 PagerPagerState 超載。(Iea07e)。
  • 已將 BasicTooltipBox 新增至 compose.foundation 並更新 PlainTooltipBoxRichTooltipBox,以便將 TooltipBox 與新的 PlainTooltipRichTooltip 可組合項搭配使用。(I79e1d)。

1.6.0-alpha04 版

2023 年 8 月 23 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha041.6.0-alpha04 版本包含以下修訂版本。

API 變更

  • 新增 ReusableComposition 介面,用於管理生命週期及重複使用子組合。(I812d1b/252846775)
  • Modifier.focusGroup 已升級為穩定版 API。(I7ffa3)。
  • 為接受不可變動值的 BasicTextField2 新增超載,以及用於變更該值的回呼,就像目前的 BasicTextField API 一樣。(I3f2b8)。
  • GridItemSpan::currentLineSpan 現在是穩定版 API。(Icc29c)。
  • 接受 contentDescription 的 Canvas 現已成為穩定版 API。(Ib3d29)。
  • ScrollState 中導入 viewportSize,藉此在測量後瞭解使用 ScrollState 的元件 viewPort 大小。(I8b85ab/283102682)
  • 修正 Pager 中的預先擷取與檢視畫面中行為不符的問題。(I93352b/289088847)
  • Modifier.consumeWindowInsets(PaddingValues) 現在是穩定版
    • 現已移除 Deprecated Modifier.consumedWindowInsets API。請改用 Modifier.consumeWindowInsets (Id72bb)。

1.6.0-alpha03 版

2023 年 8 月 9 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha031.6.0-alpha03 版包含此連結所列的修訂項目。

API 變更

  • 新增了 LazyLayout 的超載,因此接受 LazyLayoutItemProvider 的 lambda,而非像之前的純物件。先前的超載已淘汰,(I42a5a)。
  • 新增了設定 privateImeOptions 的支援功能 (Idb772)

修正錯誤

  • 修正了在 readOnly 為 true 時顯示鍵盤的文字欄位。此外,也修正了當聚焦在 readOnly 從 true 變更為 false 時鍵盤無法顯示的問題(I34a19b/246909589)

1.6.0-alpha02 版本

2023 年 7 月 26 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha021.6.0-alpha02 版包含此連結所列的修訂項目。

API 變更

  • 導入 PagerLayoutInfo,其中包含 Pager 中的測量過程後收集的資訊。也推出了 PageInfo,這是 Pager 中單一測量頁面的相關資訊。(Iad003b/283098900)
  • 其他註解,用於指定允許可組合項的輸入值 (I51109)
  • 新增了 SemanticsNodeInteraction.requestFocus,方便您在測試中要求焦點,輕鬆又方便。(Ie8722)。
  • PlatformTextInput* API 經過全面重新設計,(I6c93ab/274661182b/267235947b/277380808)
  • SoftwareKeyboardControllerLocalSoftwareKeyboardController 不再是實驗版,LocalSoftwareKeyboardController 現在也是正確的 CompositionLocal。(I4c364)。
  • Modifier.transformable 現在可在 canPan 參數中提供平移差異,協助判斷允許或禁止的平移方向。(I692aab/266829800)
  • 更新修飾符 consumeWindowInsets,以擴充父類別 AbstractComposeView (Iacd74b/269479941)

1.6.0-alpha01 版

2023 年 6 月 21 日

發布 androidx.compose.foundation:foundation-*:1.6.0-alpha011.6.0-alpha01 版包含此連結所列的修訂項目。

新功能

  • 在基礎中推出全新的 AnchoredDraggable API。可用來建構可在獨立狀態之間拖曳的元件,例如強制回應底部功能表。這個 API 會取代 Material 的 Swipeable API。(I4a2ed)。

API 變更

  • 支援 InputConnection#requestCursorUpdates (I0c69b)
  • 推出 scrollAnimationSpec,允許自訂動畫規格。BringIntoViewCalculator 已更新為 BringIntoViewScroller。(Idb741)。
  • 新增 ResourceResolutionException 類型,以在嘗試載入點陣圖素材資源時擲回的擲回抵射項目,並提供無法載入的資產路徑說明。(I19f44b/230166331b/278424788)
  • 新增語意屬性和動作,以支援文字翻譯。(I4a6bc)。
  • 推出 BringIntoViewCalculator API,可用於自訂 Scrollable 等元件回應 bringIntoView 要求的方式。變更可捲動的超載,可選擇接受 BringIntoViewCalculator 的執行個體。(Iaf5af)。

修正錯誤

  • 新增了 Lint 檢查,如果您在不記憶該結構的情況下在組合中建立 MutableInteractionSource,系統會發出警告,例如用於建立可變動狀態的 Lint 檢查 (Animatable)。(I5daae)。
  • 新增透過滑鼠選取的功能。觸控式選取項目會逐字展開,並縮小字元。(Ic0c6cb/180639271)
  • 新增了 FocusTargetModifierNode 介面,可用來建立自訂 FocusTarget。(I9790e)。

1.5 版

1.5.4 版本

2023 年 10 月 18 日

發布 androidx.compose.foundation:foundation-*:1.5.41.5.4 版包含此連結所列的修訂項目。

1.5.3 版本

2023 年 10 月 4 日

發布 androidx.compose.foundation:foundation-*:1.5.3。這個版本沒有任何變更。

1.5.2 版本

2023 年 9 月 27 日

發布 androidx.compose.foundation:foundation-*:1.5.21.5.2 版包含此連結所列的修訂項目。

修正錯誤

  • 修正在語意失效的情況下,於特定情況下導致當機的文字錯誤。

1.5.1 版

2023 年 9 月 6 日

發布 androidx.compose.foundation:foundation-*:1.5.11.5.1 版包含此連結所列的修訂項目。

修正錯誤

  • 修正了在 readOnly 為 true 時顯示鍵盤的文字欄位。此外,也修正了當聚焦在 readOnly 從 true 變更為 false 時鍵盤無法顯示的問題(I34a19b/246909589)

1.5.0 版

2023 年 8 月 9 日

發布 androidx.compose.foundation:foundation-*:1.5.01.5.0 版包含此連結所列的修訂項目

自 1.4.0 版以來的重要異動

  • 許多基礎修飾符 (包括 Modifier.clickableModifier.draggableModifier.scrollable、版面配置修飾符等) 已遷移至 Modifier.Node API,以降低初始組合的負擔。
  • 改善 Pager 穩定性。目前解決了許多錯誤,
  • pageCount 參數現在位於 PagerState,而非 Pager 本身

1.5.0-rc01 版

2023 年 7 月 26 日

發布 androidx.compose.foundation:foundation-*:1.5.0-rc011.5.0-rc01 版包含此連結所列的修訂項目

修正錯誤

  • 您可以選擇執行檢查,建議將 mutableStateOf() 呼叫遷移至其對應基元的對應特殊類型。其 Lint ID 為 AutoboxingStateCreation。先前,所有專案都會預設啟用這項檢查功能。如要在 Android Studio 編輯器和專案的 Lint 輸出內容中查看這則警告,請在模組的 build.gradlebuild.gradle.kts 設定中宣告 warning "AutoboxingStateCreation",將嚴重性從資訊嚴重性變更為警告 (或更高),如下所示 (I34f7e):

        android {
            lint {
                warning "AutoboxingStateCreation"
            }
            ...
        }
    

1.5.0-beta03 版本

2023 年 6 月 28 日

發布 androidx.compose.foundation:foundation-*:1.5.0-beta031.5.0-beta03 版包含此連結所列的修訂項目。

1.5.0-beta02 版

2023 年 6 月 7 日

發布 androidx.compose.foundation:foundation-*:1.5.0-beta021.5.0-beta02 版包含此連結所列的修訂項目。

1.5.0-beta01 版

2023 年 5 月 24 日

發布 androidx.compose.foundation:foundation-*:1.5.0-beta011.5.0-beta01 版包含此連結所列的修訂項目

API 變更

  • 實作 PlatformDataProvider 提供心率和每日步數。SensorGateway 介面已從公用 API 中移除。(I55b84)。

修正錯誤

  • 在延遲清單/格線等測量期間減少配置 (Iaf9e2)
  • 減少套用快照時的分配比例 (I65c09)
  • 從彈簧動畫中移除配置 (Ie9431)
  • 已從 TextLayout 中移除分配 (I0fd11)
  • 移除指標速率追蹤中的多個配置 (I26bae)

1.5.0-alpha04 版

2023 年 5 月 10 日

發布 androidx.compose.foundation:foundation:1.5.0-alpha04androidx.compose.foundation:foundation-layout:1.5.0-alpha041.5.0-alpha04 版包含此連結所列的修訂項目。

API 變更

  • 已新增含有完整參數清單的最佳化 TextStyle.merge(...)。(Iad234b/246961787)
  • 導入可與 LazyGridState 搭配使用的 SnapLayoutInfoProvider。(I92134b/269237141b/260914964)
  • 為延遲交錯格線項目範圍新增實驗性 Modifier.animateItemPlacement()。對項目套用樣式,即可讓動畫位置自動變更/重新排序動畫。(I4b62db/257034719)
  • GridCells.FixedSize 升級為穩定版。FixedSize 會定義 LazyGrid,其中每個儲存格都會以交叉軸為基礎,剩餘的空間依交叉軸排列。(I8542f)。
  • 引入 Pager 的接收器範圍 PagerScope,以及計算指定頁面偏移的公用程式函式。(If2577)。
  • 在建立貼齊快速滑過行為時加入 snapPositionalThreshold。請使用這個參數在 Pager 中指定短距的位置門檻。(If8f7f)。
  • SnapLayoutInfoProvider.calculateSnappingOffsetBounds 已由 calculateSnappingOffset 取代。在這個新方法中,我們只要求下一個偏移值。此處應在實作層級計算上下限,因為這可能取決於一個需要貼齊的方式。(I923a4)。
  • LazyStaggeredGrid API 已升級為穩定版。(I633a5)。
  • Horizontal/VerticalPager 移除 pageCount。這項資訊必須在建立狀態時提供。將 PagerStaterememberPagerState 更新為接受 pageCount。(Ieb52db/266965072)
  • Horizontal/VerticalPager 移除 pageCount。這項資訊必須在建立狀態時提供。將 PagerStaterememberPagerState 更新為接受 pageCount。(Ifa3cbb/266965072)
  • 在 Pager 的 SnapFlingBehavior 中導入 shortSnapVelocityThreshold。(I7379eb/275579012)
  • 新增 FlowRowScopeFlowColumnScope。(I54fe2)。

修正錯誤

  • 當限制條件具有 minWidthminHeight 時,呼叫以取得 Text 語意時(Ibd072)。
  • 修正迴歸問題:非由 Dialog 可組合項建立對話方塊的文字欄位,鍵盤不會顯示。(I82551b/262140644)

1.5.0-alpha03 版

2023 年 4 月 19 日

發布 androidx.compose.foundation:foundation:1.5.0-alpha03androidx.compose.foundation:foundation-layout:1.5.0-alpha031.5.0-alpha03 版包含此連結所列的修訂項目。

這個版本為 Compose 啟用新的文字轉譯堆疊。新堆疊的效能已經過最佳化,您應該不會發現任何明顯的變更。

如果轉譯後的文字出現變更,您可以設定 NewTextRendering1_5 = false 來確認行為差異,以便進行偵錯。設定會強制重組。請將任何行為差異歸類為錯誤。

偵錯標記將在 1.5 beta01 版之前移除。(Iada23b/246960758)

API 變更

  • FlowColumn/FlowRow 設為內嵌。(Idab37)。

1.5.0-alpha02 版

2023 年 4 月 5 日

發布 androidx.compose.foundation:foundation:1.5.0-alpha02androidx.compose.foundation:foundation-layout:1.5.0-alpha021.5.0-alpha02 版包含此連結所列的修訂項目。

API 變更

  • 開始支援 LazyGrid 中的固定大小儲存格,並採用跨軸排列方式排列這些儲存格。(I83ed9b/235121277b/267942510)
  • 現已支援在 LazyStaggeredGrid 中使用固定大小的車道,並透過交叉軸排列排列這些車道。(I7d519)。
  • AnnotatedString 中的 UrlAnnotation 現在可以透過 TalkBack 等無障礙服務開啟。(If4d82b/253292081)
  • 為文字欄位新增 InsertTextAtCursor 語意動作。(I11ed5)。
  • 文字相關的測試動作 (例如 performTextInput) 現在會使用語意動作直接要求焦點,而不會點選欄位。(I6ed05)。
  • 新增使用 FlowRow 中的 verticalArrangementFlowColumn 中的 horizontalArrangement,支援跨軸間距/排列方式。我們也會移除 FlowRow/FlowColumn 中的頂層 verticalAlignmenthorizontalAlignment。開發人員可以改用 Modifier.align。這可以減少 verticalAlignmentverticalArrangement 的命名慣例造成的混淆。(I87b60b/268365538)

1.5.0-alpha01 版

2023 年 3 月 22 日

發布 androidx.compose.foundation:foundation:1.5.0-alpha01androidx.compose.foundation:foundation-layout:1.5.0-alpha011.5.0-alpha01 版包含此連結所列的修訂項目。

API 變更

  • 系統會重構文字和 BasicText,以使用新的修飾符系統。如此一來,在多數情況下,效能就能大幅改善。不應顯示任何變更。(If1d17b/246961435)
  • 新增 PerformImeAction 語意動作,可在文字編輯器節點上叫用 IME 動作。(Ic606fb/269633506)

修正錯誤

  • 已更新 Modifier.hoverable 的內部結構。hoverable 修飾符只有在啟用時才會顯示在檢查器中。(I82103)。

1.4 版

1.4.3 版本

2023 年 5 月 3 日

發布 androidx.compose.foundation:foundation:1.4.3androidx.compose.foundation:foundation-layout:1.4.3,但沒有任何變更 (僅更新版本編號)。

1.4.2 版

2023 年 4 月 19 日

發布 androidx.compose.foundation:foundation:1.4.2androidx.compose.foundation:foundation-layout:1.4.21.4.2 版包含此連結所列的修訂項目。

1.4.1 版

2023 年 4 月 5 日

發布 androidx.compose.foundation:foundation:1.4.1androidx.compose.foundation:foundation-layout:1.4.11.4.1 版包含此連結所列的修訂項目。

1.4.0 版

2023 年 3 月 22 日

發布 androidx.compose.foundation:foundation:1.4.0androidx.compose.foundation:foundation-layout:1.4.01.4.0 版本包含這些修訂版本。

自 1.3.0 版以來的重要異動

  • 新增 Emoji Compat 整合功能至 TextTextField,以及較低層級的 Paragraph系統會在設定 EmojiCompat 時預設啟用此功能。
  • 您可以使用 PlatformParagraphStyle 為特定文字設定 EmojiCompat
  • 支援完整行距 LazyStaggeredGrid(I28252)
  • ClickableText 中新增實驗性的 onHover (I6938f)
  • 針對接受 CoroutineContext 參數的 runComposeUiTest 函式和 create*ComposeRule 函式,推出新的實驗性超載。結構定義將用於測試組合及當中的 LaunchedEffectrememberCoroutineScope() 呼叫。(I10614b/265177763)
  • FlowRowFlowColumn 現已用 @ExperimentalFoundationApi 的形式提供,可在主軸空間不足時,針對會斷行的元件提供更彈性的列與欄式版面配置 (I3a7b2)。
  • 提供 Modifier.basicMarquee() 實驗性功能,可在顯示內容時呈現捲動式跑馬燈效果(I2df44b/139321650)。

1.4.0-rc01 版

2023 年 3 月 8 日

發布 androidx.compose.foundation:foundation:1.4.0-rc01androidx.compose.foundation:foundation-layout:1.4.0-rc011.4.0-rc01 版包含此連結所列的修訂項目。

API 變更

  • 推出新的低階 PlatformTextInputAdapter API,用於建構直接與平台 API 通訊的自訂文字輸入實作。(I58df4)。
  • LazyStaggeredGrid 中新增反向版面配置的支援。(I3ef4a)。

修正錯誤

  • BasicTextFieldSetText 語意動作現在會使用與輸入法編輯器更新和測試函式 (例如 performTextReplacement) 相同的程式碼路徑,來更新文字緩衝區。
  • 文字測試函式 performTextClearanceperformTextReplacementperformTextSelection 現在使用 SemanticsActions。(I0807db/269633168b/269624358)

1.4.0-beta02 版本

2023 年 2 月 22 日

發布 androidx.compose.foundation:foundation:1.4.0-beta02androidx.compose.foundation:foundation-layout:1.4.0-beta021.4.0-beta02 版包含此連結所列的修訂項目。

API 變更

  • 新增 Modifier.Node.onReset() 回呼,可讓您重設部分本機狀態,妥善處理重複使用 Layout (例如 LazyColumn 項目) 時的情況。已修正 FocusTargetModifierNode,以便正確重設聚焦狀態。(I65495b/265201972)
  • DrawScope.drawTextParagraph.paintMultiParagraph.paint 方法中新增 BlendMode 參數,以在 Canvas 上繪製文字時支援不同的混合演算法。(I57508)。
  • 已移除 modifierElementOf() API。請改為直接從「ModifierNodeElement」延長。(Ie6d21)。

修正錯誤

  • 調整選取控點無法再選取部分字元。(Idedd1)。
  • 修正空白 TextField 中 ctrl+backspace 時發生的當機問題 (I0427fb/244185537)

1.4.0-beta01 版

2023 年 2 月 8 日

發布 androidx.compose.foundation:foundation:1.4.0-beta01androidx.compose.foundation:foundation-layout:1.4.0-beta011.4.0-beta01 版包含此連結所列的修訂項目

新功能

  • 自 1.3 版起,新增了 Emoji Compat 整合功能至 TextTextField,以及較低層級的 Paragraph系統會在設定 EmojiCompat 時預設啟用此功能。
  • 您可以使用 PlatformParagraphStyle 為特定文字設定 EmojiCompat

API 變更

  • 新增了所有 LazyLayouts 中使用的 PinnableContainer API 常見實作,以保留退出組合,但仍需啟用的項目。(If45a4)。
  • PinnableContainer.PinnedHandle.unpin() 已重新命名為 release() (I4667a)。

外部貢獻

  • LazyListLayoutInfoLazyGridLayoutInfoLazyStaggeredGridItemInfo 中新增 mainAxisItemSpacing 屬性 (I52fad)

1.4.0-alpha05 版

2023 年 1 月 25 日

發布 androidx.compose.foundation:foundation:1.4.0-alpha05androidx.compose.foundation:foundation-layout:1.4.0-alpha05查看 1.4.0-alpha05 版的修訂項

新功能

  • 支援完整行距 LazyStaggeredGrid (I28252)
  • ClickableText 中新增實驗性的 onHover (I6938f)
  • 針對接受 CoroutineContext 參數的 runComposeUiTest 函式和 create*ComposeRule 函式,推出新的實驗性超載。結構定義將用於測試組合及當中的 LaunchedEffectrememberCoroutineScope() 呼叫。(I10614b/265177763)

API 變更

  • OverscrollEffect 的前/後 API 合併至組合的「裝飾器」applyToScrollapplyToFling 函式。請參閱說明文件中的更新範例,瞭解如何以新 API 的形式實作過度捲動效果。(I8a9c4b/255554340)
  • 針對內嵌函式/已淘汰的隱藏函式,提供更多類型/是否可為空值選項 (I24f91)
  • TextStyle 中的 LineBreakHyphens API 升級為穩定版。(Ic1e1d)

修正錯誤

外部貢獻

  • TextInputSessionTextInputService 中的 notifyFocusedRect 方法不會再次淘汰。(I23a04b/262648050)

1.4.0-alpha04 版本

2023 年 1 月 11 日

發布 androidx.compose.foundation:foundation:1.4.0-alpha04androidx.compose.foundation:foundation-layout:1.4.0-alpha04查看 1.4.0-alpha04 版的修訂項

新功能

  • FlowRowFlowColumn 現已用 @ExperimentalFoundationApi 的形式提供,可在主軸空間不足時,針對會斷行的元件提供更彈性的列與欄式版面配置 (I3a7b2)。
  • 提供 Modifier.basicMarquee() 實驗性功能,可在顯示內容時呈現捲動式跑馬燈效果 (I2df44b/139321650)。

API 變更

  • FocusRequesterModifier 已淘汰,並改用 FocusRequesterNode (I7f4d7b/247708726b/255352203b/253043481b/247716483b/254529934b/251840112b/251859987b/257141589)。
  • 包含 variationSettingsAndroidFont 建構函式現在是穩定版 API,可用於建立新類型的字型描述元 (I5adccb/261565807)。
  • 透過本機組合導入可由 Lazy 清單提供的 PinnableContainer API,藉此固定目前項目。也就是說,當這類項目因為捲動操作而超出檢視區塊時,並不會遭到捨棄。舉例來說,Modifier.focusable() 會透過這個機制固定目前聚焦的項目 (Ib8881b/259274257b/195049010)。
  • 重新編寫可捲動項目回應 bringIntoViewRequesters 和可聚焦項目的方式,進一步模擬這些作業的複雜度並處理更多極端情況 (I2e5feb/241591211b/192043120b/237190748b/230756508b/239451114)。
  • 更多已淘汰隱藏函式的傳回類型為空值 (Ibf7b0)。
  • 新增實驗性 TextMotionTextStyle,將文字定義為 Static(default) 或動畫。如要透過動畫縮放、變換或旋轉文字,請使用 TextMotion.Animated (I24dd7)。
  • 新增 TextFieldFocusModifier,修正 Android 平台的焦點導覽行為 (I00303)。
  • drawText 中的 maxSize: IntSize 引數替換為 size: Size,以便內嵌於其他 DrawScope 函式。size 預設為 Size.Unspecified,這應該不會變更先前的預設行為 (Icd27d)。

修正錯誤

  • 調整 SnapFlingBehaviour 中的貼齊物理行為,讓效果更自然。

已知問題

  • androidx.compose.foundation:1.4.0-alpha03 更新為 androidx.compose.foundation:1.4.0-alpha04 時,您可能會遇到 java.lang.NoSuchFieldError 錯誤,這個網頁是最初回報問題的地方。我們已提交修正程式,預計下次 Compose 更新時就會發布。目前暫時性的解決方法是將 androidx.compose.materialandroidx.compose.material3 程式庫更新為最新版本 (1.1.0-alpha04),或將 androidx.compose.foundation 降級為 1.4.0-alpha03。

1.4.0-alpha03 版本

2022 年 12 月 7 日

發布了 androidx.compose.foundation:foundation:1.4.0-alpha03androidx.compose.foundation:foundation-layout:1.4.0-alpha03查看 1.4.0-alpha03 版的修訂項

API 變更

  • 在使用 Compose 規則的 UI 測試中,系統會等所有影格回呼執行完畢,才會分派在 withFrameNanos 回呼期間恢復的連續作業。這與 Compose 正常執行時的行為相符。不過,仰賴舊行為的測試可能會失敗。這只會影響直接呼叫 withFrameNanoswithFrameMillis 的程式碼,並將回呼外的邏輯傳遞至可能需要在回呼內移動的函式。請參閱這份 CL 範例中的動畫測試變更。
  • 將選用的 onPerformTraversals: (Long) -> Unit 參數新增至 TestMonotonicFrameClock 建構函式和工廠函式,以便在 withFrameNanos 回呼之後和重新啟用呼叫端協同程式之前執行程式碼。(Idb413b/254115946b/222093277b/255802670)
  • 導入頁面無障礙動作:PageUpPageDownPageLeftPageRight。請注意,這些內容僅適用於 API 29。(Ida4ab)
  • 導入 HorizontalPagerVerticalPager,以 Pager 方式顯示可組合項。導入 PagerState,藉此控制 Pager 和 Pager 目前狀態的查詢資訊。導入 PageSize,這是控制 Pager 頁面大小的一種方法,可用來建立類似 Pager 的輪轉介面。導入 PagerSnapDistance,可控制貼齊功能在 Pager 的快速滑過行為的運作方式。(I01120)
  • 已在 SnapFlingBehavior.performFling 中引入超載,幫助您瞭解快速滑過發生的位置。(I569f6)
  • 已移除 OverscrollEffect#isEnabled。您不必記住並設定這個標記,而不要在不顯示過度捲動的情況下,將事件分派到過度捲動效果 (例如,如果 ScrollableState#canScrollForward/backward 都傳回 false)。(I1a4b0b/255554340b/255557085)
  • 新增 ScrollableState#canScrollForwardScrollableState#canScrollBackward 以查詢 ScrollableState 是否有向任何方向捲動的空間 (是否位於其範圍的最小 / 最大範圍內)。為了兼顧與 ScrollableState 現有實作的回溯相容性,這個欄位預設為 true。取用者可利用這項功能,向使用者顯示指示,讓使用者知道是否還有捲動空間;也可以用於避免將差異遷移調度至 ScrollableStates,其沒有空間在指定方向捲動,以減少不必要的工作。(Idf1a0b/255557085)
  • 新增用於查詢祖系捲動資訊的 Modifier API。(I2ba9db/203141462)
  • 如果手勢可能產生捲動事件,用在 Clickable 中可正確延遲按下的互動動作。
  • 修正了在 Scrollable ViewGroup 中使用 Clickables 時無法正確延遲漣漪效果的問題。
  • 更新導覽匣和試算表,以便在手勢變為捲動事件時正確延遲按下動作。
  • 更新 snapStepSize 命名方式,使其與 SnapLayoutInfoProvider 中的其他方法保持一致。(Ife67c)
  • EmojiCompat 新增至 Compose (Ibf6f9b/139326806)
  • 已將 consumedWindowInsets() 重新命名為 consumeWindowInsets(),並將 withConsumedWindowInsets() 重新命名為 onConsumedWindowInsetsChanged(),並將修飾符設為公開。(Ie44e1)

修正錯誤

  • 修正 Modifier.animateItemPlacement() 和 Lazy 格線異常終止的問題。以前若新項目的數量比先前的項目少,有時就會發生這種情況。(I0bcacb/253195989)

1.4.0-alpha02 版本

2022 年 11 月 9 日

發布 androidx.compose.foundation:foundation:1.4.0-alpha02androidx.compose.foundation:foundation-layout:1.4.0-alpha021.4.0-alpha02 版本包含以下修訂項目。

API 變更

  • awaitFirstDownwaitForUpOrCancellation 現在接受 PointerEventPass,靈活性更高 (I7579ab/212091796)。
  • 從 Lazy* API 還原 beyondBoundCount API (I12197)
  • 在 Lazy API 中導入了參數,用於撰寫和放置可視區域外項目 (I69e89b/172029355)
  • BasicTextBasicTextField 中新增了 minLines 參數。這樣即可使用行數來設定這些可組合項的最小高度 (I24294b/122476634)

1.4.0-alpha01 版

2022 年 10 月 24 日

發布 androidx.compose.foundation:foundation:1.4.0-alpha01androidx.compose.foundation:foundation-layout:1.4.0-alpha011.4.0-alpha01 版本包含這些修訂版本。

API 變更

  • 新增了適用於手勢偵測工具的新方法:awaitEachGesture()。運作方式與 forEachGesture() 類似,但手勢的迴圈完全在 AwaitPointerEventScope 內運作,因此事件不會在疊代之間遺失。
  • 由於 forEachGesture() 會導致事件在手勢間遺失,因此已將其淘汰並改用 awaitEachGesture() (Iffc3fb/251260206)
  • 新增 WindowInsets.imeAnimationSource 和 WindowInsets.imeAnimationTarget,可協助判斷動畫進度,並掌握輸入法編輯器在動畫結束後的位置 (I356f1b/217770337)

1.3 版本

1.3.1 版本

2022 年 11 月 9 日

發布了 androidx.compose.foundation:foundation:1.3.1androidx.compose.foundation:foundation-layout:1.3.11.3.1 版包含此連結所列的修訂項目。

修正錯誤

  • 修正 BeyondBoundsLayout 中的效能問題 (aosp/2255266)
  • 除非附加 ContentInViewModifier,否則不會讀取版面配置座標 (aosp/2241316)

1.3.0 版本

2022 年 10 月 24 日

發布 androidx.compose.foundation:foundation:1.3.0androidx.compose.foundation:foundation-layout:1.3.01.3.0 版本包含以下修訂項目。

自 1.2.0 版以來的重要異動

  • 推出 LazyVerticalStaggeredGridLazyHorizontalStaggeredGrid 的實驗版本。
  • 已將 SnapFlingBehaviorrememberSnapFlingBehavior 和其他對應的 API 新增為實驗功能。
  • 現在,如果使用鍵盤或遙控器上的 D-Pad 按一下 Modifier.clickableModifier.toggleableModifier.selectable,會顯示漣漪效果。

1.3.0-rc01 版本

2022 年 10 月 5 日

發布 androidx.compose.foundation:foundation:1.3.0-rc01androidx.compose.foundation:foundation-layout:1.3.0-rc011.3.0-rc01 版本包含以下修訂項目。

API 變更

  • 在沒有足夠的快速滑過速率可減慢時,採用方法步驟使用的 lowVelocityAnimationSpec (Iaeb27)
  • 新增了實驗性 API Hyphens,以支援 Text 中的自動連字號 (Iaa869)

1.3.0-beta03 版本

2022 年 9 月 21 日

發布 androidx.compose.foundation:foundation:1.3.0-beta03androidx.compose.foundation:foundation-layout:1.3.0-beta031.3.0-beta03 版本包含以下修訂項目。

API 變更

  • 新增自訂文字斷行選項 (I86907)
  • BringIntoViewResponder 現在在處理要求時,可以取得最新的邊界 (If86a5b/241591211)。
  • 實驗性 Staggered Grid 現在支援項目間距 (I10b82)
  • 在實驗性 Staggered Grid 新增內容邊框間距 (I342ea)
  • 變更 TextMeasurer.measure 方法中的 size:IntSize 引數與 constraints: Constraints,來處理最小的寬度限制 (I37530b/242707525)
  • 新增 Modifier.withConsumedWindowInsets(),這個函式會取得已使用的 WindowInsets,可供在 windowInsetsPadding 之外使用。
  • 新增了 MutableWindowInsets,以便在不重新組合的情況下輕鬆變更 WindowInsets(I7fd28b/237019262b/243119659)

1.3.0-beta02 版本

2022 年 9 月 7 日

發布 androidx.compose.foundation:foundation:1.3.0-beta02androidx.compose.foundation:foundation-layout:1.3.0-beta021.3.0-beta02 版本包含以下修訂項目。

API 變更

  • 實驗性 StaggeredGrid 的初始版本 (Ia48be)
  • 已將 FocusDirection.InFocusDirection.Out 重新命名為 FocusDirection.EnterFocusDirection.Exit (Ia4262b/183746982)
  • 推出了 rememberSnapFlingBehavior 超載,以便快速在 LazyLists 中啟用貼齊功能 (Ifb48a)
  • 使用具體的 SnapFlingBehavior 類別取代了 snapFlingBehavior 工廠。將 SnapLayoutInfoProvider 方法的範圍限定為「密度」,讓 API 使用者更容易進行 Dp<->Px 轉換 (I54a11)
  • 更新 LazyLayoutMeasureScope.measure 以傳回可置放的值清單,突顯傳回的值所需的不變性 (I48b7c)
  • 推出了 SnapLayoutInfoProvider,取用 LazyListState 來建立 SnapLayoutInfoProvider 的執行個體,可用於為 LazyLists 啟用貼齊 FlingBehavior (I2dd10)

修正錯誤

  • 重構 AwaitPointerEventScope#awaitLongPressOrCancellation 以比對其他 await 函式 (I646e6)

1.3.0-beta01 版本

2022 年 8 月 24 日

發布 androidx.compose.foundation:foundation:1.3.0-beta01androidx.compose.foundation:foundation-layout:1.3.0-beta011.3.0-beta01 版本包含以下修訂項目。

API 變更

  • OverscrollEffect 中移除 pointerPosition - 需要注意指標位置的特效,可以使用 effectModifier 中的 Modifier.pointerInput { },來取得目前的指標位置 (I9f606b/241239306)。
  • 公開 AwaitPointerEventScope#awaitLongPressOrCancellation 做為其他用於更複雜手勢偵測的建構區塊 (I04374b/181577176)
  • 推出了 lazyListSnapLayoutInfoProvider 用來在 Lazy 清單中啟用貼齊功能 (I3ecdf)
  • 推出了 SnapFlingBehavior,這是可啟用清單貼齊功能的快速滑過行為。提供一個 SnapLayoutInfoProvider 的執行個體,內容包含貼齊版面配置的相關資訊 (Ie754c)

1.3.0-alpha03 版本

2022 年 8 月 10 日

發布了 androidx.compose.foundation:foundation:1.3.0-alpha03androidx.compose.foundation:foundation-layout:1.3.0-alpha031.3.0-alpha03 版本包含以下修訂項目。

API 變更

  • 資源字型現在支援字型變化版本設定 (API 26 以上級別) (I900ddb/143703328)
  • DeviceFontFamilyNameFont 中的可變字型支援 (Ic1279b/143703328)
  • PlatformTextStyleLineHeightStyle 中移除實驗性註解 (I64bef)
  • 如果 VisualTransformation 提供的 OffsetMapping 傳回無效索引,文字欄位現在會擲回更詳細的例外狀況 (Ie73f9b/229378536)。
  • 推出實驗性 API,在多個 Lazy 版面配置之間共用項目提供者的邏輯 (Ic891c)
  • ScrollableDefaults.reverseDirection() 已不再處於實驗階段 (Iba646)
  • 淘汰了 SemanticsModifier.id,並將語意 ID 移至 LayoutInfo.semanticsId (Iac808b/203559524)
  • checkScrollableContainerConstraints() 不再處於實驗階段 (I2c290)
  • Modifier.clipScrollableContainer() 不再處於實驗階段 (Ia2b44)
  • 淘汰 TextInputService.show|hideSoftwareKeyboard。請在應用程式程式碼中改用 SoftwareKeyboardController,並在輸入法編輯器管理程式碼中使用 TextInputSession。(I14e4cb/183448615)

1.3.0-alpha02 版本

2022 年 7 月 27 日

發布了 androidx.compose.foundation:foundation:1.3.0-alpha02androidx.compose.foundation:foundation-layout:1.3.0-alpha021.3.0-alpha02 版包含此連結所列的修訂項目。

API 變更

  • DrawScope 上新增 drawText 擴充功能函式,這樣就能針對在 DrawScope (例如 CanvasdrawBehind) 上運作的可組合項和修飾符,繪製多樣式的文字。(I16a62b/190787898)

修正錯誤

  • 現在如果聚焦的文字欄位處於停用狀態,就會隱藏文字鍵盤 (I6e3e4b/237308379)。
  • InputEventChange 事件加入至速率追蹤器時,我們現在會考慮使用差異值而非位置,所以即使目標元素移動,也能確保所有案例的速度計算正確 (Icea9db/216582726b/223440806b/227709803)
  • 如果可捲動項目中有聚焦的子項,現在當整個項目縮小,甚至大小因動畫改變時,都能正常捲動並讓聚焦的子項保持在畫面中。(I80867b/230756508b/220119990)
  • 修正在選擇狀態下清除並重新填入 TextField 會導致異常終止的問題。(I1235bb/208655565b/214253689)

1.3.0-alpha01 版本

2022 年 6 月 29 日

發布 androidx.compose.foundation:foundation:1.3.0-alpha01androidx.compose.foundation:foundation-layout:1.3.0-alpha011.3.0-alpha01 版本包含以下修訂項目。

API 變更

  • 推出 UrlAnnotation 註解類型與相關的方法,能夠支援 AnnotatedString 中的 TalkBack 連結支援。(I1c754b/231495122)

修正錯誤

  • BasicTextField cursorBrush 現在可以動畫處理,無須重新啟動游標計時器 (I812e6b/236383522)

1.2 版本

1.2.1 版本

2022 年 8 月 10 日

發布了 androidx.compose.foundation:foundation:1.2.1androidx.compose.foundation:foundation-layout:1.2.11.2.1 版本包含以下修訂項目。

1.2.0 版

2022 年 7 月 27 日

發布了 androidx.compose.foundation:foundation:1.2.0androidx.compose.foundation:foundation-layout:1.2.01.2.0 版本包含以下修訂項目。

自 1.1.0 版以來的重要異動

  • LazyVerticalGridLazyHorizontalGrid 現已穩定。
  • 您現在可以為 Lazy 清單和格線項目中的項目指定內容類型。如此一來,元件就能更有效率地重複使用元素。
  • Lazy 清單和格線現在包含 userScrollEnabled 參數,可透過使用者手勢停用捲動功能。
  • 新增了名為 LazyLayout 的實驗性 API。這是我們在內部使用的 API,用來支援 Lazy 清單和格線。
  • OverscrollEffect API 推出實驗性版本。您可以定義自訂過度捲動效果,也可以將標準平台新增至自訂的可捲動容器。
  • 推出了巢狀捲動互通性 API,以允許檢視畫面和 compose 捲動操作者之間的互通性。
  • 滑鼠和觸控板的捲動功能已新增至所有捲動容器。

1.2.0-rc03 版本

2022 年 6 月 29 日

發布 androidx.compose.foundation:foundation:1.2.0-rc03androidx.compose.foundation:foundation-layout:1.2.0-rc031.2.0-rc03 版本包含以下修訂項目。

  • 自 1.2.0-rc02 以來沒有變更。

1.2.0-rc02 版

2022 年 6 月 22 日

發布 androidx.compose.foundation:foundation:1.2.0-rc02androidx.compose.foundation:foundation-layout:1.2.0-rc021.2.0-rc02 版本包含以下修訂項目。

1.2.0-rc01 版

2022 年 6 月 15 日

發布 androidx.compose.foundation:foundation:1.2.0-rc01androidx.compose.foundation:foundation-layout:1.2.0-rc011.2.0-rc01 版本包含以下修訂項目。

API 變更

  • 我們推出了實驗性 OverscrollEffect,可以支援自訂過度捲動功能,以及接受 Modifier.scrollable 的超載。
  • 實驗性 LocalOverScrollConfiguration 已從 foundation.gesture 移至基礎套件,並重新命名為 LocalOverscrollConfiguration (If19fbb/204650733)
  • 撰寫程式庫中的介面現已使用 jdk8 預設介面方法建立 (I5bcf1)
  • 推出實驗性 API checkScrollableContainerConstraints(),檢查我們是否並未為捲動容器建立巢狀結構。透過 LazyLayout 建立自訂捲動式延遲版面配置時就可以使用。(Id6fabb/233352497)
  • 已從 androidx.compose.foundation.lazy 套件中移除已淘汰的 LazyVerticalGrid。新版穩定 API 位於 androidx.compose.foundation.lazy.grid (I73c76b/225192009)

1.2.0-beta03 版本

2022 年 6 月 1 日

發布了 androidx.compose.foundation:foundation:1.2.0-beta03androidx.compose.foundation:foundation-layout:1.2.0-beta031.2.0-beta03 版本包含以下修訂項目。

API 變更

  • 新增了實驗性 IntervalListMutableIntervalList。這可讓您透過多個間隔來表示部分值的清單。如果要定義類似 LazyColumn 使用的自訂 DSL,而其中清單項目可透過多個項目呼叫定義,這個功能就非常實用 (I2d05eb/228580728)

修正錯誤

  • 釐清有關 WindowInsets.ime 的說明文件,指出 API 23 以上級別皆可回報 ime 插邊,但只有 API 30 以上級別會採用「動畫」(Ia7fc0b/230756508)。
  • 當游標移到文字欄位結尾時,按下向前刪除鍵不會再當機。
  • 現在 DeleteSurroundingTextCommandDeleteSurroundingTextInCodePointsCommand 的建構函式引數不得為負數。(Ica8e6b/199919707)

1.2.0-beta02 版

2022 年 5 月 18 日

發布 androidx.compose.foundation:foundation:1.2.0-beta02androidx.compose.foundation:foundation-layout:1.2.0-beta021.2.0-beta02 版本包含以下修訂項目。

  • 不會變更 Text 或 TextField 配置大小的可下載字型解析度先前不會重繪,導致字型顯示過時。這項錯誤修正可確保文字版面配置一定會觸發重繪 (b/229727404)。(I1d49eb/229727404)

1.2.0-beta01 版本

2022 年 5 月 11 日

發布 androidx.compose.foundation:foundation:1.2.0-beta01androidx.compose.foundation:foundation-layout:1.2.0-beta011.2.0-beta01 版本包含以下修訂項目。

新功能

  • 這是 1.2 版的第一個 Beta 版!

API 變更

  • 新增了實驗性的 BeyondBoundsInterval,可供 LazyList 的自訂實作用於布局範圍超出可見邊界的情況 (Ifabfbb/184670295)
  • LineHeightBehavior 已重新命名為 LineHeightStyle
  • LineVerticalAlignment 已重新命名為 LineHeightStyle.Alignment
  • LineHeightTrim 已重新命名為 LineHeightStyle.Trim
  • 移除 LineHeightStyle 中的預設建構函式值 (I582bfb/181155707)。
  • 新增了 LazyLayoutItemProvider 介面選用成員的預設值。(Iba8a0)
  • LazyLayoutItemProvider API,我們現在不再需要由工廠按照索引傳回可組合的 lambda,而能用更簡單的可組合函式項目接受索引。(Id2196)
  • LazyLayoutItemsProvider 已重新命名為 LazyLayoutItemProvider (I0638c)
  • LazyLayoutItemsProvider.itemsCount 已重新命名為 itemCount (Id409c)
  • 針對 TextStyleSpanStyle 新增 Brush,可供繪製漸層上色的文字。(I53869b/187839528)
  • LineHeightBehaviortrimFirstLineToptrimLastLineBottom 屬性已變更為單一列舉:LineHeightTrimLineHeightTrim 有由兩個布林值定義的 4 種狀態值:FirstLineTopLastLineBottom、Both 和 None (Ifc6a5b/181155707)
  • TextStyleParagraphStyle. LineHeightBehavior 新增了 LineHeightBehavior,可控制是否要將行高套用於第一行的頂部和最後一行的底部,以及定義 TextStyle (lineHeight) 所提供空間中的行對齊方式。

    舉例來說,您可以透過 LineHeightBehavior(alignment = LineVerticalAlignment.Center, trimFirstLineTop=false, trimLastLineBottom = false),獲得與 CSS 定義行為類似的結果。

  • trimFirstLineToptrimLastLineBottom 設定只有在 includeFontPadding 設定為 False 時才能正確運作。(I97332b/181155707)

  • 新增實驗性的 imeNestedScroll() 修飾符,方便開發人員以捲動方式控制輸入法編輯器。(I60759)

修正錯誤

  • 修正迴歸問題:從可組合項中移除位於焦點的文字欄位時,文字欄位不會隱藏鍵盤。(I7a410b/230536793b/225541817)
  • 在高度有限且無法容納所有文字行時支援刪節號 (Ie528cb/168720622)。
  • BringIntoViewRequester.bringIntoView 將一直處於暫停狀態,直到要求完成或由較新的非重複要求中斷為止。重疊的要求將排入佇列 (I43e7fb/216790855)。
  • 針對完全重疊矩形的並行 BringIntoViewRequester.bringIntoView 呼叫,現在只會處理較大矩形的要求。(I34be7b/216790855b/184760918)
  • 已開啟預設 includeFontPadding。您可以使用 TextStyle.platformTextStyle 屬性關閉 includeFontPadding。我們即將變更預設行為。但在此之前,這種做法能以較好的方式整合行高改善項目 (aosp/2058653),並解決 TextField 裁剪問題 (I01423b/171394808)
  • Modifier.bringIntoViewRequester 已不再使用 onGloballyPositioned。(I630f5)

外部貢獻

  • 現在垂直捲動時,就會在 Android 上反轉 MouseInjectionScope.scroll(delta = someDelta) (如果 someDelta 為正值,則會向下捲動) (Ifb697b/224992993)

1.2.0-alpha08 版

2022 年 4 月 20 日

發布 androidx.compose.foundation:foundation:1.2.0-alpha08androidx.compose.foundation:foundation-layout:1.2.0-alpha081.2.0-alpha08 版本包含以下修訂項目。

API 變更

  • 使用 FontFamily.SansSerif 時,可在 Android 的系統字型中顯示所有可用權重。這會在 API 21-28 內部使用備用廣告字型名稱,例如 Santa-serif-medium。由於之前 API 21-28 上僅支援 400 和 700 粗細,因此這是行為變更。(I380feb/156048036b/226441992)
  • 「段落」和「多段落」目前接受限制參數。傳送 Constraints.maxHeight 目前為免人工管理,但未來會進行一些計算,例如根據高度進行刪節。(I6afeeb/168720622)
  • SubcomposeSlotReusePolicy.getSlotsToRetain() 可接受自訂 MutableSet 類別,該類別不允許在其中新增項目。(Icd314)
  • 已從 PointerInputChange 淘汰部分消耗功能 (減少或定位)。可使用 consume() 徹底使用變更。可使用 isConsumed 判斷其他使用者是否曾經使用過該變更。
  • PointerInputChange::copy() 現在會一律建立淺層複本。這表示只要使用一份複本,系統就會使用 PointerInputChange 的複本。如要建立未繫結的 PointerInputChange,請改用建構函式。(Ie6be4b/225669674)
  • 已推出新的實驗性 LazyLayout API。這可讓您建構自己的元件,例如 LazyVerticalGrid 中的 LazyColumn。請注意,此 API 處於早期階段,在後續版本中可能有所調整 (Iba2bcb/166591700)。
  • AndroidFont 現在使用 typefaceLoader 做為建構函式參數 (I2c971)。
  • WindowInsets companion 現在無論是否在螢幕上、或是否與視窗相交,都會顯示出來。如果裝置上有此物件、但目前並未處於運作狀態,也可以得知可能的大小。(I65182b/217770337)

1.2.0-alpha07 版本

2022 年 4 月 6 日

發布 androidx.compose.foundation:foundation:1.2.0-alpha07androidx.compose.foundation:foundation-layout:1.2.0-alpha071.2.0-alpha07 版本包含以下修訂項目。

API 變更

  • 新增 PinnableParent API,讓 Lazy 版面配置能夠避免目前組合的項目遭到捨棄 (Ibbdd0b/184670295)
  • LazyListLayoutInfoLazyGridLayoutInfo 現在有 beforeContentPaddingafterContentPadding 欄位 (I3b628b/200920410)
  • 新增 KeyboardType.Decimal 做為 Keyboard.Number 的替代項,專用於在輸入法編輯器中加入小數分隔符。(Iec4c8b/209835363)
  • 新增字型描述元 Font(DeviceFontFamilyName),可選擇在字型備用廣告鏈中查詢系統已安裝的字型。(I30468b/219754572)
  • PointerEventType.ScrollPointerEvent.scrollDelta 現在是穩定的 API (I574c5b/225669674)
  • TextStyle/ParagraphStyle. includeFontPadding 中新增 includeFontPadding 的臨時相容性設定,可透過 TextStyle(platformStyle = PlatformTextStyle(includeFontPadding = true/false)) 變更。這是配合遷移提供的臨時設定選項,日後將移除。(If47beb/171394808)
  • 更新 FontFamily.Resolver,以整合全系統中的粗體文字無障礙設定 (I6c1e7)
  • ComposeViewconsumeWindowInsets 擴充功能屬性可讓開發人員停用 Android WindowInsets 的消耗。這樣一來,階層中的個別 ComposeViews 就能分別套用 WindowInsets,不會彼此干擾。(I0ef08b/220943142)

1.2.0-alpha06 版本

2022 年 3 月 23 日

發布 androidx.compose.foundation:foundation:1.2.0-alpha06androidx.compose.foundation:foundation-layout:1.2.0-alpha061.2.0-alpha06 版本包含以下修訂項目。

API 變更

  • 新增 RequestFocus 語意動作,用於要求聚焦於可聚焦的目標 (I17b71)
  • FocusOrder 現已合併至 FocusPropertiesfocusProperties() 現已具備 focusOrder() 的所有功能。FocusOrderfocusOrder() 已淘汰。接受 focusRequesterfocusOrder() 應替換為 focusRequester() 修飾符,並與 focusProperties() 搭配使用。如此一來,修飾符就能更妥善區隔問題 (I601b7)
  • 新增 WindowInsets.asPaddingValues(Density),方便開發人員在不需要組合的情況下完成轉換。(I94c35)
  • 更新向量可繪項目剖析,支援自動鏡像,亦即在目前版面配置的方向為 RTL 時翻轉 VectorPainter 的內容。(I79cd9b/185760237)

修正錯誤

  • 捲動修飾符 (Modifier.verticalScroll()Modifier.horizontalScroll()Modifier.scrollable()) 將在捲動區域大小改變後進行捲動,確保先前聚焦的可組合項仍顯示在畫面上。
  • 現在,當 TextField 中有非延遲的可捲動項,而且軟輸入模式是 ADJUST_RESIZE 時,只要文字欄位處於聚焦狀態並顯示鍵盤,TextField 就會一直顯示在鍵盤上方。(I4a485b/190539358b/192043120b/216842427)

1.2.0-alpha05 版本

2022 年 3 月 9 日

發布 androidx.compose.foundation:foundation:1.2.0-alpha05androidx.compose.foundation:foundation-layout:1.2.0-alpha051.2.0-alpha05 版本包含以下修訂項目。

API 變更

  • LazyVerticalGridLazyHorizontalGrid 現已轉為穩定版。(I307c0)
  • LazyGridItemInfo.Unknown 已替換為 LazyGridItemInfo.UnknownRowLazyGridItemInfo.UnknownColumn (I56d51)
  • LazyVerticalGrid/LazyHorizontalGrid 和所有相關 API 已移入 .grid 子套件。請將匯入內容從 androidx.compose.foundation.lazy 更新為 androidx.compose.foundation.lazy.grid。(I2d446b/219942574)
  • 文字︰includeFontPadding 現在預設為關閉。系統會處理 includeFontPadding=false 造成的裁剪問題,長指令碼應不致於遭到裁剪。(I31c84b/171394808)
  • 測量後的介面現在起會顯示 parentData 屬性 (I3313f)
  • 推出實驗性 Modifier.onFocusedBoundsChanged,以便觀察可聚焦子項的邊界 (I14283b/220030968b/190539358b/192043120b/216842427)。
  • 新增了 LazyHorizontalGrid (I61ae7b/191238807)。
  • 新增用於定義跨軸大小的 LazyVerticalGrid API (I17723)
  • 新增 FocusGroup 修飾符 (I64bc0b/213508274b/184670295)

修正錯誤

  • WindowInsets.toString() 現在能顯示正確的值 (I1585d)

外部貢獻

  • 已更新為使用 Kotlinx 協同程式 1.6.0 (I3366d)

1.2.0-alpha04 版

2022 年 2 月 23 日

發布 androidx.compose.foundation:foundation:1.2.0-alpha04androidx.compose.foundation:foundation-layout:1.2.0-alpha041.2.0-alpha04 版本包含以下修訂項目。

API 變更

  • 不需再利用 BringIntoViewResponders 手動將傳遞向上傳送給父項回應者,而改為需立即回傳想讓父項帶入檢視畫面的矩形。(I8e66a)
  • 支援在 Text 中載入非同步字型 (I77057b/214587005)
  • LazyVerticalGrid 現在起允許將 line breaking 置於跨距超出目前字行的項目之前 (I05c40b/207462103)。
  • excludeFromSystemGestures 重新命名為 systemGesturesExclusion (I19526)
  • LazyVerticalGrid 現已支援 reverseLayout (I6d7d7b/215572963b/211753558)
  • 新增 WindowInsets.only() 方法,可讓開發人員只納入取自 WindowInsets 的尺寸。(I14c94b/217768486)
  • 新增 ComposableTargetComposableTargetMarkerComposableOpenTarget,在針對非設計對象的套用者呼叫可組合函式時,可報告編譯時間。

    在多數情況下,Compose 編譯器外掛程式能夠推論出註解,因此直接使用這些註解的情形應該相當罕見。無法推論的案例包括建立及使用自訂 Applier、抽象的可組合函式 (例如介面方法)、欄位,或是屬可組合 lambda 的全域變數 (本機變數和參數為推論得出),或在使用 ComposeNode 或相關的可組合函式時。

    對於自訂 Applier,呼叫 ComposeNodeReusableComposeNode 的可組合函式需要為函式和任何可組合的 lambda 參數類型新增 CompoableTarget 註解。不過,與其直接使用 ComposableTarget,建議您建立以 ComposableTargetMarker 加上註解的註解,再使用已標示的註解。使用 ComposableTargetMarker 加上標示的可組合註解,等同於使用屬性類別完整名稱做為套用器參數的 ComposbleTarget。如需 ComposableTargetMarker 的使用範例,請參閱 anroidx.compose.ui.UiComposable。(I38f11)

修正錯誤

  • 現在可將負的捲動偏移值傳遞至 LazyGridState.scrollToItem()LazyGridState.animateScrollToItem() (I025c6b/211753558)
  • 支援為 TextField 載入非同步字型。(Icc4bfb/214587005)

1.2.0-alpha03 版本

2022 年 2 月 9 日

發布 androidx.compose.foundation:foundation:1.2.0-alpha03androidx.compose.foundation:foundation-layout:1.2.0-alpha031.2.0-alpha03 版本包含以下修訂項目。

API 變更

  • 不會再呼叫 TextInputSessionTextInputService 中的 notifyFocusedRect 方法,此方法現已淘汰。請改用 BringIntoViewRequester (Ia4302b/192043120b/216842427b/178211874)。
  • 使用 Modifier.animateItemPlacement() 針對 Lazy 格線項目啟用動畫功能 (Ib6621b/211753218)
  • BringIntoViewRequester 現在起可將請求傳播到主控的 Android View (Ia7a51)
  • FontFamilyResolver 現在起可經由 LocalFontFamilyResolver.current 取用
    • 新增 createFontFamilyResolver(context)createFontFamilyResolver(context, coroutineScope),可在使用 Compose 之外的情況下建立新的 FontFamily 解析器。
    • Paragraph 和 MultiParagraph 現在起能接受 FontFamily.Resolver
    • TextLayoutResult.layoutInput.fontFamilyResolver 現在包含此版面配置使用的解析器,並淘汰不再使用的 TextLayoutResult.layoutInput.resourceLoader (Id5a45b/174162090)。
  • 新增 AndroidFont 這個新的低階 API,可在 Android 上提供新型的字型資源描述元。例如,可從特定應用程式的後端載入字型、選擇性地從裝置上找出預先安裝的字型,或從目前字型工廠未提供的資源載入字型。
    • 擴充 Font.ResourceLoaded API,以支援選用和非同步的字型載入功能。我們不建議應用程式開發人員直接使用這個 API。如要新增字型類型,請參閱 AndroidFont。
    • Font.AndroidResourceLoader 擴充功能函式可用以在撰寫之外建構 Font.ResourceLoader
    • loadingStrategy 參數新增至以資源為基礎的字型,以便在資源字型參照可下載的字型 XML 時進行非同步載入。(Ie5aeab/174162090)
  • Typeface(FontFamily) 建構函式已經淘汰,之前用於預先載入字型,而且最多可能需要 10 秒才能下載字型。使用可下載的字型時,這個呼叫可能會封鎖達 10 秒。請改用 FontFamilyResolver.preload
    • 淘汰 fontResource(FontFamily): Typeface。之前用於預先載入字型,而且最多可能需要 10 秒才能下載字型。請改用 FontFamilyResolver.preload (If8e7cb/174162090)
  • 您現在可以為 LazyVerticalGrid 的項目指定內容類型;LazyGridScope 上的項目函式現在可接受這類參數。提供這樣的資訊有助於項目撰寫作業重複使用邏輯,藉此提高效率,並且只在類型相似的項目之間重複使用內容。(I7b355b/215372836)
  • LazyListLayoutInfoLazyGridLayoutInfo 現在有新屬性:viewportSizeorientationreverseLayout (Ifc8edb/200920410)
  • 現在起可為 LazyColumn/LazyRow 的項目指定內容類型;LazyListScope 上的項目函式現在已可接受這種參數。提供這樣的資訊有助於項目撰寫作業重複使用邏輯,藉此提高效率,並且只在類型相似的項目之間重複使用內容。(I26506)
  • 接受 maxSlotsToRetainForReuseSubcomposeLayoutState 建構函式現已淘汰,替換為接受 SubcomposeSlotReusePolicy 的新建構函式:新版介面可讓您更精準控制要保留哪些運算單元供日後重複使用 (I52c4d)。
  • 新增 WindowInset 用以處理邊框間距與大小調整的輔助鍵。這樣就能讓一些內容延伸到插邊區,但主要內容仍不會跨入插邊區。例如,windowInsetsPadding 可用來設定內容區的邊框間距,以避免一些區域完全或部分遭到覆蓋。(Id0395b/213942085)

修正錯誤

  • 當焦點在 TextField 上時,TextField 現在會保持在鍵盤上方;如果軟輸入模式設為 ADJUST_PAN,則會顯示鍵盤 (I8eaebb/190539358b/192043120)
  • 電腦版會使用 FontFamily.Resolver 的本機可組合項
    • 淘汰電腦版 FontLoader
    • 新增電腦版適用的新 createFontFamilyResolver 工廠函式 (I6bbbbb/174162090)
  • 切換文字欄位時,螢幕鍵盤輸入類型不會再閃爍。(I1bf50b/187746439)
  • 游標控點顯示時,對於文字欄位不再需要額外按返回按鈕。(Ideb4bb/205726883)
  • 調整文字選取放大鏡的行為,讓系統與平台的放大鏡一致。(Idd918b/206833278)

1.2.0-alpha02 版本

2022 年 1 月 26 日

發布 androidx.compose.foundation:foundation:1.2.0-alpha02androidx.compose.foundation:foundation-layout:1.2.0-alpha021.2.0-alpha02 版本包含以下修訂項目。

API 變更

  • NonRestartableComposable 新增至屬於現有方法超載且無複雜邏輯的方法。如此一來,對於呼叫內部函式中重複的所有參數,可減少編譯器產生的記憶檢查 (等於)。(I90490)
  • 新增 excludeFromSystemGesture 修飾符,便於存取 Android 的 setSystemGestureExclusionRects (I46f07)

修正錯誤

  • 調整文字選取放大鏡的行為,讓系統與平台的放大鏡一致。(Idd918b/206833278)
  • LazyColumnLazyRowModifier.verticalScroll 及其他使用 Modifier.scrollable 的容器支援滑鼠滾輪捲動功能。(I2b5e1b/198214718)

1.2.0-alpha01 版本

2022 年 1 月 12 日

發布了 androidx.compose.foundation:foundation:1.2.0-alpha01androidx.compose.foundation:foundation-layout:1.2.0-alpha011.2.0-alpha01 版本包含以下修訂項目。

API 變更

  • 已為 LazyColumnLazyRowLazyVerticalGrid 中加入新參數 userScrollEnabled,讓使用者能透過觸控手勢或無障礙功能,暫時或永久性地停用使用者啟動的捲動操作。依然能夠經由 state 上的方法以程式輔助方式設定捲動 (I7eae9b/201150093)。
  • 在放大鏡修飾符中新增 onSizeChanged 回呼。(I6879f)
  • 現在拖曳 SelectionContainer 中的選取控點時,就會顯示放大鏡小工具。(I30b38b/139320979)

修正錯誤

  • 已修正在捲動出視圖之外時,不會隱藏 TextField 游標控點的問題 (I14552b/208883748)。

依附元件更新

  • 現在依附於 Kotlin 1.6.10

1.1 版

1.1.1 版

2022 年 2 月 23 日

發布 androidx.compose.foundation:foundation:1.1.1androidx.compose.foundation:foundation-layout:1.1.11.1.1 版本包含以下修訂項目。

修正錯誤

1.1.0 版

2022 年 2 月 9 日

發布 androidx.compose.foundation:foundation:1.1.0androidx.compose.foundation:foundation-layout:1.1.01.1.0 版本包含以下修訂項目。

自 1.0.0 版以來的重要變更

  • 穩定支援 Android 12 的過度捲動效果
  • 改善觸控目標縮放功能
  • 請注意,對於 Compose 1.0 版,Material 元件會展開版面配置空間,以符合 Material 無障礙功能準則對於觸控目標尺寸的規定。舉例來說,即使您將按鈕的尺寸設為小於最小尺寸 48x48 dp,系統仍會將按鈕的觸控目標擴大為這個尺寸。這樣一來,Compose Material 的行為就會與 Material Design 元件相同,在混用 Views 和 Compose 時便可確保行為一致。利用 Compose Material 元件建立使用者介面時,這項異動還能確保達到觸控目標無障礙功能的最低要求。
  • 穩定支援導覽邊欄
  • 將先前推出的一些實驗性 API 升級為穩定版
  • 支援更新版本的 Kotlin

1.1.0-rc03 版

2022 年 1 月 26 日

發布 androidx.compose.foundation:foundation:1.1.0-rc03androidx.compose.foundation:foundation-layout:1.1.0-rc031.1.0-rc03 版本包含以下修訂項目。

修正錯誤

  • 更新為可支援 Compose Material 1.1.0-rc03

1.1.0-rc01 版

2021 年 12 月 15 日

發布 androidx.compose.foundation:foundation:1.1.0-rc01androidx.compose.foundation:foundation-layout:1.1.0-rc011.1.0-rc01 版本包含以下修訂項目。

修正錯誤

  • 現在可將負的捲動偏移值傳遞至 LazyListState.scrollToItem()LazyListState.animateScrollToItem() (Iceb90b/184252837)
  • 已修正會造成無障礙捲動遺漏操作的錯誤 (I7cbfb)

1.1.0-beta04 版本

2021 年 12 月 1 日

發布 androidx.compose.foundation:foundation:1.1.0-beta04androidx.compose.foundation:foundation-layout:1.1.0-beta041.1.0-beta04 版本包含以下修訂項目。

新功能

  • 已更新為與 Kotlin 1.6.0 相容

API 變更

  • 已去除 androidx.core.view 中為空值的可能 (I7078ab/204917439)
  • 新增了實驗性 API,允許整體取用 PointerInputchange 或者檢查是否已取用 PointerInputchange。(I2e59d)
  • 在文字欄位中拖曳游標或選取控點時,顯示放大鏡小工具。(I5391eb/203781358)

修正錯誤

  • 修正問題:輸入法編輯器瀏覽權限變更時,文字控點不會移動 (I25f2e)。

1.1.0-beta03 版

2021 年 11 月 17 日

發布 androidx.compose.foundation:foundation:1.1.0-beta03androidx.compose.foundation:foundation-layout:1.1.0-beta031.1.0-beta03 版本包含以下修訂項目。

API 變更

  • LazyVerticalGrid 支援水平範圍。(I7e2fab/176758183)
  • 新增針對 Lazy 清單項目的位置添加動畫效果的實驗性功能。LazyItemScope 中新增一個名為 Modifier.animateItemPlacement() 的新輔助鍵可用。使用範例:

      var list by remember { mutableStateOf(listOf("A", "B", "C")) }
      LazyColumn {
          item {
              Button(onClick = { list = list.shuffled() }) {
                  Text("Shuffle")
              }
          }
          items(list, key = { it }) {
              Text("Item $it", Modifier.animateItemPlacement())
          }
      }
    
    • 經由 LazyListScope.itemLazyListScope.items 提供索引鍵時,這個輔助鍵能夠啟動項目重新排序的動畫。除了項目的重新排序之外,諸如排列或對齊方式改變等事件造成的其餘位置改變情形,也會以動畫呈現。(I59e7bb/150812265)

1.1.0-beta02 版本

2021 年 11 月 3 日

發布 androidx.compose.foundation:foundation:1.1.0-beta02androidx.compose.foundation:foundation-layout:1.1.0-beta021.1.0-beta02 版本包含以下修訂項目。

修正錯誤

  • 現在,漣漪效果與其他指示元素只有在位於 Modifier.scrollable() 容器內時才會延遲,不會因為按下事件而一律延遲 (Ibefe0b/203141462)。
  • 新增實驗性的 BringIntoView API,可讓您傳送要求給父項,讓父項透過捲動將項目帶入檢視區塊 (Ib918db/195353459)

外部貢獻

  • 新增了 Modifier.pointerHoverIcon (I95f01)

1.1.0-beta01 版本

2021 年 10 月 27 日

發布 androidx.compose.foundation:foundation:1.1.0-beta01androidx.compose.foundation:foundation-layout:1.1.0-beta011.1.0-beta01 版本包含以下修訂項目。

修正錯誤

  • 新增實驗性的 BringIntoView API,可讓您傳送要求給父項,讓父項透過捲動將項目帶入檢視區塊 (Ib918db/195353459)

1.1.0-alpha06 版本

2021 年 10 月 13 日

發布 androidx.compose.foundation:foundation:1.1.0-alpha06androidx.compose.foundation:foundation-layout:1.1.0-alpha061.1.0-alpha06 版本包含以下修訂項目。

API 變更

  • 新增 Layout 的無子項超載,使效率提高 (Ib0d9a)
  • SemanticsNodeInteraction.performSemanticsAction 現在可傳回所呼叫函式位在的 SemanticsNodeInteraction。(I9e5db)
  • 新增了 performScrollToNode(matcher: SemanticsMatcher),能將可捲動的容器捲動到經過特定的比對器比對為相符的內容。(Ic1cb8)

1.1.0-alpha05 版本

2021 年 9 月 29 日

發布 androidx.compose.foundation:foundation:1.1.0-alpha05androidx.compose.foundation:foundation-layout:1.1.0-alpha05查看 1.1.0-alpha05 版的修訂項

API 變更

修正錯誤

  • 修正可捲動項 (無論延遲與否) 在捲動方面的無障礙支援 (I6cdb0)

1.1.0-alpha04 版本

2021 年 9 月 15 日

發布 androidx.compose.foundation:foundation:1.1.0-alpha04androidx.compose.foundation:foundation-layout:1.1.0-alpha041.1.0-alpha04 版本包含以下修訂項目。

API 變更

  • 淘汰 performGestureGestureScope,並替換為 performTouchInputTouchInjectionScope。(Ia5f3fb/190493367)
  • touchBoundsInRoot 加入含有最低觸控目標尺寸的 SemanticsNode,讓開發人員能確保觸控目標符合無障礙功能的最低要求 (I2e14bb/197751214)

修正錯誤

1.1.0-alpha03 版

2021 年 9 月 1 日

發布 androidx.compose.foundation:foundation:1.1.0-alpha03androidx.compose.foundation:foundation-layout:1.1.0-alpha031.1.0-alpha03 版本包含以下修訂項目。

新功能

  • 更新 Compose 1.1.0-alpha03,使其依附於 Kotlin 1.5.30。(I74545)

API 變更

  • 已新增捲動的光暈效果。已新增實驗性 OverScrollConfiguration API,以設定過度捲動的視覺效果。輸入 null 即可關閉過度捲動效果。(I0c304b/171682480)
  • AwaitPointerEventScope 現在起具備 withTimeout() 和 withTimeoutOrNull() (I507f0b/179239764b/182397793)
  • 新增了測試方法,以取得裁剪邊界 (I6b28e)
  • 已對 ViewConfiguration 新增最小觸控目標尺寸,將其用於語意及輸入指標,確保可使用無障礙功能。(Ie861c)

1.1.0-alpha02 版

2021 年 8 月 18 日

發布 androidx.compose.foundation:foundation:1.1.0-alpha02androidx.compose.foundation:foundation-layout:1.1.0-alpha02查看 1.1.0-alpha02 版的修訂項

API 變更

1.1.0-alpha01 版本

2021 年 8 月 4 日

發布 androidx.compose.foundation:foundation:1.1.0-alpha01androidx.compose.foundation:foundation-layout:1.1.0-alpha011.1.0-alpha01 版本包含以下修訂項目。

API 變更

  • 已更新利用來源和目的地矩形的 DrawScope#drawImage 方法,以便使用選擇性的 FilterQuality 參數。相當適合像素風格藝術在放大時進行像素化處理之用。已更新 BitmapPainter + Image 可組合項,成為也能取用選擇性的 FilterQuality 參數 (Ie4fb0b/180311607)
  • 按下返回按鈕時,TextField 現在可清除選取項目,這與 Android EditText 的行為相符 (I3ca16b/174173645)。
  • 新增游標控點 (I07a82b/173016579)。

修正錯誤

  • 對於延遲清單和一般捲動元件的語意操作之下所執行的捲動,現在能夠呈現動畫 (Id9066b/190742024)

外部貢獻

  • LazyVerticalGrid 現在可接受水平與垂直排列參數兩者。(If9c92)

1.0 版本

1.0.5 版

2021 年 11 月 3 日

發布 androidx.compose.foundation:foundation:1.0.5androidx.compose.foundation:foundation-layout:1.0.51.0.5 版包含此連結所列的修訂項目。

修正錯誤

  • 修正追蹤 derivedStateOf 例項時的異常終止問題 (aosp/1792247)。

1.0.4 版

2021 年 10 月 13 日

發布 androidx.compose.foundation:foundation:1.0.4androidx.compose.foundation:foundation-layout:1.0.41.0.4 版包含此連結所列的修訂項目。

依附元件更新

  • 已更新為依附 Kotlin 1.5.31

1.0.3 版

2021 年 9 月 29 日

發布 androidx.compose.foundation:foundation:1.0.3androidx.compose.foundation:foundation-layout:1.0.31.0.3 版包含此連結所列的修訂項目。

依附元件更新

  • 已更新為依附 Kotlin 1.5.30

1.0.2 版

2021 年 9 月 1 日

發布了 androidx.compose.foundation:foundation:1.0.2androidx.compose.foundation:foundation-layout:1.0.21.0.2 版包含此連結所列的修訂項目。

更新為支援 Compose 1.0.2 版。Compose 1.0.2 仍與 Kotlin 1.5.21 相容。

1.0.1 版

2021 年 8 月 4 日

發布 androidx.compose.foundation:foundation:1.0.1androidx.compose.foundation:foundation-layout:1.0.11.0.1 版包含此連結所列的修訂項目。

依附元件更新

  • 已更新為依附 Kotlin 1.5.21

1.0.0 版本

2021 年 7 月 28 日

發布了 androidx.compose.foundation:foundation:1.0.0androidx.compose.foundation:foundation-layout:1.0.0查看 1.0.0 版的修訂項

1.0.0 的主要功能

這是 Compose 的第一個穩定版本。如需詳細資訊,請參閱官方的 Compose Release 網誌

已知問題

  • 如果使用的是 Android Studio Bumblebee Canary 4 或 AGP 7.1.0-alpha04/7.1.0-alpha05,則可能會遇到下列當機情形:

      java.lang.AbstractMethodError: abstract method "void androidx.lifecycle.DefaultLifecycleObserver.onCreate(androidx.lifecycle.LifecycleOwner)"
    

    如需修正這個問題,請暫時將 build.gradle 檔案中的 minSdkVersion 提高到 24 以上。Android Studio Bumblebee 和 AGP 7.1 的下一個版本會修正這個問題 (b/194289155)

1.0.0-rc02 版

2021 年 7 月 14 日

發布 androidx.compose.foundation:foundation:1.0.0-rc02androidx.compose.foundation:foundation-layout:1.0.0-rc02查看 1.0.0-rc02 版的修訂項

  • 更新一般形狀的邊框轉譯功能,解決使用固定尺寸定義的路徑所發生的問題。(aosp/1748871b/191817116)

1.0.0-rc01 版本

2021 年 7 月 1 日

發布 androidx.compose.foundation:foundation:1.0.0-rc01androidx.compose.foundation:foundation-layout:1.0.0-rc01查看 1.0.0-rc01 版的修訂項

API 變更

  • Canvas 現已支援 contentDescription 參數以提供無障礙功能。(Ib547c)

修正錯誤

  • 停用的按鈕、資訊卡、核取方塊和整體 Modifier.clickable(enabled=false) 會阻止點擊父項。(Ic2c3bb/183908811)

1.0.0-beta09 版本

2021 年 6 月 16 日

發布 androidx.compose.foundation:foundation:1.0.0-beta09androidx.compose.foundation:foundation-layout:1.0.0-beta091.0.0-beta09 版包含此連結所列的修訂項目。

API 變更

  • 移除了 ManualFrameClock。如要控制動畫,請改用 composeTestRule.mainClock。(I3c3e8b/189951065)。
  • 將列舉 Role 和 LiveRegionMode 變更為使用私人建構函式的內嵌類別 (Id1890)
  • KeyboardCapitalization 會轉換為內嵌類別。(Id5a1c)
  • TextOverflow 已變更為內嵌類別。(I433af)

修正錯誤

  • 現在,當您為 LazyColumn/Row 項目指定不重複的按鍵時,會依照該鍵維持住捲動的位置,亦即如果在目前可見的項目之前加入/移除項目,系統會將該鍵所給定的項目維持在第一個顯示的項目。(Id263fb/184257857)
  • 目前索引鍵常數為 @ExperimentalComposeUiApi。穩定之前,使用程式碼可宣告不公開常數。(Ia5d48)
  • 已將 IdlingStrategy 新增至 AndroidComposeTestRule,測試架構可用來安裝等待或達成休止的替代機制。請在測試作業開始安裝您本身的策略之前,先使用 AndroidComposeTestRule.setIdlingStrategyFactory()。(I608fa)

新增設定檔規則

這個版本將設定檔規則新增至下列撰寫模組 (I14ed6):

  • androidx.compose.animation
  • androidx.compose.animation-core
  • androidx.compose.foundation
  • androidx.compose.foundation-layout
  • androidx.compose.material
  • androidx.compose.material-ripple
  • androidx.compose.runtime
  • androidx.compose.ui
  • androidx.compose.ui.geometry
  • androidx.compose.ui.graphics
  • androidx.compose.ui.text
  • androidx.compose.ui.text
  • androidx.compose.ui.unit
  • androidx.compose.ui.util

什麼是設定檔規則?

  • 程式庫的設定檔規則在位於 src/main 或同等目錄中的文字檔 baseline-prof.txt 內進行指定。該檔案會每行指定一個規則,這裡的規則是指對應至程式庫方法或類別的模式。這些規則所用語法是人類可讀形式的 ART 設定檔格式的超集,使用 adb shell profman --dump-classes-and-methods ... 時會用到這類格式。這些規則會採用兩種形式之一來指定方法或類別。

  • 方法規則將採用以下模式:

    <FLAGS><CLASS_DESCRIPTOR>-><METHOD_SIGNATURE>
    
  • 類別規則將採用以下模式:

    <CLASS_DESCRIPTOR>
    
  • 此處的 <FLAGS>HSP 之中的一或多個字元,用於指出這個方法應標記為「Hot」、「Startup」或「Post Startup」。

  • <CLASS_DESCRIPTOR> 是指定方法所屬的類別描述元。舉例來說,androidx.compose.runtime.SlotTable 類別的描述元是 Landroidx/compose/runtime/SlotTable;

  • <METHOD_SIGNATURE> 是方法的簽名,含有該方法的名稱、參數類型和傳回類型。舉例來說,LayoutNode 上的 fun isPlaced(): Boolean 方法含有 isPlaced()Z 簽名。

  • 這些模式可包含萬用字元 (***?),以便讓單一規則涵蓋多種方法或類別。

規則的用途

  • 方法中如果帶有 H 標記,表示這個方法是「Hot」方法,應該預先完成編譯。

  • 方法中如果帶有 S 標記,表示這是系統會在啟動時呼叫的方法,應該預先完成編譯,以免啟動時耗費資源處理編譯作業及解析方法。

  • 方法中如果帶有 P 標記,表示這是系統在啟動之後才會呼叫的方法。

  • 如果類別顯示在這個檔案中,表示系統會在啟動期間使用該類別,因此應該要事先在堆積中分配該類別,以免耗費載入類別的成本。

運作方式

  • 程式庫可以定義這些規則,並會包裝於 AAR 構件中。接著,系統會在建構包含這些構件的應用程式時,將這些規則合併起來,然後使用合併後的規則建構該應用程式專屬的精簡二進位 ART 設定檔。當該應用程式安裝在裝置上時,ART 便可以利用這個設定檔預先編譯特定應用程式子集,以提高應用程式效能,特別是首次執行的效能。請注意,這項設定不會對可偵錯的應用程式產生任何影響。

1.0.0-beta08 版

2021 年 6 月 2 日

發布了 androidx.compose.foundation:foundation:1.0.0-beta08androidx.compose.foundation:foundation-layout:1.0.0-beta08查看 1.0.0-beta08 版的修訂項

API 變更

  • NestedScrollSource 列舉已由內嵌類別取代。(Ie321bb/187055290)
  • 已將列舉用法重構為內嵌類別,以避免在新增列舉值時提供完整陳述式而造成問題(I2b5eb)
  • 新增可點擊/可切換項目的輕觸逾時設定,以免在捲動/拖曳時呈現漣漪效果 (Ia2704b/168524931)
  • ContentDescription 和 Text 語意屬性不再只是單一的值,而是清單。如此即可直接合併,無需串連。同時也提供更優質的測試 API,以便善用這些變更 (Ica6bfb/184825850)
  • 已將 Modifier.focusModifier() 淘汰,改為 Modifier.focusTarget() (I6c860)
  • KeyboardType 列舉改為內嵌類別 (I73045b/187055290)。
  • FocusState 列舉已改為 FocusState 介面 (Iccc1ab/187055290)
  • ImeAction 列舉已由內嵌類別取代。(I18be5b/187055290)
  • AnnotatedString.withAnnotation 函式現在是 ExperimentalTextApi,而非 ExperimentalComposeApi。(I0cd0a)
    • 採用 TextUnitType 的 TextUnit 建構函式現在是 ExperimentalTextApi,而非 ExperimentalComposeApi。
  • PaddingValues 現已由 @Immutable 改為 @Stable (I88c50)

修正錯誤

  • 已修正長按非空白文字中的空白區域會異常終止的問題 (I33ab5b/187437299)。
  • 於 SelectAll 之後顯示 Toolbar (I495d9b/185919613)
  • 修正可捲動容器會在跨軸時裁剪子項的問題。如果有使用具備 Card 項目的 LazyRow,此問題之前很容易重現;現在起陰影不會被裁切 (Icb635b/186318448)。
  • 已修正使用 Modifier.combinedClickable 下做出長按動作時,漣漪/其他指標有時候會卡住的問題 (I2298cb/186223077)
  • 現在,detectDragGesuresdetectVerticalGesturesdetectHorizontalGestures 會自動取用位置變更,不需呼叫 onDrag 回呼中的 change.consumePositionChange (I42fc4b/185096350b/187320697)
  • 變更 Modifier.onGloballyPositioned(),系統會回報此修飾符在修飾符鏈結中的座標,而非套用所有修飾符後的版面配置座標。也就是說,修飾符的排序現在會影響系統回報的座標。(Ieb67db/177926591)

1.0.0-beta07 版

2021 年 5 月 18 日

發布 androidx.compose.foundation:foundation:1.0.0-beta07androidx.compose.foundation:foundation-layout:1.0.0-beta071.0.0-beta07 版包含此連結所列的修訂項目。

API 變更

修正錯誤

  • LazyColumn/Row 現在會保留最多 2 個先前顯示項目的有效狀態 (而非加以丟棄),即使這些項目已被捲出畫面也一樣。如此一來,當我們需要組合新項目時,元件可重複使用有效的子組合,達到提升捲動效能的效果 (Ie5555)
  • 移除 paintBackground。(I38660)
  • 使用 DrawScope 繪製選取項目背景。(I73c61b/186674472)
  • 修正會影響 Row/Column 使用 spacedBy 排列方式配置加權子項的 beta06 迴歸問題 (Ifaf8cb/187326588)。

1.0.0-beta06 版本

2021 年 5 月 5 日

發布了 androidx.compose.foundation:foundation:1.0.0-beta06androidx.compose.foundation:foundation-layout:1.0.0-beta06查看 1.0.0-beta06 版的修訂項

API 變更

  • 解決手勢操作衝突的問題 (I1145e)
  • 新增了 CollectionInfo 和 CollectionItemInfo 無障礙 API,可為無障礙服務對集合及其項目進行標示 (Id54efb/180479017)
  • 新增了 SemanticsActions.ScrollToIndex,可將含有索引項目的項目清單捲動到含有特定索引的項目,並新增 SemanticsProperties.IndexForKey 以取得包含索引鍵項目清單的項目索引。這兩個動作均是透過 LazyList 實作。
    • 新增了 SemanticsNodeInteraction.performScrollToIndexSemanticsNodeInteraction.performScrollToKey,前者可將清單捲動至指定的索引,後者則能將清單捲動到含有指定鍵的項目上。(I4fe63b/178483889b/161584524)
  • 對 TextFieldValue.Saver 新增儲存 AnnotatedString 的支援。新增了 addTtsAnnotation 和 withAnnotation 公用函式至 AnnotatedString.Builder (I8cbdcb/178446304)
  • 已將預設 0.dp 參數值新增至 PaddingValues(horizontal, vertical) (I05571b/181336792)

修正錯誤

  • 含有 weight(fill = false) 的 Row 和 Column 子項不再能讓父項填滿完整的主軸可用空間。(Ied94db/186012444b/184355105)

1.0.0-beta05 版

2021 年 4 月 21 日

發布 androidx.compose.foundation:foundation:1.0.0-beta05androidx.compose.foundation:foundation-layout:1.0.0-beta05查看 1.0.0-beta05 版的修訂項

API 變更

  • FlingBehavior 介面現在標示為 @Stable。所有實作項目都必須遵守 @Stable 合約。(I93354b/184830577)

修正錯誤

  • 修正 ACTION_SCROLL_FORWARDACTION_SCROLL_BACKWARDaccessibilityActionScrollLeftaccessibilityActionScrollUpaccessibilityActionScrollRightaccessibilityActionScrollDown 無障礙捲動操作。現在不會捲動至可捲動項目底部,而是會依照指定方向捲動單一畫面 (Ieccb0)。
  • ui-test-manifest 和 ui-tooling-data 的 AndroidManifest 檔案現在與 Android 12 相容 (I6f9deb/184718994)

1.0.0-beta04 版

2021 年 4 月 7 日

發布 androidx.compose.foundation:foundation:1.0.0-beta04androidx.compose.foundation:foundation-layout:1.0.0-beta041.0.0-beta04 版包含此連結所列的修訂項目。

API 變更

  • SoftwareKeyboardController 上的 hideSoftwareKeyboard 和 showSoftwareKeyboard 分別重新命名為 hide()show()
    • 為 LocalSoftwareKeyboardController 提供完整的 CompositionLocal 介面,以便設定該物件 (在測試中特別實用) (I579a6)
  • 加入 TextOverflow.Visible。(Ic8f89)
  • 移除 RowScopeColumnScopeBoxScopeBoxWithConstraintsScope 的公開例項。(I4e83eb/181869067)

修正錯誤

  • 已修正快速滑過後,位於邊緣的 LazyColumn/LazyRow 項目位置擺放錯誤的問題 (Ie4d13b/183877420)
  • 在這項變更之前,本機可組合函式可根據其參數而略過。在此變更之後,系統就不會略過任何本地可組合函數。之所以要做這樣的更改,是因為本地函數通常會擷取父項參數,而略過參數是常見的錯誤原因。

    總結來說,建議您參考以下範例:

    @Composable fun Counter(count: Int, onCountChange: (Int) -> Unit) {
      @Composable fun ShowCount() { Text("Count: $count") }
      ShowCount()
      Button(onClick={ onCountChange(count + 1) }) {
        Text("Increment")
      }
    }
    

    在此變更之前,即使 count 參數已更新,ShowCount 可組成的函數也會一律略過。不過現在已非如此。(I5648a)

1.0.0-beta03 版本

2021 年 3 月 24 日

發布 androidx.compose.foundation:foundation:1.0.0-beta03androidx.compose.foundation:foundation-layout:1.0.0-beta03查看 1.0.0-beta03 版的修訂項

API 變更

  • 淘汰 DefaultMonotonicFrameClock。現在呼叫無 MonotonicFrameClockwithFrameNanosRecomposer.runRecomposeAndApplyChanges 會擲回 IllegalStateException (I4eb0d)

修正錯誤

  • 即使速率為 0,現在系統仍會呼叫 FlingBehavior.performFling() (I0b6e5b/181237123)

1.0.0-beta02 版

2021 年 3 月 10 日

發布 androidx.compose.foundation:foundation:1.0.0-beta02androidx.compose.foundation:foundation-layout:1.0.0-beta02查看 1.0.0-beta02 版的修訂項

API 變更

  • 在 LazyColumn 測量邏輯中新增多個小型最佳化項目 (Ic6889)
  • 新增 LocalSoftwareKeyboardController 組合本機 API,取代 TextField 的 SoftwareKeyboardController 舊介面。(I5951eb/168778053)。
  • 新增了 LocalSoftwareKeyboardController 組合本機 API,以取代 TextField 中的舊 SoftwareKeyboardController 介面 (I84472b/168778053)

修正錯誤

1.0.0-beta01 版

2021 年 2 月 24 日

發布 androidx.compose.foundation:foundation:1.0.0-beta01androidx.compose.foundation:foundation-layout:1.0.0-beta011.0.0-beta01 版包含此連結所列的修訂項目。

這是 Compose 1.0.0 Beta 版的第一個版本。

API 變更

  • 已將 onStart 回呼新增至 detectDragGestures (I67269b/179995594)
  • 用於依照內建函式調整大小的修飾符不再處於實驗階段。(I15744)
  • 已移除 dp 判斷提示 (I798d2)
  • SoftwareKeyboardController 回呼已從所有文字欄位中移除,而且很快就會替換為新的 API。(Iae869b/168778053)
  • MeasureBlock 已重新命名為 MeasurePolicy,成為趣味介面。版面配置 API 經過更新/簡化,可使用 MeasurePolicy (Icab48b/167662468b/156751158)。
  • InteractionState 已替換為 [Mutable]InteractionSource
    • 介面負責傳送/收集「互動」(Interaction) 事件。
    • 使用 interactionSource = remember { MutableInteractionSource() },而不是將 interactionState = remember { InteractionState() } 傳遞給 ButtonModifier.clickable() 等元件。
    • 應改用 InteractionSource 中的擴充功能函式,例如 InteractionSource.collectIs PressedAsState(),而不是:Interaction.Pressed in interactionState
    • 如果用途複雜,可以使用 InteractSource.interactions 來觀察互動的串流。如需詳細資訊,請參閱 InteractSource 的說明文件和範例
    • (I85965b/152525426b/171913923b/171710801b/174852378)。
  • 移除了淘汰的 LayoutCoordinate 方法,positionInParent 和 boundsInParent 請使用函式,請勿使用屬性 (I580edb/169874631b/175142755)
  • 為 CoreTextField 等低階文字元件的輸入工作階段建立新的 TextInputSession。(I8817fb/177662148)
  • 「位置」指標現在會顯示測距,代表子版面配置實際測量的大小。這個大小可能不受測量限制的影響。(Ib2729b/172560206b/172338608)。
  • 新增 selectionGroup 修飾符,可為 Tab 或 RadioButton 集合加上無障礙用途標示 (Ie5c29)
  • 新增 LazyListState.animateScrollToItem

    這個方法會快速捲動至清單中的特定項目。(I4bfd7)

  • ScrollableState.smoothScrollBy() 已重新命名為 animateScrollBy() LazyListState.snapToItemIndex() 已重新命名為 scrollToItem() ScrollState.smoothScrollTo() 已重新命名為 animateScrollTo() (I35ded)

  • Modifier.zoomable 已取代為 Modifier.transformable。smoothPanBy、smoothRotationBy 已新增成為功能 (Ifc32bb/175294473)。

  • compositionLocalOfstaticCompositionLocalOfdefaultFactory 現在是必要元素,而非選用元素。

    如未提供預設工廠,這項變更可移除非空值的潛在類型錯誤。以前,這會為非空值的類型提供空值的參照。

    如果是可為空值類型,請考慮提供 { null } 做為預設工廠。

    除非能提供合理的預設值,否則我們不建議搭配不可為空值類型使用本機。如果沒有任何可行的預設值,defaultFactory lambda 應擲回例外狀況。不過,擲回例外狀況代表本機取用者會有隱含的依附元件,前提是該元件不會由類型系統強制執行 (Ifbd2a)

  • 已將 Indication#createIndication() 變更為 Indication#rememberUpdatedIndication(InteractionState),並自 IndicationInstance#drawIndication() 移除 InteractionState 參數。IndicationInstance 只應負責繪製視覺效果,而非回應 InteractionState 的變更,啟動動畫/寫入狀態。這些動畫和狀態寫入作業應改為在 rememberUpdatedIndication() 內執行。此外,Modifier.indication 中的 indication 參數也已變更為必要參數 (Ic1764b/152525426)

  • Text 操作現在會自動檢查焦點 (I13777b/179648629)

  • 移除了 runBlockingWithManualClock (I15cdcb/179664814)

  • Modifier.verticalScroll()/horizontalScroll() 的捲動位置現在起以 Int 表示 (I81298)

  • smoothScrollBy 和 ScrollBy 方法的套件已變更為 androidx.compose.foundation.gestures.* (I3f7c1b/175294473)

  • FlingConfig 已重新命名為 FlingBehavior,現在起可自訂懸浮動畫,而非預先定義的 Decay。(I02b86b/175294473)

  • 已重新命名大小修飾詞。將 Modifier.width/height/size 重新命名為 requiredWidth/requiredHeight/requiredSize。Modifier.PreferredWidth/PreferredHeight/recommendedSize 已重新命名為 width/height/size。(I5b414)

  • defaultMinSizeConstraint 已重新命名為 defaultMinSize。(I4eaae)

  • 已移除 Modifier.tapGestureFilter。請改用 Modifier.pointerInput { detectTapGestures(...) } (I266edb/175294473)。

  • 部分消耗已從指標輸入系統中移除。協調部分消耗的建議做法是使用 Modifier.nestedScroll (Ie9c9b)。

  • 方向已移至基礎套件。VelocirtTracker 已從 ui.gesture 移至 ui.input.pointer (Iff4a8b/175294473)

  • 已移除 AnimationClockObservable 和子類別。AnimatedFloat 也已移除。(Icde52b/177457083)。

  • drawerState.open() 和 drawerState.close() 現已為暫停函式。可使用 rememberCoroutineScope() 取得組合的範圍以便呼叫 (I16f60b/175294473)

  • Provider 已重新命名為 CompositionLocalProvider

    • Composition 建構函式不再接受索引鍵參數,且已淘汰。
    • currentCompositeKeyHash 已變成可組合的頂層屬性,而非可組合的頂層函式。
    • CompositionData 和 CompositionGroup 已移至 androidx.compose.runtime.tooling 命名空間
    • ComposableLambda 已成為介面而非具體類別,並且不再有類型參數。
    • ComposableLambdaN 已成為介面而非具體類別,並且不再有類型參數。
    • snapshotFlow 函式已移至 androidx.compose.runtime 命名空間。
    • SnapshotMutationPolicy 的合併方法不再為實驗性。
    • 移除 @TestOnly 頂層 clearRoots 函式,因為不再需要使用。
    • 已移除 keySourceInfoOf 和 resetSourceInfo 函式,因為不再需要使用。
    • 已移除 Composer.collectKeySourceInformation,因為不再需要使用。
    • 已移除 isJoinedKey、joinedKeyLeft 和 joinedKeyRight 方法。因為不再需要使用。
    • 重新整理多個頂層 API,分別歸類到不同的檔案中。由於 Kotlin 的檔案類別語意的關係,此舉會破壞二進位檔案相容性,但不影響原始碼相容性,因此對大多數使用者而言應不成問題
    • (I99b7db/177245490)
  • Modifier.scrollable 經過重新設計。今後其使用 Scrollable 介面,而非 ScrollableController 類別 (I4f5a5b/174485541b/175294473)

  • Modifier.draggable 現在接受 DraggableState,而非簡單的 lambda。您可以透過 rememberDraggableState { delta -> } 建立狀態,以得到與之前相同的行為 (Ica70fb/175294473)

  • 新增 requiredWidth(IntrinsicSize) 和 requiredHeight(IntrinsicSize) 修飾符,以便視需要調整內建函式尺寸 (I0a6b4)

  • 移除淘汰的 emptyContent()。請改用 {} (Idb33fb/179432510)。

  • 已刪除一些先前淘汰的 API (Ice5dab/178633932)

修正錯誤

  • 新增 LocalSoftwareKeyboardController 組合本機 API,取代 TextField 的 SoftwareKeyboardController 舊介面 (I658b6b/168778053)。

1.0.0-alpha12 版

2021 年 2 月 10 日

發布了 androidx.compose.foundation:foundation:1.0.0-alpha12androidx.compose.foundation:foundation-layout:1.0.0-alpha121.0.0-alpha12 版包含此連結所列的修訂項目。

API 變更

  • Modifier.pointerInput 目前規定 remember 鍵必須指出指標輸入偵測處理常式何時該重新啟動,以設定新的依附元件。(I849cd)
  • 測試更新:hasText() 會檢查文字欄位中的輸入和標籤/提示/預留位置文字 (Iab803)
  • 已新增 PaddingValues.Absolute 且可於接受 PaddingValue 的 API 中使用。(Ia5f30)
  • onImeActionPerformed 已淘汰,請改用 KeyboardAction (If0bbdb/179071523)
  • 為更符合 ImageBitmap 和 ImageVector 的命名慣例,ImagePainter 已重新命名為與 VectorPainter 並行的 BitmapPainter。(Iba381b/174565889)
  • 已改良子字串測試 API,現在起以子字串作為引數 (Icbe78)
  • 推出 InfiniteAnimationPolicy 協同程式結構定義元素,這將套用於無限動畫。根據預設,系統不會安裝任何政策,除非使用 ComposeTestRule 執行測試。(I50ec4b/151940543)。
  • Animatable.snapTo 和 Animatable.stop 現已為暫停函式 (If4288)
  • ComponentActivity.setContent 已移至 androidx.activity:activity-compose 模組中的 androidx.activity.compose.setContent。(Icf416)
  • Destructuring 和 copy() 方法在幾個類別中極少使用,現已將其從中移除。(I26702b/178659281)
  • 已新增支援 LazyColumn/LazyRow 的自訂索引鍵。如此一來,項目重新排序可處理得更佳。因此在將元素重新排序、或從中間移除項目時,儲存在記憶 {} 區塊中的狀態可隨項目一起移動

    LazyColumn {
        items(users, key = { user -> user.id }) { ... }
    }
    
  • 已將 Indication#createInstance 變更為 @Composable,並將 LocalIndication 更改為含有 Indication,而非 () -> Indication。(I5eeeab/157150564)

  • Constraints.enforce 已改為 Constraints.constrain。(I8b8ea)

  • loadFontResource 已淘汰,請改用 fontResource。imageResource、loadImageResource、vectorResource 和 loadVectorResource 也已淘汰,請改用 painterResource。(I6b809)

  • 出於效能考量,ScrollAxisRange 語意現在接受傳回 Float (而非直接 Float 值) 的 lambda。(If4a35b/178657186)。

  • 新增了 EditableText 語意,可為文字欄位的可編輯輸入文字加上無障礙標示,同時新增對應的測試方法以檢查語意 (I8e07a)

  • Modifier.clickable 現在不支援連按兩下和長按。如要達到此功能,請使用 Modifier.combinedClickable。(Iafad1)

  • toIntPx() 已重新命名為 roundToPx() (I9b7e4b/173502290)

  • IntBounds 已重新命名為 IntRect,且該 API 已改善 (I1f6ff)

  • 已淘汰 Modifier.dragGestureFilter。請改用 Modifier.pointerInput { detectDragGestures (...)}。或者,也可使用 Modifier.draggable 進行單一軸線拖曳 (I0ba93b/175294473)

  • 已將 Ambient 重新命名,以配合 Ambient -> CompositionLocal 的更名。Ambient 原本名為 AmbientFoo,現在已將 CompositionLocal 命名為 LocalFoo。(I2d55d)

  • 選取項目已移至 Foundation。(I7892b)

  • 如同我們先前移除 state { 0 } 可組合項且現在鼓勵使用 remember { mutableStateOf(0) } 等項目,我們也將移除 savedInstanceState { 0 } 可組合項。請改用 rememberSaveable { mutableStateOf(0) },如果 MutableState 中使用的類型可以存放在 Bundle 中,系統將自動儲存並還原資料。如果您之前傳遞的是自訂 Saver 物件,現在就必須使用含有 stateSaver 參數的新 rememberSaveable 超載。用法形式如下:val holder = rememberSaveable(stateSaver = HolderSaver) { mutableStateOf(Holder(0)) } (Ib4c26b/177338004)

  • 新增了無障礙功能密碼語意 (I231ce)

  • 新增了 ProgressBarRangeInfo.Indeterminate 以標示無障礙功能的不確定進度列 (I6fe05)

  • 動畫中的播放時間現已統一為奈秒 (If776a)

  • 已淘汰 @ComposableContract,並改用三個更具體的註解。

    @ComposableContract(restartable = false) 已成為 @NonRestartableComposable @ComposableContract(readonly = true) 已成為 @ReadOnlyComposable @ComposableContract(preventCapture = true) 已成為 @DisallowComposableCalls @ComposableContract(tracked = true) 已移除。(I60a9d)

  • 已淘汰 emptyContent()(@Composable () -> Unit).orEmpty() 公用程式,原因是這些公用程式對效能已無正面影響或價值 (I0484d)

  • 重新寫入器現在可以關閉。封閉的重組工具將繼續調整,直到構成的子項協同程式完成為止。 將 Recomposer.shutDown 重新命名為「cancel」,以便與關閉對照 (Ib6d76)。

  • LazyVerticalGrid 的相關 API 會標示為實驗性 (Ia53e3b/178519862)

  • rememberSavedInstanceState() 重新命名為 rememberSaveable() 並且移至 androidx.compose.runtime.saveable 套件。(I1366eb/177338004)

  • RestorableStateHolder 已重新命名為 SaveableStateHolder,並移至 androidx.compose.runtime.saveable 套件。內部方法 RestorableStateProvider 已重新命名為 SaveableStateProvider。Generic 類型已移除,可直接將 Any 以索引鍵格式傳遞,不再需要使用實驗性註解。(I0902eb/174598702)。

  • Saver、listSaver()、mapSaver()、autoSaver 已從 androidx.compose.runtime.savedinstancestate 移至 androidx.compose.runtime.saveable (I77fe6)

  • 構件 androidx:compose:runtime:runtime-saved-instance-state 已重新命名為 androidx:compose:runtime:runtime-saveable (I6dcac)

  • UI 套件中許多過時的 API 都已刪除 (I2f2dc)。

  • compose:runtime-dispatch 構件現已淘汰。目前可在 compose:runtime 中找到 MonotonicFrameClock,而 AndroidUiDispatcher 則可在 compose:ui 中找到。(Ib5c36)

  • 為了支援形狀在 rtl 方向的自動鏡射,RounderCornerShape、CutCornerShape 和 CornerBasedShape 上的參數已從 left/right 重新命名為 start/end。導入 AbsoluteRounderCornerShape 和 AbsoluteCutCornerShape,處理不需要自動鏡像功能的情況 (I61040b/152756983)

  • canDrag 已從 Modifier.scrollable 中移除。(Id66e7b/175294473)

  • Compose 編譯器外掛程式作為對象的 API 已經重構為採取介面,而不是具體類別。此外,介面也不會再使用類型參數。

    這項內部變更應該不會影響原始碼相容性,但屬於二進位破壞性變更 (I3b922b/169406779)。

  • 已移除 Modifier.scaleGestureFilter。請改用 Modifier.zoomable。或者,請使用 Modifier.pointerInput { detectMultitouchGestures { ... }} (Id5da1b/175294473)

  • AnimatedValue/Float 現已淘汰。請改用 Animatable (I71345b/177457083)

    • 已從公用 API 移除 CoreText 和 CoreTextField
    • 已移除淘汰的 SelectionContainer 超載 (I99c19)
  • 移除已淘汰的非暫停捲動函式 繼上次發行所作的變更後,非暫停捲動函式現已完全移除。請轉而使用同名的暫停函式。協同程式範圍可經由 rememberCoroutineScope() 取得 (I3d39cb/178169563)。

  • 已淘汰 androidx.compose.foundation.layout.ConstraintLayout,並改用 androidx.constraintlayout.compose.ConstraintLayout。您需要在 androidx.constraintlayout:constraintlayout-compose:1.0.0-alpha01 上新增依附元件 (I87adc)。

  • 已淘汰 tapGestureFilter、doubleTapGestureFilter、longPressGestureFilter 及 pressIndicaitonGestureFilter。請改用 Modifier.clickable 或 Modifier.pointerInput 搭配 DetectionTapTouchs 函式。(I6baf9b/175294473)

  • 移除了 Recomposer.current()。[Abstract]ComposeView 現已預設為延遲建立、以視窗為範圍的 Recomposers,並由視窗的 ViewTreeLifecycleOwner 所驅動。主機的生命週期停止時,Recomposition 和以withFrameNanos 為基礎的動畫滴答會暫停。(I38e11)。

  • Recomposer.runningRecomposers 現在會提供唯讀 RecomposerInfo 的全域 StateFlow,用於在程序中觀察進行中的組合狀態。建議使用這個 API 取代已淘汰的 Recomposer.current() (If8ebe)

1.0.0-alpha11 版本

2021 年 1 月 28 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha11androidx.compose.foundation:foundation-layout:1.0.0-alpha111.0.0-alpha11 版包含此連結所列的修訂項目。

API 變更

  • 淘汰非暫停 scrollBy、移除非暫停 scrollTo

    我們建議使用暫停函式來控制捲動,並等待捲動完成。在此轉換過程中,我們正在淘汰和/或移除這些函式的非暫停版。(Ie9ced)

  • 淘汰非暫停的 smoothScrollBy 我們現在建議使用暫停函式來控制捲動,並等待捲動完成。在此轉換過程中,我們正在淘汰這些函式的非暫停版。(I12880)

  • 已為圖片和圖示新增內容說明參數。用於為無障礙功能服務提供說明 (I2ac4c)

  • BasicTextField 收到名為「decorationBox」的新參數。可用以對文字欄位新增例如圖示、預留位置、標籤等等裝飾,和增加命中目標區面積。(I16996)

  • canDrag 參數已從 Modifier.draggable 移除 (Ic4becb/175294473)

  • 接受 FlingConfig 的 AnimatedFloat.fling 已經移除。請改用暫停 Animatable.animateDecay。(I4659bb/177457083)

  • 已將 data class 從以下類別移除:

    • InlineTextContent
    • LocaleList
    • (I605c7)
  • 您現在可以在構圖外建立可點選、可切換和可選取的項目 (I0a130b/172938345b/175294473)

  • 淘汰了 ScrollableColumn/Row。處理大型捲動內容時,使用 ScrollableColumn 的效率會比使用 LazyColumn 低,因為使用 LazyColumn 只能組合/測量/繪製可見元素。為避免使用者選擇效率不彰的做法,我們決定淘汰 ScrollableColumn 和 ScrollableRow,鼓勵改為使用 LazyColumn 和 LazyRow。使用者仍可決定不必使用延遲行為,直接使用類似下例的修飾符:Column(Modifier.verticalScroll(rememberScrollState())) (Ib976bb/170468083)。

  • 已為 LazyColumn/LazyRow/LazyVerticalGrid 的範圍新增 items(count: Int) 工廠方法。items(items: List)itemsIndexed(items: List) 現已成為擴充功能函式,因此在使用時必須手動匯入。新增 Arrays 的擴充功能超載:items(items: Array) 和 itemsIndexed(Array) (I803fcb/175562574)

  • 已移除淘汰的 AbsoluteArrangement。(Iffa96b/177641870)

  • propagateMinConstraints 參數已新增至 Box,以指定收到的最小限制是否應傳遞至 Box 的內容。預設值為 False (I0125bb/152613457)。

修正錯誤

  • 已淘汰 onCommit、onDispose 和 onActive,並改用 SideEffect 和 DisposableEffect API (If760e)
  • WithConstraints 已重新作業為 BoxWithConstraints,並移至 foundation.layout。(I9420bb/173387208)
  • 已將 Font/FontFamily/Typeface 變更為 Factory 函式。

    • 新增了以大寫字母開頭的工廠函式
    • 淘汰了使用第一個字母小寫的舊版工廠函式
    • 新的工廠函式會傳回 FontFamily 而非子類別
    • 隱藏子類別的建構函式,確保子類別只能透過工廠函式建構
    • 已將 Font.asFontFamily 重新命名為 Font.toFontFamily
    • (I42aa7)
  • 引入 ComposeContentTestRule,其擴充 ComposeTestRule 並且定義 setContent,後者已自 ComposeTestRule 移除。新增可傳回 ComposeTestRule 的工廠方法 createEmptyComposeRule(),且不會代為啟動活動。如要在測試期間啟動活動,請使用此方法,例如使用 ActivityScenario.launch (I9d782b/174472899)

  • animateAsState 現已改為 animateFooAsState,其中 Foo 是動畫處理的變數類型,例如 Float、Dp、Offset 等 (Ie7e25)

  • Density 現已成為 Arrangement 介面的接收器範圍。(I18aad)

  • TextFieldValue 可接受 AnnotatedString。然而,此為 API 變更,尚未導入多樣式文字編輯功能。

    • 已從 EditingBuffer 建構函式參數中移除 initial。(I326d5)
  • invalidate 和 compositionReference() 現已淘汰,並分別以 currentRecomposeScope 和 rememberCompositionReference 取代。(I583a8)

  • AnnotatedString 已變更為由 kotlin.CharSequence 擴充。因此 length 和 subSequence 現在是執行個體函式,而擴充功能函式則已經移除。(Iaf429)

  • Duration 和 Uptime 會改為 Long 毫秒,同時此步驟也能移除這些類別上指標輸入的依附元件。(Ia33b2b/175142755b/177420019)

  • RememberObserver 取代 CompositionLifecycleObserver,CompositionLifecycleObserver 現已淘汰。

    RememberObserver 是用修改後的語意和重新命名方法取代的 CompositionLifecycleObserver。針對只記錄一次的物件,您可以不假思索地改為使用新的 API,這是不變的建議做法。不過,如果參照在某個組合中已有多次記錄,系統會針對每個只呼叫一次 onEnter 的參照呼叫 onRemembered。如果子組合 (例如 WithConstraintsScaffold) 使用該物件,則會多次呼叫 onEnter,導致無法保證能穩定地單次呼叫 onEnter,因此已將其從 RememberObserver 中移除。

    RememberObserver 新增 onAbandoned,如果 RememberObserver 執行個體是從傳遞至 remember 的回呼所傳回,但未記錄在組合狀態中,並因此一律不會呼叫 onRemembered,這時就會呼叫此新增項目。之所以會這樣,可能是因為例外狀況在組合完成前終止組合,或是因為產生組合的狀態已過時 (或基於其他原因不再需要使用),導致組合遭到捨棄。如果按照上述單一參照建議提供的 RememberObserver 執行個體追蹤了外部資源,則 onForgottenonAbandoned 都表示不再需要資源。如果物件正在追蹤 onRemembered 中啟動的工作或配置的資源,則可以忽略 onAbandoned,因為呼叫 onRemembered 之後便不會對其發出呼叫 (I02c36)。

  • TransformedText.transformedText 已重新命名為 TransformedText.text

    • TransformedText 不再是資料類別 (Ie672a)
  • 以下類別不再是資料類別:

    • AnnotatedString
    • ParagraphStyle
    • SpanStyle
    • TextStyle
    • FontWeight
    • TextDecoration
    • TextGeometricTransform
    • TextIndex
    • TextLayoutResult
    • TextLayoutInput (Iaff99)
  • 已移除實驗性的 monotonicFrameAnimationClockOf 方法 (Ib753fb/170708374)

  • 淘汰全域座標方法,並建構新的視窗式座標方法。(Iee284)

  • 請使用 ImeAction.None 取代 ImeAction.NoAction

    • 請使用 ImeAction.Default 取代 ImeAction.Unspecified (Ie1bcc)
  • FocusRequester.createRefs 因為可能會有所變動,目前標示為實驗性質 (I2d898b/177000821)。

  • SemanticsPropertyReceiver.hidden 已重新命名為 invisibleToUser 並標示為 @ExperimentalComposeUiApi。AccessibilityRangeInfo 已重新命名為 ProgressBarRangeInfo。stateDescriptionRange 已重新命名為 progressBarRangeInfo。AccessibilityScrollState 已重新命名為 ScrollAxisRange。horizontalAccessibilityScrollState 已重新命名為 horizontalScrollAxisRange。verticalAccessibilityScrollState 已重新命名為 verticalScrollAxisRange (Id3148)

  • VisualTransformation 已變更為功能介面 (I3bba4)

  • 運用 TestCoroutineDispatcher 進行測試 (I532b6)

  • 已移除 PointerInputData 並修改 PointerInputChange,為其提供所有 PointerInputData 的欄位。將 PointerInputEvent 和 PointerInputEventData 改為內部使用,因為這些並未用於任何公用 API (Ifff97b/175142755)

  • 已將 TextInputService.onStateUpdated 重新命名為 updateState (Id4853)

  • displaySize 應避免使用,因此請移除。一般建議使用 onRoot() 的尺寸,或至少使用視窗尺寸 (I62db4)

1.0.0-alpha10 版本

2021 年 1 月 13 日

發布了 androidx.compose.foundation:foundation:1.0.0-alpha10androidx.compose.foundation:foundation-layout:1.0.0-alpha101.0.0-alpha10 版包含此連結所列的修訂項目。

API 變更

  • ImeOptions 和 KeyboardOptions 不再是資料類別 (I3c898b/168684531)
  • VisualTransformation API 的異動
    • 已將 OffsetMap 重新命名為 OffsetMapping
    • 已將 OffsetMap.identityOffsetMap 重新命名為 OffsetMap.Identity
    • PasswordTransformation 不再是資料類別
    • 已將 OffsetMapping 移至其檔案。
    • (I0bdf3)
  • EditOperations API 變更
    • 已將 EditOperation 重新命名為 EditCommand
    • 為 EditOperation 具體實作的指令後置字串。
    • EditCommand 已不再是資料類別
    • 已將 EditOperation.process 函式重新命名為 applyTo
    • 已將 InputEventListener 重新命名為 InputEventCallback
    • (I0a366)
  • 已將 Velocity 修改成為具有元件部分和數學運算 (Ib0447)
  • @ExperimentalTesting 已重新命名為 @ExperimentalTestApi,與類似的實驗性 API 註解保持一致 (Ia4502b/171464963)
  • 已為 LazyColumn/LazyRow 新增實驗性的 stickyHeader 方法 (I0a81d)
  • Color.useOrElse() 已重新命名為 Color.takeOrElse() (Ifdcf5)
  • 已淘汰 TestUiDispatcher。請改用 Dispatchers.Main (Ic171fb/175385255)
  • 將 Toggle 新增至 Foundation 的 Strings.kt (I4a5b7b/172366489)
  • 將 nativeClass 移至 ui 模組並設為內部使用。已在同等的實作中更新 nativeClass 的使用情形,改為使用「is MyClass」。(I4f734)
  • 淘汰 FlowRow 和 FlowColumn。請改用自訂版面配置。(I09027)
  • Modifier.focus() 和 Modifier.focusRequester() 現已淘汰。請改用 Modifier.focusModifier() 和 Modifier.focusReference()。(I75a48b/175160751b/175160532b/175077829)
  • 推出 SelectionRegistrar.notifySelectableChange,向 SelectManager 通知 Selectable 更新 (I6ff30b/173215242)。
  • 已將 fun Dp.isFinite() 變更為 val Dp.isFinite (I50e00)
  • Constraints#satisfiedBy 已重新命名為 isSatisfiedBy。(I9cf5c)
  • 為含有 Unspecified 常數的內嵌類別新增了 isSpecified、isUnspecified 和 useOrElse。(I93f7bb/174310811)

修正錯誤

  • 新增以協同程式為主的 API Animatable,可確保動畫之間的互斥性。新增 DecayAnimationSpec,可支援多維度衰減動畫 (I820f2b/168014930)
  • 新增了對停用和唯讀文字欄位的支援 (I35279b/171040474b/166478534)
  • animate() 現已替換為 animateAsState(),後者會傳回 State<T> 而非 T。這樣系統會將無效範圍縮小至讀取 State 值的位置,因此可以提升效能 (Ib179e)。
  • 新增 Semantics 角色 API,並將 Role 新增為可點選、選取和切換的 SemanticsModifier 參數。Modifier.progressSemantics 已變更,讓 Slider 也能夠使用 (I216cd)
  • 現在原生 keyEvent 能透過 keyEvent.nativeKeyEvent 加以存取 (I87c57b/173086397)

1.0.0-alpha09 版本

2020 年 12 月 16 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha09androidx.compose.foundation:foundation-layout:1.0.0-alpha091.0.0-alpha09 版包含此連結所列的修訂項目。

API 變更

  • 新增可捲動的介面

    這可讓 ScrollState 和 LazyListState 視同共通類型,如此一來即可在這兩種類型之間實作自訂捲動功能。

    這也會將 smoothScrollBy 移至 Scrollable 上的擴充功能函式,以利用此功能性。(I2153b)

  • 新增 LazyVerticalGrid (I17267b/162213211)

  • 淘汰 LazyColumnFor、LazyRowFor、LazyColumnForIndexed 和 LazyRowForIndexed。請改用 LazyColumn 和 LazyRow (I5b48c)

  • 如要暫停游標指標輸入 API,請將 RiverPointerInputScope 重新命名為 AwaitPointerEventScope,並將 HandlePointerInput() 重新命名為 awaitPointerEventScope() (Idf0a1b/175142755)

  • 已新增 LazyListState.layoutInfo,可列出目前顯示項目的尺寸和偏移清單 (If8678b/170472532)

  • 已移除 ExperimentPointerInput 註解 (Ia7a24)

  • 已為 TextFields 新增 InteractionState 的支援。(I61d91)

  • 新增 LazyColumn/Row 的 reverseLayout 參數。參數為 true 時,代表項目是由下往上組合,LazyListState.firstVisibleItemIndex == 0 則表示第一個項目位於底部 (I552aeb/166589935)。

  • 已為 LazyColumn 新增 verticalArrangement 參數。已為 LazyRow 新增 horizontalArrangement 參數。如果沒有足夠的項目可填滿最小尺寸時,即可利用 Arrangement 在項目之間加入間距,以及指定項目的排列方式。(Icf79ab/170394300)

  • detectMultitouchGestures 現在起使用一個回呼,並搭配合併的 centroid、pan、zoom 及 rotate 參數。(Ie6e1c)

  • 已將 ContentDrawScope 移至 ui-graphics 模組,以便與 DrawScope 搭配使用。(Iee043b/173832789)

修正錯誤

  • 現在,偏移修飾符中的 lambda 會傳回 IntOffset,而非 Float (Ic9ee5b/174137212b/174146755)。
  • 已從公用 API 中移除 SlotTable、SlotReader 和 SlotWriter。這些項目先前被標示為 InternalInternalAPI。現在是撰寫模組的內部。

    為了取代 ui-tooling API 而新增 CompositionData 和 CompositionGroup,用於擷取組合資訊。這些是公開工具,但不適合在 ui-tooling API 外使用,因為這些工具會提供 ui-tooling API 解讀的原始資訊 (I31a9c)

  • 提供繪圖環境大小資訊時,重構 ShaderBrush 以延遲建立著色器的執行個體。這適合用於定義在組合時構成可組合項完整繪圖邊界的漸層,而不必實作自訂的 DrawModifier 實作方式。

    已淘汰漸層函式建構函式 API,並採用 Gradient 物件的工廠方法 (I511fcb/173066799)

  • 已淘汰 Modifier.focusObserver。請改用 Modifier.onFocusChanged 或 Modifier.onFocusEvent (I30f17b/168511863b/168511484)

  • AutoFill API 現為實驗性 API,必須啟用 (I0a1ec)

  • 新增解構宣告,可建立 FocusRequester 例項 (I35d84b/174817008)。

  • 已分別將 accessibilityLabel 和 accessibilityValue 重新命名為 contentDescription 和 stateDescription。(I250f2)

  • 引入 SelectionRegistrar 的數種新函式,並將 onPositionChange 重新命名為 notifyPositionChange (Ifbaf7)

  • 已將 AndroidOwner 歸為內部 (Ibcad0b/170296980)

  • 新建 infiniteRepeatable 函式,可用於建立 InfiniteRepeatableSpec (I668e5)

  • Applier 介面經過變更,將樹狀結構建構程序從由上往下簡化為由下往上。

    insert() 方法已重新命名為 insertTopDown()

    加入新的方法 insertBottomUp()

    套用器會根據效能表現選用 insertTopDown()insertBottomUp(),將節點插入目前編輯的樹狀結構。

    對某些樹狀結構 (例如 LayoutNodeView) 而言,由下往上的建構方式會比由上往下更有效率。在這項變更之前,如要實作由下而上建構作業,您需要先插入一些堆疊,並必須將其複製到每個需進行由下而上效能建構作業的套用器。這項變更實施後,Applier 會覆寫 insertBottomUp() 以由下往上建構樹狀結構,而覆寫 insertTopDown() 則會由上往下建構樹狀結構。(Icbdc2)

  • 新增了 painterResource API 以從光柵化素材格式 (例如 PNG) 或 VectorDrawable 處理不透明地載入 Painter 物件。取用者不必再事先判斷資產類型,並可呼叫此方法,取得用於 Image 可組合項或 Painter 修飾符的 Painter 物件 (I2c703b/173818471)。

  • 新增 buildAnnotatedString 工廠函式,可供建構 AnnotatedString。淘汰了 annotatedString 建構工具函式。(Idfe0b)。

1.0.0-alpha08 版本

2020 年 12 月 2 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha08androidx.compose.foundation:foundation-layout:1.0.0-alpha081.0.0-alpha08 版包含此連結所列的修訂項目。

API 變更

  • 已從 CoreTextField 中移除 maxLines 參數。如果您要依照行數限制文字欄位的高度,請改用 BasicTextField (Iec002)
  • 已將 await*TouchSlop() 方法變更為不偵測指標向下,並且重新命名為 *OrCancellation。同時也不再需要使用 orientationLock 參數。(Ie96e1)
  • 新增了可組合 lambda 參數在於命名和位置的 lint 檢查,以檢查是否與 Compose 準則一致。另外也根據 Lint 檢查和指引,將部分使用 children 做為結尾 lambda 名稱的 API 遷移至 content (Iec48e)
  • 已將 foundation:foundation-text API 移至 foundation:foundation 套件結構維持不變 (Id3eb2)
  • 新增多點觸控手勢偵測工具,包括偵測旋轉、縮放和平移的協助程式。(Ic459d)
  • 新增拖曳手勢偵測工具的暫停指標輸入 API,包括方向鎖定在內。(Icef25)
  • 已將 VectorAsset 重新命名為 ImageVector。根據 API 委員會準則,已將 VectorAsset 移動至 Builder 並對其重新命名,使其成為 ImageVector 的內部類別。新增了 VectorAssetBuilder 的 typealias,以便連結至 ImageVector.Builder,使其彼此相容。(Icfdc8)
  • 已將 ImageAsset 和相關方法重新命名為 ImageBitmap。(Ia2d99)
  • 已將 Foundation 語意屬性移至 ui (I6f05c)
  • 新增協同程式為主的捲動 API:

    新增 LazyListState.snapToItem 和 LazyListState.smoothScrollBy,以及較低階的 API 捲動控制 API。這些 API 會提供可控制捲動操作的暫停介面,這個介面會等到捲動操作完成後再傳回。(Ie5642)

  • 已將 singeLine 參數新增至 BasicTextField、TextField 和 OutdashTextField。如要將文字欄位設為可水平捲動的單一行,請將這個參數設為 true (I57004b/168187755)。

  • 使用新的暫停指標輸入,新增了輕觸、輕觸兩下、長按和輕按指示的手勢偵測工具。我們還新增了一些公用程式,讓開發人員更容易編寫自己的手勢偵測工具。(I00807)

  • Modifier.focusable 有需要新增至 Foundation。這項工具可讓您為元件新增可聚焦的行為,並採用正確的語意和無障礙功能 (I41eb9b/152525426b/162865824)

  • 先前淘汰的 API 已移除:Border 已移除,請改用 BorderStroke。已移除 Modifier.drawBorder,請改用 Modifier.border。已移除 Modifier.gravity,請改用 Modifier.align。已移除 Stack,請改用 Box (I32c2bb/172470874)

  • AbsoluteArrangement 已重新命名為 Arrangement.Absolute。(If26f2)

修正錯誤

  • 已將 DrawModifier API 從 androidx.compose.ui 套件移至 androidx.compose.ui.draw 套件。已建立 DrawModifierDeprecated.kt 檔案,藉此加入 typealiases/helper 方法,協助從淘汰的 API 改用目前的 API (Id6044b/173834241)。
  • 已將 Modifier.drawLayer 重新命名為 Modifier.graphicsLayer,同時也根據 API 委員會的意見回饋,將相關類別更新為 GraphicsLayer。(I0bd29b/173834241)
  • 已從 SubcomposeLayout 宣告中移除 <T>,現在不必指定類型即可使用該項目 (Ib60c8)
  • 將 PointerInputData 的運作時間和位置欄位設定成不可為空值。(Id468a)
  • MaterialTheme 現可為選取控點和選取背景設定正確的顏色。非 Material 應用程式可以手動使用 AmbientTextSelectionColors 自訂用於選取項目的顏色 (I1e6f4b/139320372b/139320907)
  • Box 的對齊參數已重新命名為 contentAlignment。(I2c957)
  • offsetPx 修飾符已重新命名為 offset,且現已改用 lambda 參數,而非 State (Ic3021b/173594846)
  • 新增了 WindowManager.isWindowFocused 以檢查主機視窗是否為焦點,並新增提供 onWindowFocusChanged 回呼的 WindowFocusObserver。(I53b2ab/170932874)
  • 已將 resetInput 參數新增至 TextInputService#onStateUpdated (I3e8f5b/172239032b/171860947)
  • 已更新 TextFieldValue API
    • 將 TextFieldValue 組合設為唯讀
    • 已移除因無效選取範圍所擲回的例外狀況 (I4a675b/172239032)
  • 依照其他 Ambient 和 Compose API 準則,淘汰以 Ambient 作為字尾所命名的 Ambient,並改為以 Ambient 作為字首的新屬性。(I33440)
  • 新增了 Android Typeface 包裝函式。您可以透過 typeface 函式 (例如 typeface(Typeface.DEFAULT)) 載入 Android 字體。並將 typefaceFromFontFamily() 重新命名為 typeface() (I52ab7)
  • 新增了 lint 檢查功能,以檢查 Modifier 工廠是否在內部使用 androidx.compose.ui.composed {},而非標示為 @Composable。(I3c4bc)
  • 新增 Lint 檢查,方便檢驗修飾符工廠函式是否依其擴充功能定義,確保兩者能順利鏈結。(I07981)
  • 語意引數 mergeAllDescendant 已重新命名為 mergeDescendant。(Ib6250)
  • 測試中的時間控制項 (TestAnimationClock 及其用例) 處於實驗階段 (I6ef86b/171378521)
  • 移除舊的 ui-test 模組及其虛設常式 (I3a7cb)
  • TextUnit.Inherit 重新命名為 TextUnit.Unspecified,以與其他單元一致。(Ifce19)
  • 更新了 Alignment 介面,並使其可正常運作。(I46a07b/172311734)
  • 已將 foundation:foundation-text 模組合併為 foundation:foundation (Idac0f)
  • 淘汰 place(Offset) 和 placeRelative(Offset)。請改用含有 int 偏移的超載 (I4c5e7)
  • id 已重新命名為 LayoutIdParentDatalayoutIdMeasurable.id 已重新命名為 Measurable.layoutId (Iadbcbb/172449643)

1.0.0-alpha07 版

2020 年 11 月 11 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha07androidx.compose.foundation:foundation-layout:1.0.0-alpha07androidx.compose.foundation:foundation-text:1.0.0-alpha07查看 1.0.0-alpha07 版的修訂項

API 變更

  • 比照 Modifier.fillMaxSize[Width|Height],我們現在支援在 LazyColumn/Row 範圍內的 Modifier.fillParentMaxSize[Width|Height] 中使用分數 (I797e2b/166586426)
  • 已從公用 API 中移除 KeyboardOptions.toImeOptions。(Ic2e45)
  • 淘汰 Foundation 的 AmbientTextStyle、ProvideTextStyle 和 AmbientContentColor。請改用 Material 程式庫中可提供的新版本。對於非 Material 應用程式,您應建立自己的設計系統專屬主題設定環境,並在自己的元件中使用 (I74accb/172067770)
  • 已淘汰 foundation.Text,並替換為 material.Text。如要瞭解不使用主題值的無預設立場基本文字 API,請參閱 androidx.compose.foundation.BasicText (If64cb)
  • 已將 maxLine 新增至 TextField (Ib2a5b)
  • 更新 TextField 以接受 KeyboardOption (Ida7f3)
  • 新增了於 TextField 中使用的 KeyboardOption (I9ca32)
  • 新增 BasicText。這是一個在設計方面不預設立場的文字 API,與 BasicTextField 平行。(I28268)
  • 移除了 ExperimentalLazyDsl 註解。現在不必新增 @OptIn 即可使用 LazyColumn/LazyRow (Idab7ab/166584730)
  • 已淘汰 BaseTextField。請改用 BasicTextField。(I896eb)
  • BasicTextField 已新增為 CoreTextField 與 BaseTextField 的替代項目 (Id4cea)
  • 移除已淘汰的 LazyColumnItems/LazyRowItems (I1d8a8)
  • 已移除依照內建函式的測量值調整大小的已淘汰可組合項。(I18537b/171811496)
  • relativePaddingFrom 已重新命名為 paddingFrom。新增 paddingFromBaseline 修飾符,方便您指定版面配置邊界到文字基準線的距離 (I0440ab/170633813)
  • 在 aspectRatio 修飾符中新增 matchHeightConstraintsFirst 參數,可用於指定讓修飾符先依高度限制調整尺寸,再試著調整相應寬度。(Ie7c43b/155290593)
  • 已移除淘汰的 DpConstraint。(I87884b/171702471)

修正錯誤

  • 已引入 ScaleFactor 內嵌類別以表示水平與垂直軸相互獨立的縮放比例係數,以支援縮放比例不統一的用途。
    • 已將 ComputeScaleFactor 方法新增至 ContentScale
    • 新增了 ContentScale.FillBounds 以執行非統一的資源調度,藉此將 srcs 邊界延伸至完全符合目的地。
    • 新增了運算子方法,以便使用大小參數計算 ScaleFactor 參數。
    • (Ic96a6b/172291582)
  • captureToBitmap 已移至 captureToImage。(I86385)
  • 將 CoreText 標示為 @InternalTextApi。請改用 BasicText (I6aaeb)。
  • 將 KeyboardOptions 重新命名為 ImeOptions (I82f36)
  • 已將 KeyboardType 和 ImeAction 移入 KeyboardOptions (I910ce)
  • CoreTextField 已標示為 @InternalTextApi。請改用 BasicTextField (Ie2469)
  • 已移除 ExperimentalSubcomposeLayoutApi 註解。現在可以在不新增 @OptIn 的情況下使用 SubcomposeLayout (I708ad)
  • 推出 ui-test-junit4 模組 (Ib91f8)
  • 已更新 Icon API 以採用 Color.Unspecified 做為可能的色調顏色,可在沒有 ColorFilter 的情況下繪製指定素材或繪圖工具。先前嘗試略過繪製含有 Color.Unspecified 的色調,導致系統使用透明色繪製色調,結果完全沒有顯示任何色彩。(I049e2b/171624632)
  • 已將 MeasureResult 從 MeasureScope 移出 (Ibf96db/171184002)
  • 將數個版面配置相關符號從 androidx.compose.ui 移至 androidx.compose.layout.ui (I0fa98b/170475424)
  • 已將 androidx.ui.test 移至 androidx.compose.ui.test (I9ffdb)
  • 已將 FirstBaseline 和 LastBaseline 移至 androidx.compose.ui.layout 套件 (Ied2e7)
  • 新增不使用回呼的 SelectionContainer (Ibfadb)
  • 在 SelectionContainer 中為 SelectionHandle 的 Position 新增 Test。(Ie93db)
  • 新增了鍵盤自動更正輸入法編輯器選項 (I57b8d)

1.0.0-alpha06 版本

2020 年 10 月 28 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha06androidx.compose.foundation:foundation-layout:1.0.0-alpha06androidx.compose.foundation:foundation-text:1.0.0-alpha06查看 1.0.0-alpha06 版的修訂項

API 變更

  • androidx.compose.foundation.Icon 已移至 androidx.compose.material.Icon。如果不想使用 Material 程式庫,也可以將 Image 元件/Modifier.paint() 與 Painter 搭配使用 (I9f622)
  • 已將 engagementState 新增至 Modifier.scrollable、ScrollableColumn 和 LazyColumnFor (I81566b/169509805)
  • alignByBaseline 已新增至 RowScope,alignWithSiblings 重新命名為 alignBy (I06503b/170628732)
  • 將 Box 實作為內嵌函式。(Ibce0cb/155056091)
  • 已將 maxLines 新增至 CoreTextField (Ibee58b/143687793)
  • 已將 softwrap 新增至 CoreTextField。(I21a4b)

修正錯誤

  • 淘汰 VectorPainter 並改用 rememberVectorPainter,以更能指出可組合項 API 於內部利用「記憶」使得資料在撰寫之間持續存在。(Ifda43)
  • 在 ComposeTestRule 中啟用轉場功能,並從 ComposeTestRule 中移除啟用閃爍游標的選項。(If0de3)
  • 已對 CoreTextField 新增單行鍵盤選項 (I72e6d)
  • 已將 Radius API 重新命名為 CornerRadius,以便完善表達於 Compose 中的使用方式。更新說明文件,指出負圓角半徑的限制取值範圍已設為零 (I130c7b/168762961)
  • 新增在經組合的輔助鍵之中指定檢查器相關資訊的功能 (Idee08b/163494569)
  • 新增了 KeyboardCapitalization 輸入法編輯器選項 (I8ac38)
  • 修正 Rtl 控點位置。(I6e1e0)
  • 破壞性變更:由於指標事件中能夠變更的值應該只有取用資料,因此將 PointerInputFilter.onPointerEvent(...) 的傳回值移除。現在您不必從 PointerInputFilter.onPointerEvent(...) 傳回資料,可直接改變 PointerEvents 傳入的取用資料。(I6acd0)
  • 將 SelectAll 選項新增至選單 (Ief02b)

1.0.0-alpha05 版本

2020 年 10 月 14 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha05androidx.compose.foundation:foundation-layout:1.0.0-alpha05androidx.compose.foundation:foundation-text:1.0.0-alpha05查看 1.0.0-alpha05 版的修訂項

API 變更

  • CoreTextField 現已支援游標功能 (Id23aa)
  • 已淘汰 contentColor() 和 currentTextStyle() API 並分別改為 AmbientContentColor 和 AmbientTextStyle 環境。與搭配使用其他環境時一樣,您可以對環境屬性使用 .current,藉此存取目前的值。這項變更的用意是要維持一致性,避免採用多種方式來完成同一件事。此外,部分環境屬性已重新命名,以便清楚描述其用途,如下所示:

    • ContentColorAmbient -> AmbientContentColor
    • TextStyleAmbient -> AmbientTextStyle
    • IndicationAmbient -> AmbientIndication
    • EmphasisAmbient -> AmbientEmphasisLevels
    • RippleThemeAmbient -> AmbientRippleTheme (I37b6d)

修正錯誤

  • 為將內嵌類別 sentinel 值標準化的一部分,將 Color.Unset 重新命名為 Color.Unspecified,使其與其他內嵌類別一致 (I97611b/169797763)
  • 新增了 Copy/Paste/Cut 等無障礙功能操作 (I6db4f)
  • 引入 TextOverflow.None。溢位為 None 時,Text 不會再處理溢位,而是向 LayoutNode 回報實際尺寸 (I175c9b/158830170)
  • 將 size.Unspecified 的參數更新為 Float.NaN,而非 Float.POSITIVE_INFINITY。更新了 Painter 實作方式,以檢查 Size.Unspecified 和非有限大小 (I95a7e)
  • 新增了 Paging Compose 模組和分頁整合 (Ib85da)
  • 請修改 LazyListScope 以接收可為空的值 (I1765b)
  • OnPositionedModifier 已重新命名為 OnGloballyPositionedModifier,onPositioned() 重新命名為 onGloballyPositioned()。(I587e8b/169083903)
  • 新增了 LazyColumn/Row 的範例 (Idc16d)
  • 修正項目和 itemsIndexed 方法,以允許使用 emptyList (I06647)
  • 新增指定檢查器資訊的 DSL (Ic9a22)
  • 將 LongPress 移到文字中。(Iff2bc)
  • 停用 Text 中的 Selection 和 Demo。(Ie7e97)
  • 支援無障礙功能的 AnnotatedString 轉換至 SpannableString (Ief907)
  • 移除了 PointerInputFilter.onPointerInput(...)。並應改用 PointerInputFilter.onPointerEvent(...)。(I6f04a)

1.0.0-alpha04 版本

2020 年 10 月 1 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha04androidx.compose.foundation:foundation-layout:1.0.0-alpha04androidx.compose.foundation:foundation-text:1.0.0-alpha041.0.0-alpha04 版包含以下修訂項目。

API 變更

  • Stack 已重新命名為 Box。原先存在的 foundation.Box 會淘汰,改用 compose.foundation.layout 中的新版 Box。Box 的新行為模式為當其擁有多個子項時,會將子項一個一個向上堆疊,這一點與之前的 Box 不同,之前的行為與 Column 較為類似 (I94893b/167680279)。
  • 淘汰了 Box 裝飾參數。如果要為您的方框加上裝飾/邊框間距,請改用 Modifier (Modifier.background、Modifier.border、Modifier.padding) (Ibae92b/167680279)
  • 新增 LazyListState 類別。可用以觀察及控制 LazyRow 和 LazyColumn 元件的捲動位置。您可以使用 rememberLazyListState() 建立執行個體,並傳遞到元件的狀態參數。目前,可在此初始版本中觀察第一個顯示的項目和偏移。(Ic7cb7b/159307669)
  • 現在起,Lazy 清單的位置和捲動偏移可在 Activity 重新建立的全程當中儲存和還原 (Ie045fb/166589058)
  • 新增長按語意語意操作 (I6281bb/156468846)
  • 已新增 MutatorMutex 公用程式,用來長時間維持一個共用狀態的更動子,並且依照優先順序取消衝突的更動子 (I3f975)
  • 已使用 @VisibleForTesting 為 rootAnimationClockFactory、transitionsEnabled、blinkingCursorEnabled 和 textInputServiceFactory 加上註解,使其成為內部 API,並隱藏其 kdoc (I554ebb/168308412)
  • 已從有 String 輸入的 Text 移除 inlineContent 參數。由於 inlineContent 必須搭配 AnnotatedString,因此不會用到。(Ief403)
  • 已移除淘汰的自訂 Arrangement API (Ic576db/168297922b/168297923)
  • unbounded 參數新增至 wrapContentSize 修飾符,後者能夠測量最大限制為無限的版面配置元素。(I77951b/158559319)
  • 我們已阻止靜態匯入版面配置範圍的內容 (例如 RowScopes 中的 alignWithSiblings)請改用明確範圍替代項:with(RowScope) { Modifier.alignWithSiblings(FirstBaseline) } (I216beb/166760797)。

修正錯誤

  • 更新了多個圖形 API
    • 更新縮放和旋轉功能的轉換 API,改用單一 Offset 參數代表樞紐座標,而非使用 DrawScope 和 DrawTransform 中 x/y 座標的個別浮點參數
    • 移除了 Rect.expandToInclude 和 Rect.join 方法
    • 更新 Radius 說明文件,一併介紹橢圓形和卵形
    • 新增說明文件,指出無須直接呼叫內嵌 Radius 類別的公開建構函式,而是應該透過函式建構函式將 Radius 物件例項化
    • 移除了用於查詢 topRight、bottomRight、bottomCenter 等的 roundRect API
    • 淘汰了 Rect.shift,改用 Rect.translate
    • 移除了 RoundRect.grow 和 Rect.shrink API
    • RoundRect.outerRect 已重新命名為 Rect.boundingRect
    • 移除了 RoundRect.middleRect/tallMiddleRect/wideMiddleRect 和 Rect.isStadium 方法
    • 已將 RoundRect.longestSide 重新命名為 RoundRect.maxDimension
    • 已將 RoundRect.shortestSide 重新命名為 RoundRect.minDimension
    • 已將 RoundRect.center 變更為屬性,而非函式
    • 將 RoundRect 建構函式更新為使用 Radius 屬性,而非 x/y 半徑值的個別參數
    • 移除了 Size API,假設其為原點 0,0 的矩形
    • 在 Radius 中新增銷毀 API
    • 將各種 RoundRect 擴充功能函式移轉為屬性
    • (I8f5c7b/168762961)
  • 藉由不在每次捲動時皆執行不必要的重整,達到 LazyColumnFor/LazyRowFor 捲動的效能最佳化 (I64f65b/168293643b/167972292b/165028371)
  • 已修正捲動後 LazyColumnFor/LazyRowFor 的異常終止,接著變更項目並且實作先前顯示的項目移除之後的自動向上捲動,使得再也不會在末端顯示空白間隙 (I220abb/161480164b/167855468)
  • 不再允許在同方向的容器 (例如 ScrollableContainer 和 LazyColumnFor) 中嵌套可捲動項目。未曾支援此做法之外,也會破壞組合 LazyColumnFor 項目時的快速滑過和所有延遲 (I6e101)
  • 更新多個圖形 API
    • 更新了具有限定範圍轉換方法的 DrawScope API,指出轉換作業僅適用於回呼內部,在叫用回呼後就會移除
    • 已將 clipPath 說明文件更新為參照路徑,而不是圓角矩形
    • 已固定說明文件在 clipPath 中正確的參數
    • 已將 DrawScope.drawCanvas 重新命名為 DrawIntoCanvas 和已移除的大小參數
    • 將 inset 方法中的 dx/dy 參數重命名為水平和垂直
    • 新增插邊超載,為 4 個邊界全都提供相同的插邊值
    • 移除了 inset 方法的說明文件,指出插邊將會套用至所有 4 邊
    • 更新了 Rect 類別的說明文件
    • 更新了關於 Rect 參數的評論以符合 kdoc 樣式
    • 移除了 Rect.join 和 Rect.expandToInclude
    • 已為 Rect.translate(offset) 和已淘汰的 Rect.shift 建立超載。
    • (If086ab/167737376)
  • 將 AccessibilityScrollState 新增至語意屬性 (Ifeda9)
  • 將 TextRange 設為內嵌,以避免建立物件 (Id034b)
  • 已移除 ParagraphConstraint。寬度現在會直接傳遞至 Paragraph (Ica712)

1.0.0-alpha03 版本

2020 年 9 月 16 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha03androidx.compose.foundation:foundation-layout:1.0.0-alpha03androidx.compose.foundation:foundation-text:1.0.0-alpha03查看 1.0.0-alpha03 版的修訂項

API 變更

  • InnerPadding 已重新命名為 PaddingValues (I195f1b/167389171)
  • 版面配置 API 中用到 gravity 的部分已統一改成 align 或 alignment (I2421ab/164077038)
  • 已在 Stack 上新增對齊參數,以便可指定所有 Stack 子項的預設對齊方式 (Ie80cab/164085265)

修正錯誤

  • 已淘汰 DpConstraint 和使用該項目的 API (I90cdbb/167389835)
  • widthInminWidthmaxWidth 參數已重新命名為 minmaxpreferredWidthInheightInpreferredHeightIn 也比照完成同樣的處理。(I0e5e1b/167389544)
  • 已在 ComposeTestRule 中加入 onNode 和其他全域方法,因為目前的全域方法即將淘汰。(Ieae36)
  • 已修正 GestureScope 的尺寸和位置的計算方式,以免造成滑動手勢無效等其他問題 (Iaf358b/166589947)
  • 已將 createAndroidComposeRuleAndroidInputDispatcherandroidx.ui.test.android 移至 androidx.ui.test (Idef08b/164060572)

1.0.0-alpha02 版

2020 年 9 月 2 日

發布了 androidx.compose.foundation:foundation:1.0.0-alpha02androidx.compose.foundation:foundation-layout:1.0.0-alpha02androidx.compose.foundation:foundation-text:1.0.0-alpha021.0.0-alpha02 版本包含以下修訂項目。

修正錯誤

  • TestUiDispatcher 標示為實驗性 (Iae99db/161247083)
  • 新增了 ManualFrameClock.hasAwaiters 以查看是否有任何內容正在等待該時鐘的框架;新增 runWithManualClock 用來在執行需要 ManualFrameClock 的測試時取代 runBlocking;並新增 TestUiDispatcher.Main,供您輕鬆存取測試中的主要 UI 發送器。

    例如:

    @Test
    fun myTest() = runWithManualClock { clock ->
        // set some compose content
        withContext(TestUiDispatcher.Main) {
            clock.advanceClock(1000L)
        }
        if (clock.hasAwaiters) {
            println("The clock has awaiters")
        } else {
            println("The clock has no more awaiters")
        }
    }
    

    (I0a85bb/161247083)

1.0.0-alpha01 版

2020 年 8 月 26 日

發布 androidx.compose.foundation:foundation:1.0.0-alpha01androidx.compose.foundation:foundation-layout:1.0.0-alpha01androidx.compose.foundation:foundation-text:1.0.0-alpha011.0.0-alpha01 版本包含以下修訂項目。

0.1.0-dev 版

0.1.0-dev17 版

2020 年 8 月 19 日

發布了 androidx.compose.foundation:foundation:0.1.0-dev17androidx.compose.foundation:foundation-layout:0.1.0-dev17androidx.compose.foundation:foundation-text:0.1.0-dev17查看 0.1.0-dev17 版的修訂項

API 變更

  • 新增 Row 和 Column 的 spacedBy Arrangement,使版面配置子項能依固定間距定位;另也新增 aligned Arrangment,使 Row/Column 中的版面配置子項可根據 Alignment 方法彼此對齊放置。淘汰之前的 Arrangement.Vertical#arrange 和 Arrangement.Horizontal#arrange 方法,未來也將停止支援編寫自訂的 Arrangement。(I6733db/161985975)
  • 將 Offset 改為內嵌類別 (Iaec70)
  • 已從 TextField 移除 onFocusChanged 回呼。請改用 Modifier.focusObserver。(I51089b/161297615)
  • 已淘汰 Modifier.drawBorder。請改用 Modifier.border。Borde 資料類別已由 BorderStroke 取代 (I4257db/158160576)
  • 移除了 VerticalScroller 和 HorizontalScroller。請改用捲動式資料欄/資料列。已移除 Modifier.drawBackground。請使用 Modifier.background (I73b0db/163019183)
  • 自 LazyItemScope 移除標示為淘汰的 fillMax* 修飾符,因為對於非 LazyColumnFor 直接子項的項目而言,其增加了正確新增這些修飾符的難度 (Ifa78d)
  • 已將 LazyColumn/LazyRow 實作新增為 DSL (I93cc6)
  • 現已將 Constraint 設為內嵌類別 (I88736)
  • 利用 fillMaxWidth、fillMaxHeight 和 fillMaxSize 輔助鍵,新增將版面配置的大小設定為可用空間的一部分的功能。(I945bbb/161562591)

修正錯誤

  • 已將 modifier 參數加入至 SelectionContainer (I4aadab/161487952)
  • 已將 mergePolicy lambda 加入至 SemanticsPropertyKey。這可讓您定義 mergeAllDescendants 語意合併的自訂政策。根據預設政策,如果有父項值,就會直接使用父項值;如果沒有,則使用子項值 (Iaf6c4b/161979921)
  • 已將 PlacementScope.placeAbsolute() 重新命名為 PlacementScope.place(),原先的 PlacementScope.place() 則重新命名為 PlacementScope.placeRelative()。因此,PlacementScope.place() 方法不再以由右至左的結構定義自動鏡射位置。如果需要這個方法,請改用 PlacementScope.placeRelative()。(I873acb/162916675)
  • 移除淘汰的 FilledTextField 元件。請改用 TextField,取得 Filled 文字欄位的 Material Design 實作方式 (I5e889)
  • 已將 backgroundColor 參數加入至 LinearProgressIndicator,並從 CircularProgressIndicator 移除內部邊框間距。新增 ProgressIndicatorConstants.DefaultProgressAnimationSpec,可在各值之間以動畫表示進度時,做為預設的 AnimationSpec (If38b5b/161809914b/161804677)
  • state { ... } 可組合項現已淘汰,改為明確呼叫 remember { mutableStateOf(...) } 以求一目瞭然。這樣可以減少管理狀態所需的整體 API 介面和概念數量,且符合類別屬性委派作業的 by mutableStateOf() 模式。(Ia5727)
  • 將 RRect 重新命名為 RoundRect,以更符合 Compose 命名模式 建立了與 RRect 類似的函式建構函式,並淘汰了 RRect 函式建構函式 (I5d325)
  • 已移除 onChildPositioned 和 OnChildPositionedModifier。開發人員應改在子版面配置上使用 onPositioned 和 OnPositionedModifier。(I4522eb/162109766)
  • 已將 IntSize 設為內嵌類別 (I2bf42)
  • 長按空白區即可編輯。(Ib1e5b)
  • 隱藏輕觸文字後的 FloatingToolbar。(If4525)
  • 隱藏更新選取項目時的 FloatingToolbar。(I8444c)
  • Blur 時取消選取。(I781a2)

0.1.0-dev16 版本

2020 年 8 月 5 日

發布 androidx.compose.foundation:foundation:0.1.0-dev16androidx.compose.foundation:foundation-layout:0.1.0-dev16androidx.compose.foundation:foundation-text:0.1.0-dev16查看 0.1.0-dev16 版的修訂項

API 變更

  • 已為 Lazy 清單的 itemContent 參數新增 LazyItemScope。這可提供修飾符來填滿父項大小上限,解決以下用途問題:項目應填滿可視區域,但因該項目的測量限制為無限,導致一般 Modifier.fillMaxSize() 無法運作 (Ibd3b2b/162248854)。
  • 將對話方塊移至使用者介面 (I47fa6)
  • 新增了 LazyColumnForIndexed/LazyRowForIndexed 此 LazyColumnFor/LazyRowFor 版本,可提供 itemCallback 中的 index 與 item。如果除了現有項目還需瞭解目前的索引,這一點十分實用。(I65ff3)
  • 已將 Modifier.deternimateProgress 重新命名為 Modifier.progressSemantics (I9c0b4)
  • 已將 LazyColumnItem 重新命名為 LazyColumnFor。已將 LazyRowItem 重新命名為 LazyRowFor (I84f84)
  • 新增一些標記/註解,以達到最佳做法 (I66b20)
  • foundation.shape.corner 套件已扁平化為 foundation.share (I46491b/161887429)
  • 新增了 LazyRowItems/LazyColumnItems 的跨軸重力參數。LazyRowItems/LazyColumnItems 現在起可支援納入內容的行為模式。(Ib39fc)
  • 已將 ZoomableState 重新命名為 ZoomableController。現已加入對 smoothScale 的自訂曲線支援。新增了 enabledonZoomStarted 功能 (If8b8f)
  • 已將 Material FilledTextField 重新命名為 TextField,並將基礎的 TextField 重新命名為 BaseTextField,以便於發現及使用最簡單的所需 API (Ia6242b/155482676)
  • 已移除先前淘汰的 AdapterList。請改用 LazyColumnItems (I12b9b)
  • 將 Modifier.drawBackground 重新命名為 Modifier.background (I13677)
  • 已移除舊的 ConstraintLayout DSL。已將 ConstraintSet2 重新命名為 ConstraintSet (If58d1b/162450908)
  • 新增了 Modifier.corOffset() 和 Modifier.absoluteOffsetPx()。絕對偏移輔助鍵與偏移輔助鍵不同,不會在由右至左的結構定義中自動鏡射 (I3aa21)
  • RowColumn 現為內嵌函式,可大幅降低使用這些項目的負荷。(I75c10)

修正錯誤

  • 解決廣泛的 API 問題 (I077bc)
    1. 移除未使用的 OffsetBase 介面
    2. 對齊 Offset 和 IntOffset 類別,以便採用一致的 API 介面
    3. 將 IntOffset.Origin 重新命名為 IntOffset.Zero,使其與 Offset API 一致
    4. 已將 nativeCanvas 方法從 Canvas 介面移出,以支援取用端建立自己的 Canvas 執行個體
    5. 建立了虛設常式 EmptyCanvas 類別,藉此將 DrawScope 重構為非空值參數 (而不是 lateinit),並確保該欄位不可為空值
    6. 已將 ClipOp 列舉重新命名為 Pascal 案件
    7. 已將 FilterQuality 列舉重新命名為 Pascal 案件
    8. 已將 StrokeJOIN 列舉重新命名為 Pascal 案件
    9. 已將 PointMode 列舉重新命名為 Pascal 案件
    10. 已將 PaintingStyle 列舉重新命名為 Pascal 案件
    11. 已將 PathFillType 列舉重新命名為 Pascal 案件
    12. 已將 StrokeCap 列舉重新命名為 Pascal 案件
    13. 更新 DrawCache 實作方式,不再使用 lateinit 參數
    14. 更新 DrawScope,不再讓 fillPaint 和 strokePaint 內部參數使用延遲委派功能
    15. 更新 Image 可組合項,避免使用 Box 並降低負擔
    16. 將 Outline 類別更新為包含 @Immutable 註解
    17. 將 PathNode 更新為包含各個路徑指示的 @Immutable 註解
    18. 由於撰寫作業已經完成,更新向量分子,移除等式的多餘性檢查
    19. 淘汰 Rect 隨附建構函式方法,改用函式建構函式
    20. 已使用 @Immutable 和 @Stable API 更新 Brush 類別和函式建構函式
    21. 已將 VertexMode 列舉更新為 PascalCase
    22. 更新 DrawScope selectPaint 方法,有條件地覆寫 Paint 的筆劃參數 (如果這些項目有所變更)
    23. 已更新 Size 以新增解構 API、將 UnspecifiedSize 重新命名為 Unspecified,並移除不使用的方法
  • 新增了 MonotonicFrameAnimationClock,可用來將 MonotonicFrameClock 作為 AnimationClockObservable,可消除以協同程式為主的新版時鐘與仍使用回呼型舊版時鐘的 API 之間的差異。

    MonotonicFrameClock 等同於 ManualAnimationClock,現在為 ManualFrameClock。(I111c7b/161247083)

  • 移除了 SemanticsNodeInteraction.performPartialGesture。請改用 SemanticsNodeInteraction.performGesture (Id9b62)

  • 已將 SemanticsNodeInteraction.getBoundsInRoot() 重新命名為 SemanticsNodeInteraction.getUnclippedBoundsInRoot() (Icafdfb/161336532)

  • 更新了支援版面配置由右至左的 API。新增了 LayoutDirectionAmbient,可用於讀取及變更版面配置方向。移除了 Modifier.rtl 和 Modifier.ltr。(I080b3)。

  • 淘汰 Modifier.plus,請改用 Modifier.then。「Then」能更明確地指出排序,同時也禁止輸入會破壞鏈結及降低可讀性的 Modifier.padding().background() + anotherModifier (Iedd58b/161529964)

  • 新增了 isFocused()isNotFocused() SemanticsMatcher。(I0b760)

  • 已新增 RemeasurementModifier。可讓使用者同步性地重新測量版面配置。由於重新測量/版面重新配置程序會自動執行,通常不會用到這個項目,但在捲動時會在 LazyColumnItem 中用到 (I5f331b/160791058)

  • 依照最新準則,isSystemInDarkTheme 現在一律會考量全系統的深色主題設定,在 Q 之前忽略省電狀態。(I0c10c)

  • 已淘汰 OnChildPositioned。請改用子項的 OnPositioned (I87f95b/162109766)

  • 已將 AndroidComposeTestRule 重新命名為 createAndroidComposeRule。(I70aaf)

  • 新增無障礙操作,以取得 TextLayoutResult (I9d6e6)

0.1.0-dev15 版本

2020 年 7 月 22 日

發布 androidx.compose.foundation:foundation:0.1.0-dev15androidx.compose.foundation:foundation-layout:0.1.0-dev15androidx.compose.foundation:foundation-text:0.1.0-dev150.1.0-dev15 版本包含以下修訂項目。

如要使用 0.1.0-dev15 版的 Compose,您需要完成以下動作:

依附元件更新

  • 如要使用 0.1.0-dev15 版的 Compose,您必須依據上方「宣告依附元件」一節所示的新程式碼片段更新依附元件。

API 變更

  • 類似於 ScrollableColumn/ScrollableRow 中的新參數,LazyColumnItems/LazyRowItem 現在也有 contentPadding 參數,能在裁剪內容後在後方增添邊框間距,這是光憑輔助鍵參數所無法做到。此外,還能僅在第一個項目之前/最後一個項目之後增添一個間距 (Ibc24e)
  • 已將文字欄位中的 onFocusChange 回呼重新命名為 onFocusChanged (Ida4a1)
  • VerticalScroller 和 HoriziontalScroller 現已淘汰,使用 ScrollableColumn 和 ScrollableRow,透過資料欄/資料列行為和參數或使用內建功能,或是對元素使用 Modifier.verticalScroll 和 Modifier.horizontalScroll。同樣地,ScrollerPosition 也已淘汰,並改用 ScrollState (I400ceb/157225838b/149460415b/154105299)
  • 已將 Modifier.draggable 和 Modifier.scrollable API 重新作業。因為 DragDirection 被移除以有利於 Orientation。可捲動狀態已被簡化。ScrollableState 已重新命名為 ScrollableController (Iab63cb/149460415)
  • 單一值的語意屬性現在起採用呼叫樣式。舉例來說,「semantics { hidden = true }」現在會寫為:semantics { hidden() } (Ic1afdb/145951226b/145955412)。
  • RoundedCornerShape 和 CutCornerShape 所用的 Corner 大小現在起可以大於 50% (Id2340b/160400213)
  • 已將 Image 可組合項的預設 ContentScale 參數從 Inside 改為 Fit。之所以這麼做,是考量如果版面配置的尺寸大於繪圖工具內建函式的尺寸,同時又要維持顯示比例時,即需要具備將基礎 Painter 放大的行為模式。當內建函式的尺寸只會用在運算可組合項的尺寸時,此種行為模式更符合需為 Image 提供固定尺寸、同時不影響預設行為的預期。(I40ae3b/159838006)
  • 在頂層 API 中使用 AnimationSpec (而非 AnimationBuilder) 來釐清靜態動畫規格的概念 - 透過在建立如 tween、spring 等 AnimationSpec 時,不再需要使用 lambda 的做法來改善 DSL 的轉換。而是直接採用建構函式參數。- 改善使用 AnimationSpec 開啟建構函式 (而非仰賴建構工具) 的整體操作簡易性 - 將 KeyFrame 和 Tween 的時間與延遲時間變更為 Int。這可免除不必要的類型層級轉換和方法超載 (支援 Long 和 Int)。(Ica0b4)
  • 已移除 Clickable。請使用 Modifier.clickable (I84bdf)
  • 新增了 LazyRowItem - 類比於 LazyColumnItem 的水平捲動 (Ibbcf7)
  • 引入低階無狀態動畫 API。這些 API (I63bf7)
  • 淘汰 androidx.ui.foundation.TextFieldValue 和 androidx.ui.input.EditorValue。使用該類型的 TextField、FilledTextField 和 CoreTextField 可組合項也已淘汰。請改用 androidx.ui.input.TextFieldValue (I4066db/155211005)
  • 已將所使用的 IntPx 取代為 Int。已將 IntPxPosition 改用 IntOffset 取代。將 IntPxSize 替換成 IntSize。(Ib7b44)
  • androidx.ui.foundation.shape.RectangleShape 已移除;請用 androidx.ui.graphics.RectangleShape (I94939b/154507984)
  • 為了將呈現大小調整資訊所用的類別數量合併,應將 Size 類別的用法標準化,勿使用 PxSize。這樣就能使用內嵌類別,利用一個長整數封裝 2 個浮點值,呈現以浮點表示的寬度和高度 (Ic0191)
  • 為了整合用於呈現地點資訊的資訊類別數量,請將偏移量類別 (而非 PxPosition) 的用量標準化。這樣就能使用內嵌類別,利用一個經度封裝 2 個浮點型數值,呈現以浮點數表示的 x 和 y 偏移量。(I3ad98)
  • 已針對雙指撥動縮放的功能新增 Modifier.zoomable (Id5d63)
  • 已淘汰 Toggleable 元件。請改用 Modifier.toggleable (I35220b/157642842)
  • 已淘汰 MutuallyExclusiveSetItem。請改用 Modifier.selectable。(I02b47b/157642842)
  • TestTag 現已淘汰,請改用 Modifier.testTag。(If5110b/157173105)
  • 在 Text 中新增之前漏掉的 fontWeight 參數 (I56937)
  • 我們進行了大規模的重構工作,包括將各種撰寫類別中所使用的 Px 類別改為只使用 Dp 和基本類型來處理像素參數 (I19d02)
  • VerticalScroller 提供立即可用的欄。HorizontalScroller 現在提供立即可用的列。(Ieca5db/157020670)
  • 我們進行了大規模重構工作,包括將各種撰寫類別中所使用的 Px 類別改為只使用 Dp 和基本類型來處理像素參數 (Iede0b)
  • 已將 Modifier.indication 新增至 Foundation 套件。能用來在自訂可互動元素上顯示按下/拖曳/其他指標 (I8425fb/155287131)
  • 現已支援反向捲動的 VerticalScroller 和 HorizontalScroller 是 isReversed,在 ScrollerPosition 上設定 (I953bd)
  • 支援在文字版面配置中加入可組合項 (I1373c)
  • 已將 CanvasScope 實作項目整合,現在只有 DrawScope 和 ContentDrawScope。已將 CanvasScope 重新命名為 DrawScope。已更新 DrawScope 來實作 Density 介面,並提供 LayoutDirection。刪除 ContentDrawScope 中的 DrawScope 子類別。Painter 和 PainterModifier 已更新為不再自行維護 RTL 屬性,因為 DrawScope 已有此功能,不必手動設定 (I1798e)
  • 已移除淘汰的 DrawBackground API,改用 Modifier 上的 drawBackground 擴充 API。重構色彩、筆刷與繪製 drawBackground 的實作,減少程式碼路徑,並移除建立 Modifier 做為部分組成元件的要求。(I0343a)
  • 已更新較高層級的 Composer API,將原有顯示 Canvas 改為顯示 CanvasScope。如此一來,取用者就不必維護自己的 Paint 物件。如果取用者仍要求 Canvas 存取權,則可以使用 drawCanvas 擴充功能方法,這種方法可提供回呼,透過基礎 Canvas 發出繪圖指令 (I80afd)。
  • HorizontalScroller 和 VerticalScroller 現在可用既存執行個體狀態還原捲動位置 (Ia0faeb/155075048)
  • 移除了 FocusManagerAmbient。使用 FocusModifier.requestFocus 取得專注力。(Ic4826)
  • 表格版面配置已暫時移除,至我們以重新整理的 API 提供使用為止。(Id88a7)
  • 已建立 CanvasScope API,可納入 Canvas 物件以顯示無狀態的宣告式繪圖 API 途徑。變形作業侷限在其本身的接收器範圍內,大小調整資訊的範圍也對應插邊的邊界。不需要讓取用端保有自己的 Paint 狀態物件來設定繪圖作業。

    新增 CanvasScopeSample 並更新試用版應用程式,加入宣告式圖形示範 (Ifd86d)

  • 已移除 ColoredRect。請改用含有 drawBackground 輔助鍵的 Box (I983c7b/152753731)

  • 在 TextField 中新增游標色彩自訂 (I6e33f)

  • 現在可以使用由 onTextInputStarted 回呼所傳送的 SoftwareKeyboardController 隱藏/顯示軟體鍵盤 (I8dc44b/151860051)

  • 現在以類似以下的方式將 TextFieldValue 與 TextField 搭配使用,能在活動重建之後繼續存在:var text by savedInstanceState(saver = TextFieldValue.Saver) { TextFieldValue() } (I5c3ceb/155075724)

  • 將常用的參數加至 Text()。如果您目前是建立本機的文字樣式來傳遞這些少數的參數 (例如 Text(style = TextStyle(textAlign = TextAlign.Center))),現在可直接提供參數:Text(textAlign = TextAlign.Center) (I82768)

  • 已將 CoreTextField/TextField focusIdentifier 參數改為 FocusNode,以便與聚焦子系統整合 (I7ea48)

  • TextField 更新 - 在水平維度上,會占滿允許的所有空間 (Ib08dfb/154638552)

  • 新增了 InteractionState 和 Interaction,使得更便於建構能夠回應 UI 狀態改變 (例如按下和拖曳) 的元件 (Icfe25b/152525426)

  • 已將 RectangleShape 從 androidx.ui.foundation.shape.* 移至 androidx.ui.graphics* (Ia74d5b/154507984)

  • 將 API 中所有使用到且可為空的 Color 改為不可為空值,並改為使用 Color.Unset (Iabaa7)

  • TextField API 更新 - 已將 onFocus 和 onBlur 回呼合併至帶有參數的單一 onFocusChange(Boolean) 回呼 (I66cd3)

  • 已將 ScaleFit 重新命名為 ContentScale。已將 ContentScale 從 ui-graphics 移至 ui-core 模組,以與 Alignment API 位於同一模組。將 FillMaxDimension 重新命名為 Crop。將 FillMinDimension 重新命名為 Fit。將 Fit 重新命名為 Inside,使其更加符合 ImageView.ScaleType 的同等項目。新增說明文件,說明 Crop 與 Alignment.Center 的組合所達到的結果與 ImageView.ScaleType.CENTER_CROP 相同,與 Alignment.Center 搭配使用的 Fit 所達到的結果與 ImageView.ScaleType.FIT_CENTER 相同。搭配 Alignment.Center 使用的Inside 所達到的結果與 ImageView.ScaleType.CENTER_INSIDE 相同 (I45f09b/152842521)

  • 移除 ProvideContentColor,請改為直接搭配 Providers 使用 ContentColorAmbient (Iee942)

  • 新增色彩參數至文字,以便無需手動與主題中所提供的樣式合併,即可覆寫文字樣式的色彩。(I41a66)

  • 改善 DrawModifier API:

    • 已設定 Draw() ContentDrawScope 的接收器範圍
    • 移除了 Draw() 的所有參數
    • DrawScope 的介面與之前的 CanvasScope 介面相同
    • ContentDrawScope 含有 DrawContent() 方法 (Ibacedb/152919067)
  • ColoredRect 已淘汰,請改用 Box(Modifier.preferredSize(width, height).drawBackground(color))。(I499fab/152753731)

  • 形狀主題系統的安裝會根據 Material 設計規格進行更新。您現在可以提供大多數元件所使用的小型、中型和大型形狀 (Ifb4d1)

  • 已將 Modifier 加號運算子取代為 Factory 擴充功能函式 (I225e4)

  • Draggable 已移為修飾符 (Id9b16b/151959544)

  • 已將 androidx.ui.core 中的 Text 移至 androidx.ui.foundation 套件 (I87ce5)

  • enabled 參數加到 Checkbox、Switch 和 Toggleable (I41c16)

  • Ripple 現已改名為 Modifier。Clickable 尚未轉換期間,其建議用法是 Clickable(onClick = { ... }, modifier = ripple()) (Ie5200b/151331852b/150060763)

  • 新增了 VectorPainter API 以替向量圖形取代現有的子撰寫 API。子組合的結果是 VectorPainter 物件,而非 DrawModifier。已淘汰先前的 DrawVector 元件,改用 VectorPainter。

    Image(Painter) API 重新命名為 PaintBox(Painter) 建立 Vector 可組合項,其行為類似 Image 可組合項,除了其含有 VectorAsset 而非 ImageAsset (I9af9ab/149030271)

  • 已建立 Image 可組合項,不但可在畫面上繪製指定的 ImageAsset,也能處理大小調整/版面配置。這個可組合項也支援繪製任何任意的 Painter 執行個體,可依照內建函式的尺寸,也支援指定的固定尺寸或最小尺寸 (Ibcc8f)

  • Button、FloatingActionButton 和 Clickable 現在有獨立的 enabled 參數。Button 上的部分參數已重新命名或重新排序 (I54b5a)

  • 已將 Image 重新命名為 ImageAsset 以使參與內容的版面配置與繪製所用的 Image 資料與即將產生的 Image 可組合項之間的差異更容易區分。

    在 android.graphics.Bitmap 上建立擴充方法 Bitmap.asImageAsset() 以建立 ImageAsset 執行個體,適合用來將傳統的 Android 應用程式開發與撰寫架構相結合。(Id5bbd)

  • 移除 DrawImage 可組合項。使用 ImagePainter 在現有版面配置上繪製圖像,或用 SimpleImage 引入產生的 Image (I595e1b/149827027)

  • Stack 元件可支援由右往左的方向性 (Ic9e00)

  • 已新增 Icon、IconButton 和 IconToggleButton,並移除 AppBarIcon。您現在可以用 IconButton 直接取代 AppBarIcon 的現有使用情況,而且現在應具有正確的觸控目標。請參閱相關使用資訊的範例,並查看能直接搭配這些元件使用的 Material 圖示。(I96849)

  • 移除 DrawShape 可組合項。請改用 DrawBackground 修飾符 (I7ceb2)

  • 新增了 AdapterList 這個捲動清單元件,僅撰寫及佈置顯示的項目。目前已知的問題包括,這個元件僅限直向,且無法完全處理子項的所有變更。(Ib351b)

  • 已新增 Scrollable 元件,可用以建立自訂的 Scroller/List (I5fd37)

  • 已將 background 重新命名為 DrawBackground,並成為預設加以記憶 (Ia0bd3)

  • 為 Box 新增邊框間距、框線、形狀和背景參數 (I05027b/148147281)

  • 新增了 Canvas 元件。這個可組合項會占用某個大小 (由使用者所提供),可供使用 CanvasScope 進行繪圖 (I0d622)

  • Border 輔助鍵重新命名為 DrawBorder (I8ffcc)

  • 新增 Box 元件,可用於合併版面配置及繪製常用功能。(I6e2a7)

  • Scroller 現在會表現出 Android 原生的快速滑過動作行為。(I922afb/147493715)

  • 已取代 DrawBorder 並改用 Border 輔助鍵 (Id335a)

  • Modifier.tag 已重新命名為 Modifier.layoutId,以避免與 Modifier.testTag 混淆。(I995f0)

  • 在建立 ConstraintLayout 準則時的 percent 參數已重新命名為 fraction。(Ida2db)

  • 新增了支援 ConstraintLayout 阻隔線的外邊距。(I47ffe)

  • 已修正對 ConstraintLayout 的 RTL 支援。新增了 RTL 無感知 API。(I3b1c7)

  • 已為 ConstraintLayout 新增 DSL。詳情請參閱範例。(Icaa9a)

  • 新增了 @ExperimentalLayout 註解。ConstraintLayout、FlowRow 和 FlowColumn 現已加入該標記,以標示其 API 即將改變 (I412a8)

  • 已新增 Modifier.padding(InnerPadding) (I94985b/157133803)

  • 已移除 Row 和 Column 中淘汰的 RowAlign、ColumnAlign (If60d4b/155858731)。

  • 已移除淘汰的 LayoutTag(),請改用 Modifier.tag()移除了已淘汰的 Modifier.matchParent(),請改用 Modifier.matchParentSize()。(If8044)

  • 新增了 offsetPx 版面配置輔助鍵,可用來定義 px 中的 (動態) offset。(I5af57)

  • AlignmentLineOffset 可組合項已淘汰,請改用 relativePaddingFrom() 輔助鍵。CenterAlignmentLine 可組合項也已移除 (I60107)

  • 新增了 defaultMinSizeConstraint 版面配置輔助鍵,成為僅限收到的對應限制為未指定時,才對包裝的版面配置設定大小限制 (最小限制為 0,最大限制為無限)。(I311eab/150460257)。

  • 已移除 Container。請改用 Box (Ibbc2bb/151407926)

  • 已移除淘汰的 LayoutWidth/Height/Size 輔助鍵。(Ib0bc1)

  • 已為 offset 輔助鍵新增預設參數值。(I37f06)

  • 新增對稱式邊框間距修飾符。(I39840)

  • 移除淘汰的 LayoutAspectRatio 修飾符。(I65a74)

  • 移除淘汰的 LayoutAlign 修飾符。(I10877)

  • 修正寬度和高度修飾符的錯誤,以防納入的版面配置在沒有相反軸限制的情況下受到測量。(I210b8b/154797971)。

  • 已分別將 verticalGravity 和 horizontalGravity 參數新增至 Row 和 Column。(I7dc5a)

  • 已更新 wrapContentWidth 和 wrapContentHeight 必須使用垂直或水平對齊,而非使用任何對齊。引力調整器已更新為接受垂直或水平對齊。更新 Row、Column 和 Stack,藉此支援自訂的持續對齊方式 (Ib0728)

  • 已將 Alignment 設為能以任意值加以實例化。新增了 1D Alignment。(Ia0c05)。

  • 已將 EdgeInset 重新命名為 InnerPadding。而將 Material Buttons 的 innerPadding 參數重新命名為 paddding。(I66165)

  • alignToSibling 現在可使用 Measured 而非 Placeable。(I5788d)

  • 新增用於調整內建函式測量資料大小的修飾符,並淘汰相同用途的元件。(I8295d)

  • 支援自訂 ConstraintLayout 子項的尺寸 (Idb1a5)

  • 移除了淘汰的 Wrap 和 Center 可組合項。(I29e23)

  • 新增一個可定義版面配置修飾符的新 API LayoutModifier2;淘汰 LayoutModifier (If32ac)

  • RowScope 和 ColumnScope 構件現在已可從 Row 和 Column 之外存取。(I3a641)

  • 已淘汰 Container。請改用 Box。(I675ceb/151407926)。

  • 新增 LayoutOffset 修飾符,可移動版面配置的位置 (I0b8a3)

  • 初步提供對 Compose 版面配置中 Rtl 的支援 (Ia5519)

  • 更新 LayoutAlign,使其不再填滿可用空間 (I2b14f)

  • 移除 AspectRatio 可組合項,改用修飾符。刪除過時的 FlexColumn、FlexRow 可組合項和 Spacing 修飾符 (Iec8a7)

  • 移除 Row 和 Column 的 LayoutInflexible 修飾符 (I0d820)

  • 實作拖曳選取控點,以變更 TextField 的選取項目。(I27032)

  • 針對 TextField 選取實作 LongPressAndDrag。(I17919)

修正錯誤

  • 淘汰了 FocusModifier,改用 Modifier.focus、Modifier.focusRequester、Modifier.focusObserver。淘汰 FocusState 和 FocusDetailedState,改用 FocusState2 (I46919b/160822875b/160922136)
  • runOnIdleCompose 已重新命名為 runOnIdle (I83607)
  • 將多個測試 API 重新命名,提供更直覺化的使用體驗。將所有 FindXYZ API 都重新命名為 onNodeXYZ。將所有 doXYZ API 都重新命名為 performanceXYZ。(I7f164)
  • 移除先前淘汰的 Modifier.ripple。Clickable 現在使用波紋做為預設指標 (如果您在應用程式中設定了 MaterialTheme {}),因此在大多數情況下,您只需使用 Clickable,即可免費取得分享指示。如要自訂漣漪效果的顏色/大小/邊界參數,可以手動建立 RippleIndication,並將其做為指示參數傳遞給 Clickable (I663b2b/155375067)。
  • 已移除過時的尺寸測試 API。(Iba0a0)
  • 已將 LayoutNode 設為實驗性 API (I4f2e9)
  • 於全 Compose 實作第 1 版捲動方向的鎖定。(I1ce7ab/150289741)。
  • Popup、Dialog 和 Menu 現在起承襲結構定義的 MaterialTheme (Ia3665b/156527485)
  • 從 Layout() 函式的測量區塊移除版面配置方向參數。不過,可透過測量範圍物件,在回呼中使用版面配置的方向 (Ic7d9d)
  • 新增 StaticArrangement - 允許在 Row 中排列子項,而不使用 RTL 中的自動鏡射 (I3a1df)
  • 已淘汰 @Untracked 註解。請改用 @ComposableContract(tracked=false) (Id211e)
  • 在這項異動之前,Compose 編譯器外掛程式會顯著攔截對 @Composable 函式內建構函式的呼叫 (如果有) (I5205ab/158123804)
  • 新增 viewModel() 元件,以便建立或建立 View Model 的方式與類似「活動」或「片段」工具 (I5fdd1) 的運作方式相似。
  • 已將 Radius 類別重構為內嵌類別。移除具有預設參數的函式建立方法,並使用預設參數讓半徑 Y 軸與必要 X 軸半徑參數的 y 軸相符。

    將 DrawScope.drawRoundRect 更新為使用單一 Radius 參數,而非取用沿著 x 和 y 軸的半徑的 2 個獨立浮點值 (I46d1b)

  • 我們進行了大規模重構工作,包括將各種撰寫類別中所使用的 Px 類別改為只使用 Dp 和基本類型來處理像素參數。Px 類別也已完整刪除 (I3ff33)

  • 我們進行了大規模重構作業,包括將各種 compose 類別中使用的 Px 類別改為只使用 Dp 和原始類型來處理像素參數 (I086f4)

  • 我們進行了大規模重構工作,其中一部分是將在各種組合中使用 Px 類別來處理像素參數,更換成只使用 Dp 和基本類型 (Id3434)

  • 我們進行了大規模重構工作,包括將各種撰寫類別中所使用的 Px 類別改為只使用 Dp 和基本類型來處理像素參數 (I97a5a)

  • TextField 的游標有閃爍的動畫 (Id10a7)

  • 部分手勢不再需要傳遞 GestureToken (Id7ae5)

  • 我們進行了大規模重構工作,包括將各種撰寫類別中所使用的 Px 類別改為只使用 Dp 和基本類型來處理像素參數 (I57bff)

  • 我們已取消淘汰 Modifier.semantics,並允許使用高階元件 (I4cfdc)

  • AnnotatedString.Builder.addAnnotationString 重新命名為 addStringAnnotation。(I5059e)

  • 更新了 Alignment API 並新增了絕對對齊支援 (在 Rtl 環境中不會自動提供鏡像) (I38cd3)

  • Layout 和 LayoutModifier 子項可用不同的版面配置方向加以測量。(Ibd731)

  • 為 ImagePainter 新增其他可用的 rect 參數,以支援繪製一個底下 ImageAsset 的子區 (I0ea9e)

  • 修正移除項目時在 AOSPList 中的異常終止問題 (Ic64b0b/153195921)

  • 對於您置入 activity.setContent { } 區塊內的第一個版面配置,我們改變了測量方式。先前是強制填滿整個活動畫面,現在的行為模式有如您將版面配置放進 Stack 內:可以比畫面小,這時會放置在左上角。如果想保留原本的行為模式,可以對版面配置套用 Modifier.fillMaxSize() (Ie88a7b/153453714)

  • ui-text-compose 模組重新命名為 ui-text。ui-text 現在包含 CoreText 和 CoreTextField 元件 (Ib7d47)

  • ui-text 模組已重新命名為 ui-text-core (I57dec)

  • 將 ui-framework/CoreText、CoreTextField 可組合項移至 ui-text-pose 下。建議您在專案中納入 ui-text-compose (I32042)。

  • runOnIdleComposerunOnUiThread 現在是全域函式,不是 ComposeTestRule 上的方法 (Icbe8f)。

  • [Mutable]State 屬性委派運算子已移至擴充功能,以支援 Kotlin 1.4 屬性委派最佳化。呼叫端必須新增匯入作業才能繼續使用 by state { ... }by mutableStateOf(...) (I5312c)

  • DrawLayerModifier 和 drawLayer() 現在會將 clipToBounds 和 clipToOutline 預設為 false (I0eb8bb/152810850)

  • 已將 LayoutResult 重新命名為 MeasureResult。(Id8c68)

  • 淘汰了 Center 可組合項。應改用 LayoutSize.Fill + LayoutAnchor.Center 修飾符,或將其替換為已套用適當修飾符的 Box 或 Stack 可組合項 (Idf5e0)

  • 已將 LayoutFlex 重新命名為 LayoutWeight。將 tight 參數重新命名為 fill。(If4738)

  • DrawVector 已從一般的可組合函式改為會傳回 Modifier drawVector(),將向量繪製成版面配置的背景。(I7b8e0)

  • 將可組合函式 Clip 替換為修飾符 drawClip()。當只需要將圖層邊界裁剪為矩形時,DrawdClupToBounds 是相當實用的修飾符。(If28eb)

  • DrawShadow 可組合函式已更換為 DrawShadow() 修飾符。陰影現已繪製成 LayerModifier 的一部分。(I0317a)

  • androidx.compose.ViewComposer 已移至 androidx.ui.node.UiComposer。此外,我們移除了 androidx.compose.Emittable,它對 ComponentNode 來說是多餘的。androidx.compose.ViewAdapters 已移除。系統已不再支援這些項目。Compose.composeInto 已淘汰,請改用 setContentsetViewContent。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)

  • 淘汰了 Wrap 可組合項。這可以替換成 LayoutAnchor 修飾符或 Stack 可組合項 (Ib237f)

  • 使版面配置方向可以從上層布局節點套用到子項。新增了版面配置方向修飾符 (I3d955)

  • Painter.toModifier 重新命名為 Painter.asModifier,因為新建立的 Modifier 所參照的原始 Painter 能在多個 Modifier 執行個體之間共用 (I7195b)

  • 支援 LayoutPadding 輔助鍵中由右到左的方向 (I9e8da)

  • Density 和 DensityScope 已合併至單一介面。現在可以使用 DensityAmbient.current 取代 EnvironmentDensity()。勿用 withDensity(density),請用 with(density) (I11cb1)

  • 移除 ValueHolder 類別。已重新建構 AnimatedValue 和 AnimatedFloat 類別,使動畫值欄位變得抽象,讓子類別可以監看數值更新。

    • 為 AnimatedValue、AnimatedFloat 等新增了模型類別。
    • 新增了一組輕量的 @Composable API,用來在不同的值之間進行動畫。
    • (I79530)
  • 對環境 API 做出破壞性變更。詳情請參閱記錄檔和 Ambient<T> 說明文件 (I4c7eeb/143769776)

  • 從 Placeable#get(AlignmentLine) 傳回的 Alignment 行 Int 位置現在起不可為空值。如果缺少查詢的對齊線,就會傳回 AlignmentLine.Unspecified (I896c5b/158134875)。

  • 修正重組時造成異常終止的 ConstraintLayout 錯誤 (Ibee5ab/158164341)。

  • 變更 WithConstraints 結尾的 lambda API。我們現在以接收器範圍取代原本的兩個參數,除了 constraints 與 layoutDirection 之外,還提供 Dp 中的 minWidth、maxWidth、minHeight 和 maxHeight 屬性 (I91b9ab/149979702)

  • 已將 LayoutModifier2 重新命名為 LayoutModifier。(Id29f3)

  • Layout 和 LayoutModifier2 中的內建測量函式現在設有 IntrinsicMeasureScope 接收器,可提供附有隱性傳播版面配置方向的內建函式查詢 API (Id9945)

  • 淘汰 LayoutDirectionAmbient。如要讀取依照語言代碼所定義的版面配置方向,請使用 ConfigurationAmbient 上的 localeLayoutDirection (I851b1)

  • 已為 LayoutCoordinates 新增 positionInParent 和 boundsInParent。(Icacddb/152735784)

  • 淘汰 ParentData 可組合項。您應建立可實作 ParentDataModifier 介面的修飾符;如果只想為版面配置子項加上標記,方便在測量區塊中加以識別,則請使用 LayoutTag 修飾符 (I51368b/150953183)

  • 新增 OnPositionedModifier 和 OnChildPositionedModifier 以取代 OnPositioned 和 OnChildPositioned 可組合函式 (I2ec8f)

  • 不允許 LayoutPadding 有負值的邊框間距。勿用負值位置偏移,請改用 LayoutOffset (Ifb5b1)

  • WithConstraint 具有 LayoutDirection 參數 (I6d6f7)

  • 已將 ComposeFlags.COMPOSER_PARAM 旗標更新為 true,這會變更 Compose 外掛程式的程式碼產生策略。大致上來說,這會導致系統產生附加合成參數的 @Composable 函式,這個參數會傳遞至後續的 @Composable 呼叫中,藉此讓執行階段妥善管理執行作業。這是二進位檔的重大破壞性變更,但應在所有 Compose 的合法使用情況中,保留來源層級的相容性。(I7971c)

  • 已變更 LayoutCoordinates,將 providedAlignmentLines 成為 Set (而非 Map),同時讓 LayoutCoordinates 實作 get() 運算子,而不是擷取一個值。這樣一來,修飾符就能輕鬆修改組合的一或多個值,而不必為每個修飾符建立新的集合 (I0245a)

  • LayoutCoordinates 已不再具備位置屬性。考慮使用 LayoutModifiers、旋轉或資源調度時,排名屬性並不合理。開發人員應改用 parentCoordinates 和 childToLocal() 計算 oneLayoutCoordinate 之間的轉換。

    LayoutCoordinates 使用 IntPxSize 做為大小屬性,而非 PxSize。Layout 會使用整數像素大小設定版面配置,因此所有版面配置大小都應使用整數,而不是浮點值 (I9367b)。

  • 改善限制的 API 介面 (I0fd15)

  • 新增了 TextDirection.Content (I48f36)

  • 調整工具列選單,使其正確顯示複製、剪下和貼上選項。(Id3955)

  • 為 TextField 的選取新增 FloatingToolbar (Ie8b07)

  • 已將 TextDirectionAlgorithm 重新命名為 TextDirection (I75ce8)

  • 已將 TextDirection 重新命名為 ResolvedTextDirection (I3ff38)

  • 已為 TextField 選取新增 HapticFeedback。(I58050)

  • 已為 TextField 選取新增 Copy、Cut 和 Paste 方法 (Idb70b)

  • 已刪除 TestTag 和 Semantics。請改用 Modifier.testTag 和 Modifier.semantics (I15ff0b/158841414)

  • 已將 Locale 和 LocaleList 的套件名稱從 androidx.ui.text 變更為 androidx.ui.intl (I8132c)

  • API 變更:已將 AnnotatedString(builder: Builder) 重新命名為 annotatedString(builder: Builder) (Ia6377)。

  • API 變更:已將 AnnotatedString.Item 重新命名為 AnnotatedString.Range (I2d44d)。

  • 為文字相關作業新增工具列。(I49d53)

  • 現已提供新的 LifecycleOwnerAmbient。現在,您以 Compose UI 使用的 Activity 應能擴充 androidx.activity.ComponentActivity (or AppCompatActivity)android.app.Activity 上的 setContent 現已淘汰 (Idb25ab/153141084)

  • 為配合 androidx 原則,ui-android-text 套件名稱 (androidx.text) 改為 androidx.ui.text.platform。(I42711)