Compose UI

Compose UI 的基礎元件,用於與裝置互動,包括版面配置、繪圖及輸入。
最近的更新 穩定版 候選版 Beta 版 Alpha 版
2022 年 8 月 24 日 1.2.1 - 1.3.0-beta01 -

結構

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

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

群組說明
compose.animation在其 Jetpack Compose 應用程式中建構動畫,以提供豐富的使用者體驗。
compose.compiler透過 Kotlin 編譯器外掛程式轉換 @Composable 函式,並啟用最佳化功能。
compose.foundation透過現成可用的建構區塊編寫 Jetpack Compose 應用程式,並擴充基礎以建構您自己的設計系統元件。
compose.material運用現成可用的質感設計元件建構 Jetpack Compose UI。這是更高層級的 Compose 進入點,用意是確保提供的元件與 www.material.io 上所述元件相符。
compose.material3運用新一代的質感設計 3 元件建構 Jetpack Compose UI。質感設計 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.ui:ui:1.3.0-beta02"
}

android {
    buildFeatures {
        compose true
    }

    composeOptions {
        kotlinCompilerExtensionVersion = "1.3.0-beta02"
    }

    kotlinOptions {
        jvmTarget = "1.8"
    }
}

Kotlin

dependencies {
    implementation("androidx.compose.ui:ui:1.3.0-beta02")
}

android {
    buildFeatures {
        compose = true
    }

    composeOptions {
        kotlinCompilerExtensionVersion = "1.3.0-beta02"
    }

    kotlinOptions {
        jvmTarget = "1.8"
    }
}

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

意見回饋

您的意見可協助我們改善 Jetpack。發現新的問題或有改善這個程式庫的想法時,請告訴我們。建立新的問題之前,請先查看這個程式庫中的現有問題。只要按一下星號按鈕,即可投票給現有的問題。

建立新問題

詳情請參閱 Issue Tracker 說明文件

1.3 版本

1.3.0-beta01 版本

2022 年 8 月 24 日

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

輔助鍵節點重構

處理 Modifier/Modifier.Element 執行個體及協調其在 LayoutNodes 上行為的層已大幅重構。但由於此為重構,不會影響 Compose 中許多修飾鍵的公用 API,而且可視為僅實作的變更。儘管如此,基於各種原因,這仍是一項重要的變更 (Ie4313)。

變更摘要

新增的實驗性 Modifier.Node API 提供抽象層,允許在執行個體上維護狀態,該執行個體將隨版面配置節點的生命週期一起保留,且將按版面配置節點和產生其的對應 Modifier.Element 的使用情況進行分配。

普遍來說,這個抽象提供了另一種機制,不用依賴 Modifier.composed API 的機制即可產生有狀態的修飾鍵。

風險

此變更與先前版本的二進位檔緊密相容,用於在可觀測行為上盡可能務實且合理地提供回溯相容性。亦即,撰寫此重構的幾個子系統並未接觸,因此行為可能在我們測試未涵蓋的範圍發生了變化,因此未能發現並修復

請謹慎升級至這個版本。如果您認為升級時發生了問題,請與我們聯絡。

實驗性 API

我們新增了各種實驗性 API,全都與「輔助鍵節點」的新概念有關。輔助鍵節點的建立係依據

  • fun modifierElementOf(…): Modifier
  • abstract class ModifierNodeElement
  • abstract class Modifier.Node
  • abstract class DelegatingNode
  • interface LayoutModifierNode
  • interface DrawModifierNode
  • interface SemanticsNode
  • interface PointerInputNode
  • interface ModifierLocalNode
  • interface ParentDataModifierNode
  • interface LayoutAwareModifierNode
  • interface GlobalPositionAwareModifierNode
  • interface IntermediateLayoutModifierNode

行為破壞性變更

對話方塊和彈出式視窗支援的高度上限已降至 8dp。

Compose 對話方塊和彈出式視窗支援的高度上限已從 30dp 降至 8dp。這項變更會影響實質關聯及使用者介面自訂對話方塊和彈出式視窗。這項變更的目的在於減少 S 以下 Android 版本的無障礙錯誤,並確保這些視窗中的無障礙服務能夠與對話方塊或彈出式視窗內的內容互動。

只有在您建立自訂對話方塊或彈出式視窗實作、且高度設定為 8 dp 以上時,才會受到這項變更的影響。請考慮降低對話方塊或彈出式視窗的高度。如果您需要選擇不採用這項新行為,請考慮以您所需的高度組合,自行設定對話方塊或彈出式視窗。不建議這麼做,因為無障礙功能可能會受到不當的影響,而且必須由開發人員確保對話方塊的底部或彈出式視窗能進行互動,並且可供無障礙服務讀取。

API 變更

  • 修正 painterResource 無法更新設定變更的問題 (I58e73b/228862715)。
  • rememberTextMeasurer 不再使用 FontFamily.ResolverDensityLayoutDirection 參數。請使用 TextMeasurer 建構函式為這些參數提供自訂值 (Ia1da3)。
  • 已新增 DialogProperties.decorFitsSystemWindows 屬性,以允許對話方塊支援 WindowInsets (I57742b/229378542)。
  • 將字型建構函式移回原本的 kotlin 檔案,以保持二進位檔相容性。與上次的穩定版本相比沒有任何異動 (Ieb2f3)。
  • 從多個等號定義中移除不必要的運算子 - 不會產生任何作用 (I6c309)。
  • FontVariation.Setting 為密封介面,用於允許日後限制 API 的取值範圍 (I11021b/143703328)。
  • 新增 CompositionGroup.findParametersSlotTree.kt。這可讓工具擷取 CompositionGroup 的參數,而不必剖析整個運算單元資料表 (I124fe)。

1.3.0-alpha03 版本

2022 年 8 月 10 日

發布 androidx.compose.ui:ui-*:1.3.0-alpha031.3.0-alpha03 版本包含以下修訂項目。

API 變更

  • LayoutCoordinates.findRootCoordinates() 現已公開 (I7fa37b/204723384)
  • 新增實驗性 API,以取得 PlacementScope 中的 LayoutCoordinates。這可讓開發人員得知目前版面配置的位置,以便將其子項放在相對位置。(I5482bb/238632578)
  • 新增 LayoutCoordinates.transformFrom,以取得兩個 LayoutCoordinates 之間的 Matrix 轉換資料。(Ic5ab1b/238632578)
  • 淘汰 SemanticsModifier.id,並將語意 ID 移至 LayoutInfo.semanticsId。(Iac808b/203559524)
  • 資源字型現在支援字型變化版本設定 (API 26 以上版本)。(I900ddb/143703328)
  • DeviceFontFamilyNameFont 中的可變字型支援 (Ic1279b/143703328)
  • 字型建構函式現在接受 FontVariation.Setting 清單,以便在 O+ 裝置上設定可變字型。(I11a9db/143703328)
  • 新增 FontVariation API 以定義及使用可變字型。(I3c40cb/143703328)
  • LineHeightStyle.Alignment 建構函式現已公開 (實驗性質) (I4bbbeb/235876330)
  • Android 和電腦版應用程式現在都可以實際運用並定義段落。(Id387eb/239962983)
  • 介面 Paragraph 現已改為密封的介面 Paragarph。沒有任何用途需要將段落設為子類別,而如果這項異動對您造成影響,建議您與我們聯絡。(If5247b/239962983)
  • PlatformTextStyleLineHeightStyle 中移除實驗性註解。(I64bef)
  • 淘汰 TextInputService.show|hideSoftwareKeyboard。請在應用程式程式碼中改用 SoftwareKeyboardController,並在輸入法編輯器管理程式碼中使用 TextInputSession。(I14e4cb/183448615)
  • 為現有的動畫類型新增 API (I26179)

修正錯誤

  • @RequiresPermission 新增至需要為 SDK 33 以上版本授予 POST_NOTIFICATIONS 權限的 API (Ie542eb/238790278)

1.3.0-alpha02 版本

2022 年 7 月 27 日

發布 androidx.compose.ui:ui-*:1.3.0-alpha021.3.0-alpha02 版本包含這些修訂版本。

API 變更

  • 新增 PointerInputChange#pressure 屬性以擷取壓力。(I45a5eb/205164819)
  • 新增 rememberTextMeasurer,方便您在組合中建立及記錄 TextMeasurer 執行個體。(I8d66e)
  • RectRoundRectMutableRect 現在支援使用 Kotlin in 語法呼叫 contains 函式。(Ie42b0b/238642990)
  • KeyInjectionScope 中移除不需要的函式,因為您可透過更簡單的 API 元件輕鬆實作這些函式。已移除的函式包括 pressKeyskeysDownkeysUp。(I81d77)
  • 重構 KeyInjectionScope 中的常數和參數名稱以加上後置字串「Millis」,其中上述常數和參數的單位為毫秒。(Iabef5)。
  • EditCommand 中新增 toStringForLog() 方法,以協助排解文字編輯問題。(I53354b/228862731)
  • DrawScope 上新增 drawText 擴充功能函式,這樣就能對在 DrawScope (例如 CanvasdrawBehind) 上操作的可組合項和修飾詞繪製多樣式文字 (I16a62b/190787898)
  • 推出名為 TextMeasurer 的新實驗性 API,用於啟用任意文字版面配置運算,以便在與 Compose 執行階段無關的情況下,產生與 BasicText 相同的結果。(I17101)
  • SlotTree.kt 中新增 mapTree。這可讓各項工具檢查 SlotTree,但不需要像 asTree 一樣先在記憶體中進行複製。對於版面配置檢查器來說,效能可提升約 10 倍。(I5e113)
  • 將 Compose 預覽變更為以二進位輸出檔案儲存,方便開發人員編寫及重複使用程式庫中的 MultiPreview 註解。(I85699b/233511976)

修正錯誤

  • InputEventChange 事件加入至 Velocity 追蹤器時,我們現在會考慮使用差異值而非位置,因此即使目標元素移動,也能確保所有案例的速度計算正確 (Icea9db/216582726b/223440806b/227709803)
  • 修正 AnnotatedString.toUpperCase 在顯示註解時造成的 NPE。(I0aca2b/210899140)

1.3.0-alpha01 版本

2022 年 6 月 29 日

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

API 變更

  • 新增 LookaheadLayout,支援在實際測量/版面配置之前使用 Lookahead 傳遞。如此一來,就可以在版面配置變更時預先計算,讓 Lookahead 後測量/版面配置使用預先計算的大小/位置,以動畫方式呈現目標大小和位置。目前尚不支援 SubcomposeLayouts,但會在即將推出的版本中推出。(I477f5)
  • 新增選用的 Alpha 參數至 TextStyleSpanStyle 的 Brush 變種版本,以修改整個 Text 的不透明度。(Ic2facb/234117635)
  • 推出 UrlAnnotation 註解類型與相關的方法,以支援 AnnotatedString 中的 TalkBack 連結支援。(I1c754b/231495122)
  • 將公用程式功能移至執行階段 (I4f729)

修正錯誤

外部貢獻

  • 已加入新的 API WindowInfo.keyboardModifiers,以在可組合函式內或透過 snapshotFlow 觀測其狀態 (Icdb8a)

1.2 版本

1.2.1 版本

2022 年 8 月 10 日

發布 androidx.compose.ui:ui-*:1.2.11.2.1 版本包含以下修訂項目。

修正錯誤

  • 修正檢查器中的空值指標 (b/237987764)
  • 修正在檢查器中記錄期間發生的類別層級轉換例外狀況 (b/235526153)

1.2.0 版本

2022 年 7 月 27 日

發布 androidx.compose.ui:ui-*:1.2.01.2.0 版本包含以下修訂項目。

自 1.1.0 版以來的重要異動

  • 改善焦點周遊功能:

    • 使用新的 BeyondBoundsLayout 核心 API 時,Lazy 清單的焦點導向捲動功能現可正常運作
    • FocusOrderFocusProperties 中新增自訂行為 API
    • 改善使用實體鍵盤或電視遙控器時的行為表現
  • 適用於以下項目的新 API:

    • 視窗插邊
    • 手勢驅動、無限和版面配置動畫適用的核心基本功能
    • GraphicsLayer 功能,包括 RenderEffect
  • 修正多項錯誤並提升執行效能

1.2.0-rc03 版本

2022 年 6 月 29 日

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

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

1.2.0-rc02 版本

2022 年 6 月 22 日

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

1.2.0-rc01 版本

2022 年 6 月 15 日

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

API 變更

  • Compose 程式庫中的介面現已使用 jdk8 預設介面方法建立 (I5bcf1)
  • 已加入高排序函式至 KeyInjectionScope 以供在按住其他鍵時按下插入鍵,或在切換開啟時使用。這些函式包括 withKeysDownwithKeysToggled 等。另外也加入了可檢查特定中繼鍵是否無法使用的屬性,舉例來說,isCtrlDown 可檢查 Ctrl 鍵是否無法使用。如需各函式的文件,請參閱 KeyInjectionScope。(I9f6cdb/229831515)
  • 我們推出了實驗性 OverscrollEffect,可以支援自訂過度捲動功能,以及接受 Modifier.scrollable 的超載。
  • 實驗性 LocalOverScrollConfiguration 已從 foundation.gesture 移至基礎套件,並重新命名為「LocalOverscrollConfiguration」(If19fbb/204650733)
  • runComposeUiTestWithoutActivity {} 重新命名為 runEmptyComposeUiTest {},使其與 createEmptyComposeRule() 一致 (I6fed7)

1.2.0-beta03 版本

2022 年 6 月 1 日

androidx.compose.ui:ui-*:1.2.0-beta03 發布。1.2.0-beta03 版本包含這些修訂項目。

API 變更

  • 已將 pressKeyTimesisCapsLockOn 和好友新增至 KeyInjectionScope。此外,此 API 現也支援滑鼠和鍵盤的組合插入模式,例如按下含有中繼鍵的滑鼠按鈕。(I4c8dab/229831515)
  • 新增插入鍵事件支援。使用 performKeyInput 傳送鍵事件,或是在 performMultiModalInput 的多重模組輸入手勢中透過 MultiModalInjectionScopekey 屬性傳送這些事件。如需 API 的說明文件,請參閱 KeyInjectionScope。(Ic5000b/229831515)
  • 新增 GoogleFont.Provider.AllFontsListUri 以擷取 Android 支援的 Google Fonts 標準網際網路來源。
  • 改善 GoogleFonts 在撰寫時無法載入的錯誤訊息。(I0416c)

修正錯誤

  • InputEventChange 事件加入至速率追蹤器時,我們會考慮使用差異值而非位置,因此即使目標元素已移動,系統仍會確保所有案例的計算速度正確 (I51ec3b/216582726b/223440806b/227709803)
  • 現在只要將 Show Layout Bounds 設定套用至可快速設定圖塊的快速設定方塊,系統就會立即為可組合項套用設定,不必離開活動並重新輸入活動。(I843d5b/225937688)
  • 無障礙功能字串查詢不會觸發字型載入。之前如果 FontFamily.Resolver 遭到覆寫,系統就會嘗試載入 StyleSpans 的字型,並且造成當機。(I4609d)
  • 當游標移到文字欄位結尾時,按下向前刪除鍵就不會再當機。
  • 現在 DeleteSurroundingTextCommandDeleteSurroundingTextInCodePointsCommand 的建構函式引數不得為負數。(Ica8e6b/199919707)

1.2.0-beta02 版本

2022 年 5 月 18 日

發布 androidx.compose.ui:ui-*:1.2.0-beta021.2.0-beta02 版本包含這些修訂項目。

API 變更

  • 在其他預覽類型中提供重複使用功能 (I19f39)

修正錯誤

  • ViewCompositionStrategy.DisposeOnDetachedFromWindowIfNotInPoolingContainer 已重新命名為 DisposeOnDetachedFromWindowOrReleasedFromPool,以貼切反映棄置發生的情況,而不是棄置未發生的情況。(If15ca)

1.2.0-beta01 版本

2022 年 5 月 11 日

androidx.compose.ui:ui-*:1.2.0-beta01 發布。1.2.0-beta01 版包含以下修訂項目。

新功能

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

API 變更

  • 新增了實驗性的 BeyondBoundsInterval,可供 LazyList 的自訂實作用於版面配置範圍超出可見邊界的情況。(Ifabfbb/184670295)。
  • Modifier.composed 的索引鍵版本現在是穩定版 API。(Ie65e4b/229988420)
  • 簡化了 rememberNestedScrollConnection API,以便使用組合本機值取得目前檢視區塊資訊。(I67ca7)
  • @ComposableTargetMarker 註解和標示 @ComposableTarget 的註解現在可藉由加上 @file 前置字串,於檔案範圍使用。如果在檔案範圍使用目標註解,編譯器將假設檔案中的所有可組合函式都是用來指定相關 Applier。舉例來說,使用 @file:UiComposable 即等同於宣告所有 @Composable 函式皆指定 Compose UI Applier。如果函式需要指定其他 Applier,必須針對想指定的 Applier 明確提供目標標記註解。(I40804)
  • 推出了實驗性、獨立於平台的新測試 API:interface ComposeUiTestfun runComposeUiTest(block: ComposeUiTest.() -> Unit),可用來執行 Compose UI 測試,而不需要使用 TestRule。如要在不使用 ComposeTestRule 的情況下執行測試,請將測試以 lambda 形式傳遞至 runComposeUiTest,並使用接收範圍 ComposeUiTest 中的方法和成員 (跟 ComposeContentTestRule 中的完全相同)。

    新增了 Android 專用的 interface AndroidComposeUiTestfun runAndroidComposeUiTest(block: AndroidComposeUiTest.() -> Unit),可讓您存取基礎的 Activity,與 AndroidComposeTestRule 類似。如需更進一步的控制,您可以自行將 class AndroidComposeUiTestEnvironment 執行個體化。

    電腦版實作是 class DesktopComposeUiTest,但目前並未提供電腦版專用的執行函式。

    想將測試從 ComposeTestRule 遷移至 ComposeUiTest,可以參考下方的 Android 範例。從:

    @RunWith(AndroidJUnit4::class)
    class MyTest {
        @get:Rule val rule = createComposeRule()
        @Test
        fun test() {
            rule.setContent {
                Text("Hello Compose!")
            }
            rule.onNodeWithText("Hello Compose!").assertExists()
        }
    }
    

    到:

    @RunWith(AndroidJUnit4::class)
    class MyTest {
        @Test
        @OptIn(ExperimentalTestApi::class)
        fun test() = runComposeUiTest {
            setContent {
                Text("Hello Compose!")
            }
            onNodeWithText("Hello Compose!").assertExists()
        }
    }
    
  • 現階段,ComposeContentTestRuleComposeTestRule 不會從 ComposeUiTest 擴充,這表示在 TestRule 介面中還無法呼叫 ComposeUiTest 中的擴充功能函式。當 ComposeUiTest 升級為穩定版 API 後,ComposeContentTestRuleComposeTestRule 就會變成可從 ComposeUiTest 擴充。(Ib4e90)

  • LineHeightBehavior 已重新命名為 LineHeightStyle

  • LineVerticalAlignment 已重新命名為 LineHeightStyle.Alignment

  • LineHeightTrim 已重新命名為 LineHeightStyle.Trim

  • 移除了 LineHeightStyle 中的預設建構函式值。(I582bfb/181155707)

  • TextStyleSpanStyle 新增了 Brush,可讓您使用漸層顏色來繪製文字。(I53869b/187839528)

  • LineHeightBehaviortrimFirstLineToptrimLastLineBottom 屬性已變更為單一列舉:LineHeightTrimLineHeightTrim 擁有由兩個布林值定義的 4 種狀態值:FirstLineTopLastLineBottom、兩者和無 (Ifc6a5b/181155707)

  • TextStyleParagraphStyle 新增了 LineHeightBehaviorLineHeightBehavior 可控制是否要在第一行頂端和最後一行底端套用行高,以及定義 TextStyle(lineHeight) 所提供空間中的行對齊方式。

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

  • trimFirstLineTopincludeFontPadding 設定只有在 trimLastLineBottom 設定為 false 時才能正確運作。(I97332b/181155707)

  • PlatformParagraphStyle.lerpPlatformSpanStyle.lerp 函式變更為頂層函式。(I9a268)

修正錯誤

  • PointerInputChange::copy 說明文件現在會正確指出其為淺層複本。(I182f5)
  • 高度受限且無法納入所有文字行 (Ie528cb/168720622) 時支援刪節號
  • 啟用了預設的 includeFontPadding。您可以使用 TextStyle.platformTextStyle 屬性關閉 includeFontPadding。不久之後,我們將變更預設行為。但在此之前,此操作可讓我們以更好的方式整合行高改進 (aosp/2058653) 並解決 TextField 剪輯問題。(I01423b/171394808)

外部貢獻

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

1.2.0-alpha08 版本

2022 年 4 月 20 日

發布 androidx.compose.ui:ui-*:1.2.0-alpha081.2.0-alpha08 版包含以下修訂項目。

API 變更

  • pluralStringResource 函式加上實驗性質標示,以允許發展和進化,於日後支援更完善的國際化體驗。(If24e4)
  • Paragraph 和 MultiParagraph 現在接受 Constraints 參數。傳送 Constraints.maxHeight 目前為免人工管理,但未來會進行一些計算,例如根據高度進行刪節。(I6afeeb/168720622)
  • SubcomposeSlotReusePolicy.getSlotsToRetain() 可接受自訂 MutableSet 類別,不允許在其中新增項目。(Icd314)
  • PointerIcon 現在更名為 @Stable 介面 (I9dafe)
  • 已從 PointerInputChange 淘汰部分消耗功能 (減少或定位)。可使用 consume() 徹底使用變更。可使用 isConsumed 判斷其他使用者是否曾經使用過該變更。
  • PointerInputChange::copy() 現在會一律建立淺層複本。這表示只要使用一份複本,系統就會使用 PointerInputChange 的複本。如要建立未繫結的 PointerInputChange,請改用建構函式。(Ie6be4b/225669674)
  • 按照 Compose > View 方向,啟用 Compose 和 View 之間的巢狀捲動互通功能。這樣一來,Compose 父項即可從巢狀捲動檢視畫面接收巢狀捲動差異。(If7949b/174348612)
  • 新增 SemanticsProperty testTagsAsResourceId,用於讓 Compose 符合針對 View 系統設計的 UIAutomator 測試要求。(I39c20)
  • 使用 FontFamily.SansSerif 時,可在 Android 的系統字型中顯示所有可用權重。這會在 API 21-28 內部使用備用廣告字型名稱,例如 Santa-serif-medium。由於之前 API 21-28 上僅支援 400 和 700 粗細,因此這是行為變更。(I380feb/156048036b/226441992)
  • Paragraph 和 Multiparagraph 指示將位置引數重新排列至選用引數之前。(Idafaa)
  • AndroidFont 現在會採用 typefaceLoader 做為建構函式參數。(I2c971)

1.2.0-alpha07 版本

2022 年 4 月 6 日

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

API 變更

  • 新增 Snapshot.withoutReadObservation { ... } 函式。使用者可以透過該函式執行傳遞的 lambda,而無需訂閱在這個區塊中讀取的狀態值變更。如果您想利用以快照為基礎的安全執行緒寫入/讀取作業來提高成效,同時希望能夠在不造成不必要重組或重新測量的情況下讀取這個值,這項變更就非常實用 (I9f365b/214054486)
  • ComposeViewconsumeWindowInsets 擴充功能屬性可讓開發人員停用 Android WindowInsets 的消耗。這樣一來,階層中的個別 ComposeViews 就能分別套用 WindowInsets,不會彼此干擾。(I0ef08b/220943142)
  • KeyboardType.Decimal 新增為 Keyboard.Number 的替代項,專門用於在 IME 中加入小數分隔符。(Iec4c8b/209835363)
  • PointerEventType.ScrollPointerEvent.scrollDelta 現在是穩定的 API (I574c5b/225669674)
  • 針對合作執行的 View 類別,啟用 View 和 Compose 之間的巢狀捲動互通功能。這表示 Compose 現在可以將捲動差異調派給 (合作執行的) View 父項。(I5d1acb/174348612)
  • 更新 FontFamily.Resolver,以整合全系統中的粗體文字無障礙設定 (I6c1e7)
  • Font(AssetManager, String, ...) 已淘汰,並取代為 Font(String, AssetManager, ...)。這是一個實驗性 API。(I1c7a4)
  • 新增字型描述元 Font(DeviceFontFamilyName),可選擇在備用字型鏈中查詢系統已安裝的字型。(I30468b/219754572)
  • 為 TextStyle/ParagraphStyle 中的 includeFontPadding 新增臨時相容性設定。includeFontPadding 可以透過 TextStyle(platformStyle = PlatformTextStyle(includeFontPadding = true/false)) 變更。這是臨時設定選項,用來啟用遷移,將來會移除。(If47beb/171394808)
  • 新增 GoogleFont.Provider.isAvailableOnDevice 擴充功能以協助偵錯。(I64e31)
  • 新增 GoogleFont.Provider 建構函式,與 @ArrayRes 搭配使用 (Ic5ee1b/225984280)
  • Compose GoogleFont 現改名為 Font(GoogleFont),但 API 會保持穩定。(I125f2)

修正錯誤

  • 為 Material/Scaffold 新增 Lint 檢查,確保使用的是內部邊框間距 (Ifb111)

1.2.0-alpha06 版本

2022 年 3 月 23 日

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

API 變更

  • 新增 RequestFocus 語意動作,要求聚焦可聚焦的目標。(I17b71)
  • 更新向量可繪項目剖析,以支援自動鏡像,只要目前的版面配置方向為 RTL 就能翻轉 VectorPainter 的內容 (I79cd9b/185760237)
  • 將陰影/環境色彩更新為 Modifier.graphicsLayer 的結尾參數,確保 API 相容性 (I3f864b/160665122)

  • 針對 GraphicsLayerScope 中的陰影/環境色彩新增預設實作,確保進行非破壞性 API 變更

  • 在 RSB 事件中新增事件時間 (Ief8ae)

  • FocusOrder 現已合併至 FocusPropertiesfocusProperties() 現在具備 focusOrder() 的所有功能。FocusOrderfocusOrder() 已淘汰。focusOrder() 接受 focusRequester,應替換為 focusRequester() 輔助鍵,搭配 focusProperties() 使用。如此一來,輔助鍵就能更妥善地分隔問題。(I601b7)

  • 現在,如果同時升級 RecyclerViewCompose,可為包含 Compose 檢視區塊做為子項的 RecyclerView 大幅改善捲動效能。

  • 新增 ViewCompositionStrategy.Default 做為擷取內建預設策略的方法

  • 新增 ViewCompositionStrategy.DisposeOnDetachedFromWindowIfNotInPoolingContainer,這是新的預設策略,可正確處理 RecyclerView 等集區容器。(If7282)

  • 新增支援使用 @Preview 為註解類別加上註解,這是新增 Multipreview 功能的第一步。這類註解可加註於可組合方法或其他註解類別,這樣這些方法或類別就能視為間接加上了指定的 @Preview 註解。(I12eff)

  • 在 @Preview 裝置清單中新增參照裝置 (I071c9)

修正錯誤

  • 更新向量圖形 API,以便使用適當的可組合註解 @VectorComposable,而非 @UiComposable (I942bc)
  • AnnotatedString.Builder.withStyle 中移除 crossinline (If84d5)

外部貢獻

  • compose-ui:在 GraphicsLayerScope 中新增 ambientShadowColorspotShadowColor 屬性 (I1ba1ab/160665122)
  • 現在起,透過 pluralStringResource 函式支援複數資源。(Ib2f23b/191375123)

1.2.0-alpha05 版本

2022 年 3 月 9 日

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

API 變更

  • TextToolbar 現在會以 lambda 引數取代 ActionCallback,(Ib2eb9b/197950089)。
  • 根據 Tiramisu DP2 (I0cbb7) 更新核心和應用程式的空值
  • 經過測量的介面現在會顯示 parentData 屬性 (I3313f)
  • Modifier.onPlacedOnPlacedModifier 介面現已穩定運作。(Ib5482)
  • 太棒了!現在 Compose 動畫支援「開發人員選項」中的「動畫影片長度比例」設定。(I5a4fcb/161675988)。
  • 已新增 BeyondBoundsLayout 修飾詞 (If8b51b/184670295)
  • 文字:includeFontPadd 目前預設為停用狀態。系統會處理 includeFontPadding=false 造成的剪輯問題,而不會針對較高指令碼執行剪輯。(I31c84b/171394808)。

修正錯誤

  • 如果您嘗試設定已有內容的內容,ComposeContentTestRule.setContent 現在會擲回 IllegalStateException。(I888a5b/199631334)
  • 修正在 Android 上讀取剪貼簿時,由剪貼簿內容造成的當機問題。(I06020b/197769306)
  • 改善 RSB 滾動樣本。(I6a596)

外部貢獻

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

1.2.0-alpha04 版本

2022 年 2 月 23 日

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

API 變更

  • 新增了 ComposableTargetComposableTargetMarkerComposableOpenTarget,這樣如果所呼叫的可組合函式指定了不適用的 Applier,就能在編譯時回報。

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

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

  • Font(resId, ...) 現在可以在 穩定版 API 上使用 loadStrategy。(Ief3d2)

  • FontLoadingStrategy 現在是穩定版 API。(I1ee35b/174162090)

  • 支援在 Text 中載入非同步字型。(I77057b/214587005)

  • 新增 Bridge API,可將自訂 Font.ResourceLoader 轉換成 FontFamily.Resolver。(Ia0060)

修正錯誤

  • 提供 FontFamily.Resolver 會傳送至子元件,例如彈出式視窗。
  • 提供 Font.ResourceLoader 會傳送至子元件,例如彈出式視窗。(I48fa5)

1.2.0-alpha03 版本

2022 年 2 月 9 日

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

API 變更

  • TextInputSessionTextInputService 中的 notifyFocusedRect 方法現已淘汰,且不會呼叫。請改用 BringIntoViewRequester (Ia4302b/192043120b/216842427b/178211874)。
  • RenderNode 虛設常式類別中加入 destroyDisplayListData 方法 (I1e659b/216660268)
  • 加入新的 API,可預先評估您預先撰寫的 SubcomposeLayout 子項。(I857ea)
  • 新增了 movableContentOf,能夠將可組合 lambda 轉換為 lambda 函式,把其狀態和對應節點移至任何呼叫該 lambda 的新位置。如果先前的呼叫離開組合,狀態會暫時保留,如果對 lambda 的新呼叫進入組合,狀態和相關聯的節點就會移至新呼叫的位置。如未新增新呼叫,系統會永久移除對應的狀態。同時別忘了,觀察器會收到相關通知。

    如果在相同組合中多次呼叫 movableContentOf lambda,系統會為每個呼叫建立新的狀態和節點。隨著呼叫退出組合及新呼叫進入組合,系統會按照呼叫順序,將對應的狀態從第一個退出的呼叫移至隨後進入的呼叫。系統會永久移除新呼叫未宣告的所有狀態。(Ib4850)

  • FontFamilyResolver 現可透過 LocalFontFamilyResolver.current 使用

  • 已新增 createFontFamilyResolver(context)createFontFamilyResolver(context, coroutineScope),以便在撰寫用途外建立新的 FontFamily 解析器。

  • Paragraph 和 MultiParagraph 現在採用 FontFamily.Resolver

  • TextLayoutResult.layoutInput.fontFamilyResolver 現在包含此版面配置使用的解析器,並由於 TextLayoutResult.layoutInput.resourceLoader 已不再使用而已經淘汰 (Id5a45b/174162090)。

  • 支援非同步和選用字型載入,並支援備用行為。這個文字由 Text 和 TextField 使用,並透過 FontFamilyResolver 公開

  • 支援透過 FontFamilyResolver.preload 預先載入字型

  • FontFamilyResolver.setAsyncLoadContext 可讓您設定用於載入非同步字型的全域處理常式結構定義。(I87fe8b/174162090)

  • 加入新的低階 API AndroidFont,為 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)

  • 接受 maxSlotsToRetainForReuseSubcomposeLayoutState 建構函式現已淘汰。但現在,我們加入了新的架構:SubcomposeSlotReusePolicy - 新版介面可讓您進一步控制要保留哪些運算單元供日後重複使用。(I52c4d)

  • Color 中的 HSV 和 HSL 函式公開為非實驗 API。Oklab 色域現已改為公開 API。(I08fb6b/180731008)。

  • 已經淘汰的 AndroidComposeTestRule.AndroidComposeStatement 並非公開 API,且不會採取任何行動。(Ibc46b)

  • 內部產生的 kt 類別重新命名 (Ia0b9eb/174162090)

  • 已移除FontLoadingStrategy.values (I42a9db/174162090)

  • 全域字型載入器現在稱為 FontFamilyResolver。(I4f773b/174162090)

  • 使用電腦版的新字型載入系統。(I9ce5cb/174162090)

  • FontFamily.Resolver.resolve 會傳回 State<Any> (I4406cb/174162090)

修正錯誤

  • 現在焦點在鍵盤上時,焦點欄位會保持在鍵盤上方,當輸入模式設為 ADJUST_PAN 時,則會顯示鍵盤。(I8eaebb/190539358b/192043120)。
  • 電腦使用 FontFamily.Resolver 的本機元素
  • 電腦版 FontLoader 已經淘汰
  • 電腦版適用的新 createFontFamilyResolver 工廠 (I6bbbbb/174162090)
  • 切換文字欄位時,螢幕鍵盤輸入類型不會再閃爍。(I1bf50b/187746439)。

1.2.0-alpha02 版本

2022 年 1 月 26 日

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

API 變更

  • 新增具有旋轉側邊按鈕的穿戴裝置 (Modifier.onRotaryScrollEvent()Modifier.onPreRotaryScrollEvent()) (I18bf5b/210748686)
  • 新增實驗性 View.createLifecycleAwareRecomposer 擴充功能 (I0cde6)

外部貢獻

  • PointerEvent.scrollDelta.y 現在可在 Android 上反轉 (現在將滑鼠滾輪往右移,會傳回 1,而非 -1) (Ia9811)

1.2.0-alpha01 版本

2022 年 1 月 12 日

發布 androidx.compose.ui:ui-*:1.2.0-alpha011.2.0-alpha01 版本包含以下修訂項目。

API 變更

  • FontFamily.canLoadSynchronously 已淘汰。這個屬性沒有語意含義。(Ica5ef)
  • 將 ID 欄位新增至 CompositionData,以在版面配置檢查器中產生不變的 ID。(Ic116e)
  • 已將 Wear OS 裝置 ID 新增至預覽裝置清單 (I93232)

依附元件更新

  • 現在依附於 Kotlin 1.6.10

1.1 版本

1.1.1 版本

2022 年 2 月 23 日

發布 androidx.compose.ui:ui-*:1.1.11.1.1 版本包含以下修訂項目。

修正錯誤

1.1.0 版本

2022 年 2 月 9 日

發布 androidx.compose.ui:ui-*:1.1.01.1.0 版本包含以下修訂項目。

自 1.0.0 版本以來的重要異動

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

1.1.0-rc03 版本

2022 年 1 月 26 日

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

修正錯誤

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

1.1.0-rc01 版本

2021 年 12 月 15 日

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

修正錯誤

  • 修正導致無障礙捲動操作失敗的錯誤 (I7cbfb)
  • 如果 HardwareRenderer.isDrawingEnabled()false,只要在呼叫期間啟用,SemanticsNodeInteraction.captureToImage() 也能正常運作 (Idf3d0)

1.1.0-beta04 版本

2021 年 12 月 1 日

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

新功能

  • 已更新為與 Kotlin 1.6.0 相容

API 變更

  • 清除 androidx.core.view 中的空值 (I7078ab/204917439)
  • 新增實驗性 API,可讓使用者將整個端點使用 PointerInputchange 或確認是否已被使用。(I2e59d)
  • 新增 UI 圖層中滑鼠滾輪事件的支援。(Ia14ebb/198214718)。
  • 新增實驗性 Modifier.composed 超載,允許索引鍵進行相等性的比較,而且符合略過最佳化的資格。(Ice799b/205851704)
  • ComposeNotIdleException 現在由 Exception 擴充,而不是直接由 Throwable。請注意,這表示原本擷取 Exception 的擷取子句現在可能會擷取 ComposeNotIdleException,而這些子句先前針對類似情況並不會這麼做 (I9c217)

修正錯誤

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

1.1.0-beta03 版本

2021 年 11 月 17 日

發布 androidx.compose.ui:ui-*:1.1.0-beta031.1.0-beta03 版本包含這些修訂項目。

API 變更

  • 新增修飾詞 Modifier.onPlaced,藉此觀察位置變更。您可以根據觀察到的位置變更,對子項修飾詞的偏移進行額外變更。(I558fd)
  • 已移除 InjectionScope.flush()InjectionScope.dispose()。所有事件的清除和處理範圍的棄置現在會透過已呼叫的 Run*Input() 方法結尾。(I2bed8)
  • 已移除 MultiModalInjectionScope.TouchMultiModalInjectionScope.Mouse。如要插入多模式手勢的觸控和滑鼠事件,現在您可以使用 MultiModalInjectionScope.touch()MultiModalInjectionScope.mouse(),而這兩種都接受使用有該形式接收器範圍的 lambda (Idde18)。

修正錯誤

  • 系統現在會計算 TouchInjectionScope.swipeWithVelocity 中的 durationMillis 預設值,以執行滑動操作。(I19deb)

1.1.0-beta02 版本

2021 年 11 月 3 日

發布 androidx.compose.ui:ui-*:1.1.0-beta021.1.0-beta02 版包含這些修訂版本。

API 變更

  • 新增了實驗性的 BringIntoView API,可讓您傳送要求給父項,請父項透過捲動將項目帶入檢視區塊。(Ib918db/195353459)
  • 新增支援工具的 Animation API。具體來說,這類 API 可讓工具檢查轉換中的動畫和動畫設定。(I4116e)

外部貢獻

  • 新增 Modifier.pointerHoverIcon (I95f01)

1.1.0-beta01 版本

2021 年 10 月 27 日

發布 androidx.compose.ui:ui-*:1.1.0-beta011.1.0-beta01 版本包含這些修訂項目。

API 變更

  • 新增實驗性 BringIntoView API,讓您可以傳送要求至父項,使其可捲動項目至檢視畫面中 (Ib918db/195353459)
  • 新增支援工具的 Animation API。具體來說,這類 API 可讓工具檢查轉換中的動畫和動畫設定。(I4116e)

1.1.0-alpha06 版本

2021 年 10 月 13 日

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

API 變更

  • ViewRootForInspectorLayoutInfo.ownerViewId 移除 ExperimentalComposeUiApi (I5c2e3)
  • 已新增版面配置 (不含子元素) 以增加效率 (Ib0d9a)
  • 將必須從跨模組呼叫的 Composer 方法中移除 InternalCompilerApi (I1aa0b)
  • SemanticsNodeInteraction.performSemanticsAction 現在會傳回呼叫該函式的 SemanticsNodeInteraction (I9e5db)
  • 新增 LocalInputModeManager CompositionLocal 以偵測 TouchMode/NonTouchMode。(I6a83cb/175899786)
  • 已新增 viewConfiguration: ViewConfigurationLayoutInfo,讓取用端可取得長按逾時等的正確值。(I76ca6)
    • 新增 InjectionScopeviewConfiguration: ViewConfiguration,讓測試能夠根據長按逾時或觸控界區等因素調整插入輸入內容。
    • 根據 InjectionScope.viewConfiguration 中的值,針對觸控和滑鼠輸入調整了長按和輕觸兩下操作的預設時間長度。
  • 根據 ExposedDropdownMenuBox 的 ExposedDropdownMenu 實作,且內部有 TextField 和 DropdownMenu (If60b2)
  • 向 PopupProperties 新增 dismissOnOutClick,取代已淘汰的 dismissOnClickExternal。新屬性可接收點擊位置與錨點邊界,讓您能夠更精細地控制是否要叫用 onDismissRequest。舉例來說,如果想防止錨點因輕觸到而關閉,這就能派上用場。
    • updateAndroidWindowManagerFlags 已新增至 PopupProperties,以低階的方式控制從彈出式視窗傳送給 Android WindowManager 的標記。lambda 的參數則是從產生 WindowManager 標記的 PopupProperties 值計算得出的標記:例如 focusable。lambda 的結果將是最終標記,並會傳遞給 Android WindowManager。根據預設,updateAndroidWindowManagerFlags 不會變更以參數計算的標記。此 API 僅可於彈出式視窗有非常具體的行為規定時使用,因此請謹慎使用 (I6e9f9)
  • Recomposer.state 已經淘汰,並由 Recomposer.currentState 取代,將類型變更為 StateFlow (Ic2ab3b/197773820)
  • 已新增 flush()dispose()InjectionScope。如果要立即清除所有排入佇列的事件,或要處理範圍,即可使用。(Ifb73a)
  • 新增了 performScrollToNode(matcher: SemanticsMatcher),這會根據指定配對工具的配對結果,將可捲動的容器捲動至配對內容。(Ic1cb8)
  • InjectionScope 現已導入 Density,允許您在 performTouchInput 和好友之間輕鬆轉換 px 和 dp。(I8fe1f)

修正錯誤

  • AndroidView 現在會透過 ViewTreeLifecycleOwner 和 ViewTreeSavedStateRegistryOwner 將 LocalLifecycleOwner 和 LocalSavedStateRegistryOwner 傳輸到檢視畫面中。(I38f96b/179708470)
  • 修正 WearOS SwipeToDismissBox 有時無法處理滑動手勢的問題。(I9387e)
  • 插入輸入事件之間的預設時間已從 10 毫秒變更為 16 毫秒。這項操作會變更執行輸入手勢的測試結果,例如特定滑動。(I829fd)

1.1.0-alpha05 版本

2021 年 9 月 29 日

發布 androidx.compose.ui:ui-*:1.1.0-alpha051.1.0-alpha05 版本包含以下修訂項目。

API 變更

  • 新增修飾詞之間通訊的支援 (Id5467b/198826874)
  • 將實驗性的歷來指標新增至 PointerEventChange。(Ic1fd8b/197553056b/199921305)。
  • density: DensitylayoutDirection: LayoutDirection 新增至 LayoutInfo。這樣 LayoutInfo 的取用端就能正確解讀 LayoutInfo 中顯示的維度和位置。(I002f1)
  • 新增插入滑鼠事件的實驗性支援。使用 performMouseInput 即可開始傳送滑鼠事件,或在使用 performMultiModalInput 的多模組輸入手勢期間,透過 MultiModalInjectionScopeMouse 屬性傳送滑鼠事件。如需可用 API 的說明文件,請參閱 MouseInjectionScope。(Iaa4a8b/190493367)。

修正錯誤

  • 修正了可捲動元件 (包括延遲和非延遲) 在捲動方面的無障礙功能支援 (I6cdb0)
  • 已改善 TouchInjectionScope.swipeWithVelocity。現在可接受更廣泛的輸入變數,但如果無法建立滑動手勢,系統會建議輸入的內容 (I40fbeb/182477143) )

1.1.0-alpha04 版本

2021 年 9 月 15 日

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

API 變更

  • PointerEvent 現在有 PointerEventType,可支援懸停事件。(I091fa)
  • 允許子項接受父項指標輸入範圍以外的指標輸入資料。父項可以使用屬性 PointerInputScope.alwaysInterceptChildEvents 攔截呼叫 (I9eae3b/192479655)
  • 已淘汰 performGestureGestureScope,並已由 performTouchInputTouchInjectionScope 取代。(Ia5f3fb/190493367)。
  • 已將 touchBoundsInRoot 加入至含有最低觸控目標尺寸的 SemanticsNode,讓開發人員能夠確保觸控目標符合無障礙功能的最低要求。(I2e14bb/197751214)。
  • 重做可檢查實作 (I927bcb/191017532)
  • 將可檢查的參數名稱變更為組合 (I3a482, b/191017532)
  • 採用 performTouchInputTouchInjectionScope 做為 performTouchInputTouchInjectionScope 的替換方法,藉此提供其他模式 (例如滑鼠)。

    TouchInjectionScopeGestureScope 採用的方法相同,但 movePointerTomovePointerBy 除外,系統會將其重新命名為 updatePointerToupdatePointerBy。所有其他方法都相同。

    TouchInjectionScope 的行為幾乎與 GestureScope 相同,只有兩個小細節:

    1. 傳送下移事件的同時,如果指標在未傳送移動事件的情況下移動 (也就是使用了 updatePointerTo(),但未使用 move(),然後呼叫 down()),先前的實作會將事件時間提前並傳送移動事件,然後再傳送下移事件。新的導入作業仍會傳送移動事件,但在這個特定情境中並不會延後事件時間。
    2. 傳送上移事件的同時,如果指標在未傳送移動事件的情況下移動 (與上述情況類似),先前的實作會將事件時間提前並傳送移動事件,然後再傳送上移事件。新的實作方式都不會改變:指標的新位置只會透過上方的事件反映。

    最後,TouchInjectionScope 會採用新的方法 currentPosition(pointerId: Int) 來取得指定指標的目前位置。(If1191b/190493367)。

修正錯誤

  • 在剪輯時,允許觸控目標邊界超出剪輯區域,以符合最小觸控目標要求 (I43e10b/171509422)。
  • 在 Android 12 裝置中新增延伸越區捲動支援 (Iccf3cb/171682480)

1.1.0-alpha03 版本

2021 年 9 月 1 日

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

新功能

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

API 變更

  • 已新增 Modifier.inspectable 以納入其他修飾詞。(I1909bb/191017532)
  • 新增 BlurredEdgeTreatment API,以簡化剪輯作業的用途,並結合常用的短片標記和 TileModes 組合。最常見的用途有二,一種是讓模糊處理的內容顯示在原始內容邊界外,並以透明黑色模糊處理這些邊界外的區域,另一種是針對擴展至內容邊界外的模糊處理核心,將內容依據包含最近邊緣取樣的內容邊界進行剪輯。(I6b4b7b/166927547)。
  • 在 Compose 電腦版中新增了 RenderEffect 支援。 推出 OffsetEffect 以及模糊處理修飾詞,讓您可輕鬆地為一部分的組合階層導入模糊視覺效果 (I0f6aab/166927547)
  • 推出 Renderimpact API,您可以在 Modifier.graphicsLayer 上加以設定,以變更圖層本身的內容。這可用於模糊處理可組合項的內容,以及組合階層中的子項可組合項。(I47c4db/166927547)。
  • AwaitPointerEventScope 現在支援 withTimeout() 和 withTimeoutOrNull() (I507f0b/179239764b/182397793)
  • 為 ViewConfiguration 新增了最小觸控目標尺寸,適合用於語意和指標輸入內容,以實踐無障礙設計 (Ie861c)
  • 新增 TileMode.Decal 支援,可用於定義邊緣式的 RenderAction 的邊緣行為。(I7e8edb/166927547)
  • performScrollToIndexperformScrollToKeyhasScrollToIndexActionhasScrollToKeyAction 現已改為穩定 API (I142aeb/178483889)
  • 已新增測試方法,以取得裁剪範圍。(I6b28e)

修正錯誤

  • 已從 FabricredEdgeTreatment 中移除了 Bounded 方法,以便明確檢查形狀參數是否為空值。(I85d68)

1.1.0-alpha02 版本

2021 年 8 月 18 日

發布 androidx.compose.ui:ui-*:1.1.0-alpha021.1.0-alpha02 版本包含這些修訂項目。

API 變更

  • PointerEvent 現在支援讀取滑鼠按鈕狀態和鍵盤修飾詞狀態。(I6310cb/180075467)。
  • 插入的手勢現在使用 MainTestClock 的時間做為可靠資料來源。系統會將 performGesture 中插入事件的目前時間初始化為 MainTestClock 的目前時間。(Ifb364b/192064452)
  • 新增了 DpRect(DpOffset, DpSize) 建構函式 (I2cf16b/194219828)
  • 新增 DpSize 類別 (I7abb1b/194219828)

修正錯誤

  • 更新 Vector 圖形 xml 剖析功能,以支援 ColorStateLists 做為 VectorDrawables 上的根色彩色調屬性。(I86915b/195668138)。

1.1.0-alpha01 版本

2021 年 8 月 4 日

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

API 變更

  • RelocationRequester.bringIntoView 現在接受矩形參數做為參數,可讓系統將一部分的元件納入檢視畫面中 (Ice2c5b/194330245)
  • AnimatedImageVector 和相關 API 現已新增至新的 androidx.compose.animation:animation-graphics 模組。(I60873)
  • 已新增實驗性修飾詞,可處理重新配置請求。(I65a97b/178211874)
  • 推出 BrushPainter API,支援在 PaintPall 中繪製任意筆刷,類似 ColorPainter

    更新 Brush API,以在 BrushPainter (Ia2752b/189466433) 中查詢的內建大小參數

  • 已更新 DrawScope#drawImage 方法,並採用來源和目的地矩形,以使用選用的 FilterQuality 參數。這適合用於放大以像素為基礎的圖片進行像素化的像素藝術。 更新 BitmapPainter + Image 可組合項,也可使用選用的 FilterQuality 參數 (Ie4fb0b/180311607)

  • 新增 GestureScope.advanceEventTime 方法,以便進一步掌控手勢中的事件時間 (Ibf3e2)

修正錯誤

  • 為針對繪製修飾詞鏈結提供更完善的支援,請務必在 Modifier.paint 實作中呼叫 drawContent。以往我們會將 Modifier.paint 加在修飾詞鏈結的分葉節點中,但是這種操作會導致 Modifier.paint 無法在可組合項容器 (例如:Box) 上設定,或在 Modifier.paint().border() 等之上添加其他修飾。現在,我們讓 Modifier.paint 在繪製指定 Painter 的內容後呼叫 drawContent,這樣就能提升修飾詞模式中的行為一致性 (Ibb2a7b/178201337b/186213275)。
  • 對話方塊現在會遵循平台大小行為。將 usePlatformDefaultWidth 設為 false,即可覆寫這個行為 (Iffaedb/192682388)。
  • 已將 InfiniteAnimationPolicy 移至 :compose:ui (I5eb09b/160602714)
  • 現在透過語意操作捲動延遲清單和一般捲動式元件時會呈現動畫效果 (Id9066b/190742024)

1.0 版本

1.0.5 版本

2021 年 11 月 3 日

發布 androidx.compose.ui:ui-*:1.0.51.0.5 版本包含以下修訂項目。

修正錯誤

  • 已修正追蹤 derivedStateOf 例項時的當機問題。(aosp/1792247)。

1.0.4 版本

2021 年 10 月 13 日

發布 androidx.compose.ui:ui-*:1.0.41.0.4 版本包含以下修訂項目。

依附元件更新

  • 已更新為依附 Kotlin 1.5.31

1.0.3 版本

2021 年 9 月 29 日

發布 androidx.compose.ui:ui-*:1.0.31.0.3 版本包含以下修訂項目。

依附元件更新

  • 已更新為依附 Kotlin 1.5.30

1.0.2 版本

2021 年 9 月 1 日

發布 androidx.compose.ui:ui-*: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.ui:ui-*:1.0.11.0.1 版本包含以下修訂項目。

依附元件更新

  • 已更新為依附 Kotlin 1.5.21

1.0.0 版本

2021 年 7 月 28 日

發布 androidx.compose.ui:ui-*:1.0.01.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.ui:ui-*:1.0.0-rc021.0.0-rc02 版包含以下修訂項目。

修正錯誤

  • 對話方塊現在會遵循平台大小行為。將 usePlatformDefaultWidth 設為 false,即可覆寫這個行為 (Iffaedb/192682388)。

1.0.0-rc01 版本

2021 年 7 月 1 日

發布 androidx.compose.ui:ui-*:1.0.0-rc011.0.0-rc01 版本包含以下修訂項目。

新功能

  • 將 ui-tool 模組分割為 ui-toolingui-tooling-preview (Iefa28b/190649014)

API 變更

  • 已移除淘汰的實驗性 FocusManager#moveFocusInFocusManager#moveFocusOut (I227d7b/170154986b/186567354b/168510304))
  • Canvas 現已支援 contentDescription 參數來進行無障礙功能。(Ib547c)
  • useDefaultMaxWidth 中的 PopupProperties 已重新命名為 usePlatformDefaultWidth。(I05710)。
  • 對話方塊現在可使用整個螢幕寬度 (I83929b/190810877)。
  • 新增 HSV 和 HSL 色彩表示法的實驗性支援。 (Id7cf8b/180731008)。

行為變更

  • @Preview 現在提供 LocalActivityResultRegistryOwner,可讓您預覽使用 rememberLauncherForActivityResult() 等 API,且與現有擁有者有關的可組合項。(Ib13d1b/185693006)。
  • Compose @Preview 現在提供 LocalOnBackPressedDispatcherOwner,可讓您預覽使用 BackHandler 等 API,且依附於現有擁有者的依附元件。(Ia1c05b/185693006)

修正錯誤

  • 已將 InfiniteAnimationPolicy 移至 androidx.compose.ui:ui (I5eb09b/160602714)
  • 為了變更模組結構,系統已暫時停用 AnimatedImageVector。(I41906b/160602714)

1.0.0-beta09 版本

2021 年 6 月 16 日

發布 androidx.compose.ui:ui-*:1.0.0-beta091.0.0-beta09 版本包含以下修訂項目。

API 變更

  • 使用不公開建構函式將列舉角色和 LiveRegionMode 變更為內嵌類別 (Id1890)
  • KeyboardCapitalization 會轉換為內嵌類別。(Id5a1c)
  • 將 HapticfeedbackType 變更為內嵌類別。(I255ec)
  • Modifier.pointerInteropFilter 是 @experimentComposeUiApi。(Iede6c)
  • TextAlign、FontSynthesis 和 TextDirection 現為內嵌類別。(I212fe)
  • TextOverflow 已變更為內嵌類別。(I433af)
  • FontStyle 現在是內嵌類別。(I9e48b)

修正錯誤

  • 目前索引鍵常數為 @experimentComposeUiApi。穩定之前,使用程式碼可宣告不公開常數。(Ia5d48)
  • Compose 測試現可於 Robolectric 上執行。目前已找出以下限制:
    • 由於沒有原生點陣圖,因此 ImageBitmap() 會導向 NullPointerException
    • 因為沒有任何繪圖,所以 captureToImage() 會無限期地等待下一個繪圖許可 (也就是無法解鎖)。
    • 未載入任何字型,因此系統無法正確測量任何文字。所有字元的固定高度約 20 像素,寬度為 1 像素。
    • ComposeTestRule.waitUntil {} 在等待期間不會執行主執行緒,因此大致跟 ComposeTestRule.mainClock.advanceTimeUntil {} 相同。 我們預計日後會找到更多限制。(I284fa)

新增的設定檔規則

這個版本將設定檔規則新增至下列撰寫模組 (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.ui:ui-*:1.0.0-beta081.0.0-beta08 版本包含以下修訂項目。

API 變更

  • NestedScrollSource 列舉是由內嵌類別取代。(Ie321bb/187055290)
  • FocusManager.clearFocus(forcedClear = true) 已重新命名為 FocusManager.clearFocus(force = true) (Ia0c41)
  • 將列舉用例重構為內嵌類別,以避免完整的 when 陳述式在新增列舉值後出現問題。(I2b5eb)
  • PopupProperties 移除 @ExperimentalComposeUiApi。(I01fa6)
  • PointerType」已從列舉變更為內嵌類別 (If5058)
  • ContentDescription 和 Text 語意屬性不再只是單一值,而是清單。如此即可直接合併,無需串連。同時也提供更優質的測試 API,以善用這些異動 (Ica6bfb/184825850)。
  • 淘汰了 Modifier.focusModifier(),改用 Modifier.focusTarget()。(I6c860)
  • Modifier.onSizeChanged()Modifier.onGloballyPositioned() 已不再為內嵌函式 (I727f6b/186109675)
  • KeyboardType 列舉是由內嵌類別取代。(I73045b/187055290)
  • FocusState 列舉已改為 FocusState 介面 (Iccc1ab/187055290)。
  • ImeAction 列舉已由內嵌類別取代。(I18be5b/187055290)
  • PlaceholderVerticalAlign 會轉換為內嵌類別。(If6290)
  • TextUnitType 現在是內嵌類別。(I4cba9)
  • AnnotatedString.withAnnotation 函式現在是 ExperimentalTextApi,而非 ExperimentalComposeApi。(I0cd0a)
    • 採用 TextUnitType 的 TextUnit 建構函式現在是 ExperimentalTextApi,而非 ExperimentalComposeApi。

修正錯誤

  • 已修正 Beta 版 7 版導入的漏洞,因為捲動畫面後顯示 LazyColumn/Row 項目僅有部分顯示 (I8c9acb/188566058)
  • 現在,detectDragGesuresdetectVerticalGesturesdetectHorizontalGestures 會自動使用位置變更,不需要在 onDrag 回呼中呼叫 change.consumePositionChange (I42fc4, b/185096350)b/187320697)
  • 提供對齊線的 LayoutModifiers 是固定的。修正子項對齊線變更會導致無法重新測量父項的錯誤。(I4401fb/174315652)。
  • 已變更 Modifier.onGloballyPositioned(),系統會回報此修飾詞在修飾詞鏈結中的座標,而非套用所有修飾詞後的版面配置座標。也就是說,修飾詞的排序現在會影響系統回報的座標 (Ieb67db/177926591)。

1.0.0-beta07 版本

2021 年 5 月 18 日

發布 androidx.compose.ui:ui-*:1.0.0-beta071.0.0-beta07 版本包含以下修訂項目。

API 變更

  • 新增用於檢查器的 ViewRootForInspector 介面 (Ib70df)
  • SubcomposeLayoutState 現可支援可重複使用的運算單元數量。 版面配置會維持在有效計數中,而非丟棄,改為在下次需要新版位時重複使用 (Ieb981)
  • KeyEventType enum 是由內嵌類別取代。(Id670ab/187055290)
  • FocusDirection 列舉是由內嵌類別取代。(Ib6d03b/187055290b/184086802)。
  • 推出可拉高 SubcomposeLayout 狀態的功能,讓您預先組合內容並傳遞至必要的 slotId,這樣下次只要使用指定 slotId 建立子組合,就能略過組合程序,進而更快速地傳遞測量結果。(I42580b/184940225)。
  • 新增剪輯片段選取控點 (Iff80db/183408447)
  • 移除與 LayoutCheckor 支援相關聯的未使用的 API。(I2ac78)

修正錯誤

  • LazyColumn/Row 現在會保留最多 2 個先前顯示項目的有效狀態 (而非加以丟棄),即使這些項目已被捲出畫面也一樣。這樣一來,當我們需要組合新項目時,這個元件就能重複使用有效的子組合,藉此提升捲動效能。(Ie5555)
  • TextGeomerticTransformTextDecorationAnnotatedString 將套用指定的名稱。(I61900b/184760917)。

1.0.0-beta06 版本

2021 年 5 月 5 日

發布 androidx.compose.ui:ui-*:1.0.0-beta061.0.0-beta06 版本包含以下修訂項目。

API 變更

  • 解決導覽手勢相關衝突。(I1145e)
  • @ComposeCompilerApi」已不再使用「@RequiresOptIn」(Iab690)
  • 新增了 CollectionInfo 和 CollectionItemInfo 無障礙服務 API,可為集合及其項目加上無障礙服務標示 (Id54efb/180479017)。
  • 新增 SemanticsActions.ScrollToIndex,可將含有索引項目的項目清單捲動到含有特定索引的項目,並新增 SemanticsProperties.IndexForKey 以取得包含索引鍵項目清單的項目索引。這兩個動作均是透過 LazyList 實作。
    • 新增 SemanticsNodeInteraction.performScrollToIndex 以將清單捲動至指定的索引,而 SemanticsNodeInteraction.performScrollToKey 則能將清單捲動到含有指定鍵的項目上。(I4fe63b/178483889b/161584524)。
  • 已將 ownerViewId 新增至 GraphicLayerInfo (I19f62)
  • 新增了 Font() 超載,可載入素材資源、File 和 FileDescriptor 中的字型 (I5d382)
  • 新增無障礙功能 API (error),以便標示含有無效輸入內容的節點 (I12997b/180584804b/182142737)
  • 新增 Font() 超載,以載入素材資源、File 和 File 描述元 (I43007) 的字型
  • 註解標記可將支援儲存至 TextFieldValue.Saver。已將 addTtsAnnotation 和擁有註解公用程式函式新增至 AnnotatedString.Builder (I8cbdcb/178446304)
  • 已新增 TextUnit 建構函式函式 TextUnit(value: Float, type: TextUnitType) (I7ecceb/178446304)

1.0.0-beta05 版本

2021 年 4 月 21 日

發布 androidx.compose.ui:ui-*:1.0.0-beta051.0.0-beta05 版本包含以下修訂項目。

API 變更

  • 已新增實驗性 FocusManager.moveFocus(In)FocusManager.moveFocus(Out) (Ic5534b/183746743)
  • 已新增實驗性 performTextInputSelection API (I2dcbbb/178510628)
  • InputEventCallback 介面已淘汰。 您無法在任何公用 API 中使用介面;程式碼也並未使用該程式碼。 (I34a02b/184003208)
  • 已淘汰 TextLayoutResult/createTextLayoutResult 函式。這是用於測試的未使用的公開函式 這項函式沒有任何用於編寫文字 API 的功能。函式目前已淘汰,稍後會移除。(I80413)

修正錯誤

  • 已修正 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.ui:ui-*:1.0.0-beta041.0.0-beta04 版包含以下修訂項目。

API 變更

  • SoftwareKeyboardController 中的 hideSoftwareKeyboardshowSoftwareKeyboard 分別重新命名為 hide()show()
    • 為 LocalSoftwareKeyboardController 提供完整的 CompositionLocal 介面,以便設定該物件 (在測試中特別實用) (I579a6)
  • 新增了 LiveRegion 無障礙服務 API。如果節點標示為即時區域,無障礙服務會自動向使用者發送該節點的異動通知。(Idcf6fb/172590946)
  • 介紹 TextOverflow.Visible。(Ic8f89)

修正錯誤

  • 修正了位於邊緣的 LazyColumn/LazyRow 項目在快速滑過操作後擺放位置不正確的問題 (Ie4d13b/183877420)
  • AndroidViewBinding 從 Compose 階層中移除時,AndroidViewBinding 現在會妥善移除透過 FragmentContainerView 加載的片段。(Ib0248b/179915946)
  • 現在,如果 ComposeView 位於 Fragment 內,AndroidViewBinding 會正確地為透過 FragmentContainerView 加載的片段建立巢狀結構,修正無法儲存及還原這些片段狀態的問題。(I70eb0b/179915946)。
  • 撰寫 ViewBinding 現在取決於片段 1.3.2,而現在在設定變更之後,還會持續顯示透過 FragmentContainerView 增加的片段。(I0743db/179915946)

1.0.0-beta03 版本

2021 年 3 月 24 日

發布 androidx.compose.ui:ui-*:1.0.0-beta031.0.0-beta03 版包含以下修訂項目。

API 變更

  • 延遲檢查 ComposeView 的 ViewTree 依附元件 (I8dbbfb/182466548)
  • 已將 startX/endXstartY/endY 選用參數新增至 swipeUp/swipeDown/swipeLeft/swipeRight 函式,GestureScope。(I49e2db/182063305)

1.0.0-beta02 版本

2021 年 3 月 10 日

發布 androidx.compose.ui:ui-*:1.0.0-beta021.0.0-beta02 版本包含以下修訂項目。

API 變更

  • 新增了 LocalSoftwareKeyboardController 組合本機 API,以取代 TextField 中的舊 SoftwareKeyboardController 介面。(I5951eb/168778053)
  • 新增了 LocalSoftwareKeyboardController 組合本機 API,以取代 TextField 中的舊 SoftwareKeyboardController 介面。(I84472b/168778053)。
  • 已移除下列 SemanticsMatcher
    • hasWidth(width, tolerance)
    • hasHeight(height, tolerance)
    • hasLeftPosition(left, tolerance)
    • hasTopPosition(top, tolerance)
    • hasRightPosition(right, tolerance)
    • hasBottomPosition(bottom, tolerance) (If16bd)
  • 將下列 SemanticsMatchers 標示為 @experimentTestApi:
    • hasWidth(width, tolerance)
    • hasHeight(height, tolerance)
    • hasLeftPosition(left, tolerance)
    • hasTopPosition(top, tolerance)
    • hasRightPosition(right, tolerance)
    • hasBottomPosition(bottom, tolerance) (Ia600c)
  • 新增下列 SemanticsMatcher
    • hasWidth(width, tolerance)
    • hasHeight(height, tolerance)
    • hasLeftPosition(left, tolerance)
    • hasTopPosition(top, tolerance)
    • hasRightPosition(right, tolerance)
    • hasBottomPosition(bottom, tolerance) (I2f502)

修正錯誤

  • 強制限制實驗 API 的公開使用行為 (I6aa29b/174531520)
  • androidx.compose.ui:ui」已不再取決於 AppCompat 或 Fragment。如果您在應用程式中使用 ComposeView,同時也使用 Fragment 和/或 AppCompat,請確保您使用的是 AppCompat 1.3 以上版本/Fragment 1.3 以上版本,這樣才能正確設定 ComposeView 必備的生命週期和已儲存狀態擁有者 (I1d6fab/161814404)。
  • 修正在導覽構成目的地中使用無效 rememberSaveable { mutableStateOf(0) } 的問題。(I1312bb/180042685b/180701630)
  • 新增了 LocalSoftwareKeyboardController 組合本機 API,以取代 TextField 中的舊 SoftwareKeyboardController 介面。(I658b6b/168778053)
  • 修正了 ComposeRootRegistrytearDownRegistry() 中極少發生的 NoSuchElementException (Iddce1)

1.0.0-beta01 版本

2021 年 2 月 24 日

發布 androidx.compose.ui:ui-*:1.0.0-beta011.0.0-beta01 版本包含以下修訂項目。

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

API 變更

  • 已將 StartStart 回呼新增至 detectDragGestures (I67269b/179995594)
  • 用於調整為內建函式的調節係數已失去實驗作用。(I15744)
  • MeasureBlocks 已重新命名為 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)。
  • 新增 AccessibilityMananger 介面和 CompositionLocals 的 LocalAccessibilityMananger (I53520)。
  • 移除了已淘汰的 LayoutCoordinate 方法;針對 positionInParent 和 boundsInParent,請使用函式取代屬性 (I580edb/169874631b/175142755)
  • 替換為基礎類型的 Typealias:
    • ColorStop 現在是 Pair<Float, Color>
    • SpanStyleRange 現在是「AnnotatedString.Range
    • ParagraphStyleRange 現在是 AnnotatedString.Range<ParagraphStyle>
    • StringAnnotation 現在是 AnnotatedString.Range<String>
    • (I8dd1a)
  • 為 CoreTextField 等低階文字元件的輸入工作階段建立新的 TextInputSession。(I8817fb/177662148)
  • 「位置」指標現在會顯示測距,代表子版面配置實際測量的大小。這個大小可能不受評估限制的影響。(Ib2729b/172560206b/172338608)
  • 新增 selectionGroup 修飾詞,可為 Tab 或 RadioButton 集合加上無障礙用途標示 (Ie5c29)
  • compositionLocalOfstaticCompositionLocalOfdefaultFactory 現在是必要元素,而非選用元素。

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

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

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

  • 淘汰 ui 模組的已淘汰方法 (I646f6)

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

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

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

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

  • imageResource 和 varResource 現已成為 ImageBitmap 和 ImageVector 隨播廣告的擴充功能函式。已刪除 load{Image,Vector,Font}Resource 個函式。(I89130)

  • 移除了 AnimationClockObservable 及其子類別。動畫動畫已移除。(Icde52b/177457083)。

  • 供應商已重新命名為 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)
  • ComponentActivity.setContent() 已從 compose:ui 中移除。請使用 androidx.activity:activity-compose:1.3.0-alpha01 中的設定。 已將 viewModel()LocalViewModelStoreOwner 從 compose:ui 中移除。請使用 androidx.lifecycle:lifecycle-viewmodel-compose:1.0.0-alpha01 提供的項目 (I6f36b)

  • Modifier.scrollable 經過重新設計。現在,這個應用程式使用捲動式介面,而非捲動式控制器類別 (I4f5a5b/174485541b/175294473)

  • 移除了 PointerInputModifier 的 CustomEvents 支援 (I02707b/175294473)

  • SnapshotStateObserver 已不再是實驗版 (Id2e6a)

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

  • longPressGestureFilter 和 DoubleClickSlideFilter 已移除。將 Modifier.pointerInput 與輔助函式搭配使用,例如 DetectionTapTouchs (I2fedfb/175294473)

  • 移除 String.format API,將多個 toString 方法重構使用,以防止內部使用 String.format。(Id1290)

  • 已移除 dp 判斷提示 (I798d2)

  • 已移除 androidx.compose.runtime:runtime-fulfillment (I55feb)

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

  • 已移除 runBlockingWithManualClock (I15cdcb/179664814

  • Modifier.verticalScroll()/水平 Scroll() 的捲動位置現在會以 Ints 表示 (I81298

  • FlingConfig 已重新命名為 FlingBehavior,現在可以自訂暫停動畫,而不是預先定義的衰減功能。(I02b86b/175294473)

  • 新增輔助函式,用於針對所有 ImeAction 回呼設定相同的動作 (I63447b/179226323)

  • 將 SoftwareKeyboardController 回呼從所有文字欄位中移除,很快就會推出新的 API 取而代之。(Iae869b/168778053)

  • FontSpan 和 FontWeigthStyleSpan 已不再使用且已經移除。(Ie5b56b/177423444)

  • 已進行下列 Material API 變更:

    • 已將 contentPAdding 參數新增至 Top/BottomAppBar,以自訂預設邊框間距。
    • 已依據 API 指南重新調整 BackdropScaffold 中的參數順序,將必要參數置於選用參數之前。
    • 已將 BottomNavigationItem 中的 icon 參數移至 selectedonClick 之後。
    • 已將 BottomNavItem 中的 alwaysShowLabels 參數重新命名為 alwaysShowLabel
    • 在幾個元件中將 bodyContent 參數重新命名為 content
    • 已將 ButtonDefaults.buttonColors() 中的參數重新排序。請注意,由於參數類型維持不變,因此不會造成您的程式碼產生錯誤。請務必使用具名參數或是手動更新順序,否則您的程式碼將無法正常運作。
    • 已將 secondaryVariant 參數新增至 darkColors()。此顏色通常與深色主題中的 secondary 相同,但新增這個參數是為了保持一致性和進一步自訂功能。
    • 因為這些項目不常用/實用,因此從公用 API 介面中移除 ElevationDefaults 和 animateElevation()。
    • 已將 Slider 中的 onValueChangeEnd 重新命名為 onValueChangeFinished,並將該值設為可為空值。
    • 為求一致,請將 Snackbar 中的 text 參數重新命名為 content
    • 已將 contentPadding 參數新增至 DropdownMenuItem,以自訂預設邊框間距,並將 content 設為 RowScope 的擴充功能。
    • ModalDrawerLayout 已重新命名為 ModalDrawer
    • BottomDrawerLayout 已重新命名為 BottomDrawer
    • (I1cc66)

修正錯誤

  • 新增 API,可在 Compose 中使用動畫類 VectorDrawable 資源。使用 animatedVectorResource 載入 <animated-vector> XML 做為 AnimatedImageVector,並以 PainterFor 新增該動畫 (I8ea91)
  • 新增了 LocalSoftwareKeyboardController 組合本機 API,以取代 TextField 中的 SoftwareSoftwareController 介面。(I658b6b/168778053)。

1.0.0-alpha12 版本

2021 年 2 月 10 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha121.0.0-alpha12 版本包含以下修訂項目。

API 變更

  • 移除 UiApplier 的 ViewGroup 支援。移除已淘汰的 emitView 可組合項。(Ifb214)
  • Modifier.pointerInput 目前規定 remember 鍵必須指出指標輸入偵測處理常式何時該重新啟動,以設定新的依附元件 (I849cd)。
  • CompositionReference 已重新命名為 CompositionContext (I53fcb)
  • 邊界已重新命名為 DpRect (I4b32a)
  • 測試更新:hasText() 會檢查文字欄位中的輸入和標籤/提示/預留位置文字 (Iab803)
  • viewModel() composable 和 LocalViewModelStoreOwner 已移至 androidx.lifecycle.viewmodel.compose 您現在需要新增個別的依附元件 androidx.lifecycle:lifecycle-viewmodel-compose:1.0.0-alpha01 才能使用。(I7a374)
  • 允許 AccessibilityAction 中的空值動作、將 AccessibilityAction 和 CustomAccessibilityAction 的動作標籤從 CharSequence 變更為 String (I0dc82)
  • 為使圖片更符合 ImageBitmap 和 ImageVector 的命名方式,ImagePainter 已重新命名為 BitmapPainter,以採用平行的 VectorPainter。(Iba381b/174565889)
  • 更完善的子字串測試 API (含子字串) 做為引數 (Icbe78)
  • 新增接受 FocusRequester 的 Modifier.focusOrder(),但未指定自訂焦點順序的 lambda。如果只需要指定參考資料,而不是可組合的自訂焦點順序時,這個功能就非常實用 (I4f52ab/179180978)
  • ComponentActivity.setContent 已移至 androidx.activity:activity-compose 模組中的 androidx.activity.compose.setContent (Icf416)。
  • Destructuring 和 copy() 方法在幾個類別中極少使用,現已將其從中移除 (I26702b/178659281)。
  • 彈出式視窗已移至特定平台。AndroidPopupProperties 已重新命名為 PopupProperties,isFocusable 已移至 PopupProperties 中的 focusable 參數 (Ieeea5)
  • 已將對話方塊移至特定平台。已將 AndroidDialogProperties 重新命名為 DialogProperties。(I4ef69b/179138130)。
  • Made LayoutNode (I8a7b1b/175103944)
  • Constraints.enforce 已由 Constraints.constrain 取代。(I8b8ea)
  • 已淘汰 loadFontResource。請改用 fontResource。我們已淘汰 imageResource、loadImageResource、vectorResource 和 loadVectorResource。請改用 painterResource (I6b809)
  • 基於效能考量,ScrollAxisRange 語意現在會傳回 Floats,而非直接 Float 值。(If4a35b/178657186)
  • 新增了 EditableText 語意,可為文字欄位的可編輯輸入文字加上無障礙標示,也新增了相應的測試方法來檢查語意 (I8e07a)
  • Made PolicyLayer/OwnerScope/OwnerSnapshotObserver 內部 (I4ffafb/175103944)
  • toIntPx() 已重新命名為 roundToPx() (I9b7e4b/173502290)。
  • IntBounds 已重新命名為 IntRect,且該 API 已改善 (I1f6ff)
  • Snapshot API 經更新後更符合 API 指南規範,並隱藏了公用 API 的內部實作類別。(Id9e32)
  • 新增展開及收合語意動作。在 ModalBottomSheetState 中新增了 expand 和 halfExpand (Ib5064)。
  • 淘汰了 Modifier.dragGestureFilter,請改用 Modifier.pointerInput { detectDragGestures (...)}。或者,也可使用 Modifier.draggable 進行單一軸線拖曳 (I0ba93b/175294473)。
  • 已將 Ambient 重新命名,以配合 Ambient -> CompositionLocal 的更名。Ambient 原本名為 AmbientFoo,現在已將 CompositionLocal 命名為 LocalFoo。(I2d55d)
  • 已淘汰的 BaseTextField 現已移除。請改用 BasicTextField。(I71368)
  • 已將選取項目移至基礎。(I7892b)。
  • 如同我們先前移除 state { 0 } 可組合項且現在鼓勵使用 remember { mutableStateOf(0) } 等項目,我們也將移除 savedInstanceState { 0 } 可組合項。請改用 rememberSaveable { mutableStateOf(0) },這樣只要 MutableState 內使用的類型可儲存在套裝組合中,就能自動儲存並還原。如果先前傳遞的是自訂儲存工具物件,則現在需使用含有 stateSaver 參數的全新超載 rememberSaveable。用量格式如下:val holder = rememberSaveable(stateSaver = HolderSaver) { mutableStateOf(Holder(0)) } (Ib4c26b/177338004)
  • 新增無障礙功能密碼語意 (I231ce)
  • 新增 progressBarRangeInfo.Indeterminate 以標示載入作業的進度列 (I6fe05)
  • 淘汰了 emptyContent()(@Composable () -> Unit).orEmpty() 公用程式,原因是這些公用程式對效能已無正面影響或價值 (I0484d)
  • snapshotFlowwithMutableSnapshot 不再是實驗性質。(I6a45f)
  • Recomposer 現在可以關閉。封閉的重新寫入器將繼續調整,直到構成的子元件完成為止。將 Recomposer.shutDown 重新命名為「cancel」,以便與關閉狀態形成對比。(Ib6d76)
  • UiSavedStateRegistry 已重新命名為 SaveableStateRegistry,AmbientUiSavedStateRegistry 已重新命名為 AmbientSaveableStateRegistry,且兩者都移至 androidx.compose. runtime.saveable 套件。(I30224)
  • 構件 androidx:compose:runtime:runtime-saved-instance-state 已重新命名為 androidx:compose:runtime:runtime-saveable (I6dcac)
  • UI 套件中許多已過時的 API 都已刪除 (I2f2dc)
  • Compose:runtime-fulfillment 構件現已淘汰。目前可在 compose:runtime 中找到 MonotonicFrameClock,而 AndroidUiDispatcher 則可在 compose:ui 中找到。(Ib5c36)
  • Outline.* 類別已不再是資料類別 (I4879eb/178001427)
  • 已移除 view.captureToImage(),且沒有任何更換內容。(I7fcd2)
  • 推出了 ColorMatrix API,可用於修改來源內容的 RGB 值,也推出了 Refactored ColorFilter API,可做為介面並用於比對 PathEffect 的實作。(Ica1e8)
  • 將版面配置方向參數加到 形狀的 createOutline 中。允許建立版面配置方向感知形狀 (I57c20b/152756983)。
  • onImeActionPerformed 已淘汰,請改用 KeyboardActions (If0bbdb/179071523)
  • 引入了將套用於無限動畫的 InfiniteAnimationPolicy 協同程式結構定義元素。根據預設,系統不會安裝任何政策,除非使用 ComposeTestRule 執行測試。(I50ec4b/151940543)。
  • CanDrag 已從 Modifier.scrollable 移除。(Id66e7b/175294473)。
  • 已將 LayoutCoordinates.ParentCoordinates 重新命名為 LayoutCoordinates.ParentLayoutCoordinates 以允許新的父項 Coordinates 屬性。parentCoordinates 屬性現在提供父項修飾詞的 LayoutCoordintes。這樣將針對 onSizeChanged() 和 onGloballyPositioned() (Idfbfdb/177926591) 提供更完整的用途。
  • 淘汰了 tapGestureFilter、doubleTapGestureFilter、longPressGestureFilter 和 pressIndicaitonGestureFilter。請改用 Modifier.clickable 或 Modifier.pointerInput 搭配 DetectionTapTouchs 函式 (I6baf9b/175294473)。
  • 已移除 SaveableStateRegistry 的 unregisterProvider。因此,RegisterProvider() 會傳回 SaveableStateRegistry.Entry 物件,以取消註冊 (Ic4274b/178583739)
  • RememberSaveInstanceState() 已重新命名為 RememberSaveable() 並移至 androidx.compose. runtime.saveable 套件。(I1366eb/177338004)。
  • 從公用 API 移除 CoreText 和 CoreTextField
    • 已移除已淘汰的 SelectionContainer 超載
    • (I99c19)
  • 在直接新增至 WindowManager 的階層中,使用 Compose 進行測試,現已成為更穩定的方法。(Ie81edb/175765614)
  • 移除了 Recomposer.current()。[Abstract]ComposeView 現已預設為延遲建立、以視窗為範圍的 Recomposer,並由視窗的 ViewTreeLifecycleOwner 所驅動。主機的 Lifecycle 停止時,Recomposition 和以 withFrameNanos 為基礎的動畫滴答會暫停 (I38e11)
  • Recomposer.runRecomposers 現已提供唯讀 ReComposerInfo 的全域 StateFlow,用於在程序中觀察進行中的組合狀態。建議使用這個 API 取代已淘汰的 ReComposer.current() (If8ebe)
  • Saver、listSaver()、mapSaver()、autoSaver 已從 androidx.compose.runtime.savedinstancestate 移至 androidx.compose.runtime.saveable (I77fe6)
  • EditCommands 可接受 AnnotatedString。然而,此為 API 變更,尚未實作多樣式文字編輯功能。(I4c3ea)
  • 已移除運作時間與時間長度。(Ib9bf4b/177420019)。
  • CompositionData.asTree() 和相關 API 已移至個別 ui-tooling-data 模組並標示為實驗性 (Ic95b8)
  • 為了支援形狀的 rtl 方向自動鏡像,RounderCornerShape、CutCornerShape 和 CornerBasedShape 的參數已從 left/right 重新命名為 start/end。加入 AbsoluteRounderCornerShape 和 AbsoluteCutCornerShape 以處理不需要自動鏡像的情況。(I61040b/152756983)。
  • Compose 編譯器外掛程式指定的 API 經過重構,現在會使用介面,而不是具體類別。介面也不再使用類型參數。

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

  • 移除無意公開的公開 StringBuilder.deleteAt 函式 (Id6ed9)

修正錯誤

  • 放置在檢視區塊階層中,且為另一個構圖子項的 ComposeViews,現在代管其祖系的子項構圖 (I92883)
  • 已更新組合的 imageFromResource API,以在載入 ImageBitmap 物件時重複使用資源可提取的快取。(If3627b/178751994)

1.0.0-alpha11 版本

2021 年 1 月 28 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha111.0.0-alpha11 版包含以下修訂項目。

API 變更

  • WithConstraints 已重新設計為 BoxWithConstraints,並移至 foundation.layout。(I9420bb/173387208)
  • Key.DPadUp 已淘汰。請改用 Key.DirectionUp。(Iab335b/177954892)。
  • 從現在起,擁有者介面為內部使用。(If8e35)
  • 新增 FocusManager.moveFocus() API 以透過程式輔助移動焦點。(I045cbb/177681839)。
  • 將 PopupPositionProvider 變更為使用視窗相關座標,而非全域座標。重新命名父項 GlobalBounds 為 anchorBounds,並變更 windowGlobalBounds 為 windowSize: IntSize (I2994a)
  • 持續時間與運作時間將替換為長毫秒,而且這個步驟會移除這些類別的指標輸入內容。(Ia33b2b/175142755b/177420019)
  • 新增 AmbientSavedStateRegistryOwner,與現有的 AmbientLifecycleOwner 和 AmbientViewModelStoreOwner 類似 (I9a3e8b/176756365)
  • 更新向量圖形 API,以支援對向量圖形根套用的色彩剖析。(Id9d53b/177210509)。
  • 將 toolType 新增至 PointerInputChange 以區分裝置 (Iac787b/175142755)
  • AmbientWindowManager 已重新命名為 AmbientWindowInfo (I2686ab/177084714b/177084983)
  • 淘汰全域座標方法,並建構新的視窗式座標方法 (Iee284)。
  • 新增了 Modifier.toolingGraphicsLayer,這會在檢查功能開啟時加入圖形圖層修飾詞 (I315df)。
  • FocusRequester.createRefs 可能會有變動,因此目前標示為實驗性質 (I2d898b/177000821)。
  • SemanticsPropertyReceiver.hidden 已重新命名為 invisibleToUser 並標示為 @ExperimentalComposeUiApi。AccessibilityRangeInfo 已重新命名為 ProgressBarRangeInfo。stateDescriptionRange 已重新命名為 progressBarRangeInfo。AccessibilityScrollState 已重新命名為 ScrollAxisRange。horizontalAccessibilityScrollState 已重新命名為 horizontalScrollAxisRange。verticalAccessibilityScrollState 已重新命名為 verticalScrollAxisRange。(Id3148)
  • 移除 PointerInputData 和修改的 PointerInputChange,提供所有 PointerInputData 的欄位。將 PointerInputEvent 和 PointerInputEventData 改為內部使用,因為這些並未在任何公開 API 中使用。(Ifff97b/175142755)
  • 新版 GraphicsLayerScope 可實作密度,以支援將 dp 轉換為原始像素。(Ied528b/176819695)。
  • 更新了矩陣 API,以遵循資料列主要順序並提供索引常數,協助於不同的矩陣表示法之間進行轉換,進而讓內部 SkMatrix 和 Matrix4 之間的架構轉換邏輯保持一致。(I432e6)
  • 移除了實驗性的 monotonicFrameAnimationClockOf 方法 (Ib753fb/170708374)
  • 將 String.fintPrecedingBreak 和 String.fingingingBreak 移至 InternalTextApi。(I657c4)
  • androidx.compose.ui.util.isSurrogatePair 已從公開 API 中移除。(Ia9494)
  • 將 TransformedText.transformedText 重新命名為 TransformedText.text
    • TransformedText 已不再是資料類別 (Ie672a
  • 已將 data class 從下列類別中移除:
    • InlineTextContent
    • LocaleList (I605c7)
  • 以下類別已不再屬於資料類別:
    • AnnotatedString
    • ParagraphStyle
    • SpanStyle
    • TextStyle
    • FontWeight
    • TextDecoration
    • TextGeometricTransform
    • TextIndex
    • TextLayoutResult
    • TextLayoutInput (Iaff99)
  • 將 VisualTransform 變更為功能性介面。(I3bba4)
  • 新增函式參照參數類型 (I5e1bd)
  • 將轉換後的繫結新增至 ScanningorNode (Ice42f)

修正錯誤

  • 淘汰了 onCommit、onDispose 和 onActive,改用 SideEffect 和 DisposableEffect API (If760e)
  • 修改了 Font/FontFamily/Typeface 的工廠函式。

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

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

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

  • 移除應避免使用的 displaySize 值。通常使用 onRoot() 的尺寸較佳,至少應使用視窗尺寸 (I62db4)

  • OnSizeChanged 回報版面配置內容的大小。現在會回報其於修飾詞鏈結內位置的大小。(I36b78b/177562900)

  • emit() API 和所有超載已淘汰,並重新命名為 ComposeNode。API 完全一樣,只是名稱不同,以符合 Compose 的命名慣例 (I4137b)

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

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

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

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

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

    RememberObserver 新增了 onAbandoned,如果 RememberObserver 執行個體是從傳送至 remember 的回呼傳回,但未記錄在組合狀態中,且因此永不會呼叫 onRemembered,這種情況就會呼叫此項目。發生這種情況可能是因為例外狀況在完成前終止組合,或組合遭到捨棄,因為產生組合的狀態已過時,或是不再需要使用。如果按照上述單一參照建議提供的 RememberObserver 例項追蹤了外部資源,則 onForgottenonAbandoned 都表示不再需要資源。如果物件已經開始追蹤啟動的作業,或是指派給 onRemembered 的資源,則您可以忽略 onAbandoned,因為呼叫 onRemembered 之後便不會呼叫此項目。(I02c36)

  • 已淘汰 2 個或多個 TextUnit 之間的運算。已淘汰 TextUnit.Sp 和 TextUnit.Em 函式,改用擴充功能函式 (例如 Int.sp 和 Int.em)。(I48369)

  • 根據預設,沒有明確宣告公開資源 (例如透過 public.xml) 的程式庫中的資源目前設為不公開。(Ia1dccb/170882230)

  • 淘汰了 ScrollableColumn/Row。內含大型捲動內容時,使用 ScrollableColumn 會比使用 LazyColumn 來得低,因為使用 LazyColumn 時,我們只能撰寫/測量/繪製可見元素。為了避免使用者效率低落,我們決定淘汰 ScrollableColumn 和 ScrollableRow,並改為使用 LazyColumn 和 LazyRow。使用者仍可決定自己不需採用延遲行為,並直接透過以下類似方式使用修飾詞:Column(Modifier.verticalScroll(rememberScrollState())) (Ib976bb/170468083)

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

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

    • 請使用 ImeAction.Default 取代 ImeAction.Unspecified (Ie1bcc)
  • 運用 TestCoroutineDispatcher 進行測試 (I532b6)

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

  • 淘汰了以 TransitionDefinition 為基礎的轉換。(I0ac57)

  • 已移除 TextUnitType.Inherit 方法。請改用 TextUnitType.Unspecified。(I9ff64)

1.0.0-alpha10 版本

2021 年 1 月 13 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha101.0.0-alpha10 版本包含以下修訂項目。

破壞性變更

  • 所有 @Composable 函式都執行完畢後,可透過重新建構內部編譯器 API,針對進入「套用變更」組合階段所產生的節點進行批次變更。

    這是一項可能會影響應用程式程式碼的破壞性行為變更,因為在套用變更完成之前,您都無法透過內部和實驗性 API 使用節點。這種情況通常可以採取以下變通方法:在 SideEffect 可組合項中使用這類依附元件包圍程式碼,藉此延遲程式碼的執行作業,直到節點建立並完成初始化作業。(I018da)

API 變更

  • 新增 Modifier.focusOrder(),可用於指定自訂對焦週遊順序 (I90cf5b/175899543b/170155556b/170155429)
  • 改為移除已淘汰的 OOserver 使用 onFocusChanged 或 onFocusEvent (I3ecb9b/175156387)
  • EditOperations API 變更
    • 已將 EditOperation 重新命名為 EditCommand
    • 為 EditOperation 具體實作的指令後置字串。
    • EditCommand 已不再是資料類別
    • 已將 EditOperation.process 函式重新命名為 applyTo
    • 已將 InputEventListener 重新命名為 InputEventCallback
    • (I0a366)
  • 移除未使用的 PxSquared、PxCubed、PxInverse。已將 size.center() 變更為屬性。(I973f7)
  • 現在,ui-test 模組可以設定測試用 UI 重新重編 (Ibebd8)
  • 經過修改的速率,擁有元件部分和數學運算。(Ib0447)
  • @ExperimentalTesting 重新命名為 @ExperimentalTestApi,以便與類似的實驗 API 註解保持一致 (Ia4502b/171464963)
  • 已將 Color.useOrElse() 重新命名為 Color.takeOrElse() (Ifdcf5)
  • 移除未使用的 DpInverse、DpSquared 和 DpCubed 類別。(I4d62b)
  • Constraints#satisfiedBy 已重新命名為 isSatisfiedBy。(I9cf5c)
  • 新增回呼,在版面配置節點邊界變更時通知擁有者。(I72fd1
  • 為含有 Unspecified 常數的內嵌類別新增了 isSpecified、isUnspecified 和 useOrElse (I93f7bb/174310811)。
  • 展開 [Abstract]ComposeView API,以支援回收撰寫型檢視表,讓後續配置重製完成。新增 API,可用於安裝及探索視窗範圍的 Recomposers 和 CompositionReferences,以便建立子組合。

    新增 ViewCompositionStrategy,可用於設定 [Abstract]ComposeViews 的組合處理策略;預設行為是在視窗卸離時丟棄 (I860ab)

  • 已移除 Any.identityHashCode() 公用 API (I025d7)

  • 移除了 toStringAsFixed API,直接改為使用 String.format。(Iaba6b)

  • 為基礎 Strings.kt 新增 Toggle (I4a5b7b/172366489)

  • 將 nativeClass 移至 ui 模組並設為內部使用。已在同等的實作中更新 nativeClass 的使用情形,改為使用「is MyClass」。(I4f734)

  • Modifier.focus() 和 Modifier.focusRequester() 現已淘汰。請改用 Modifier.focusModifier() 和 Modifier.focusReference()。(I75a48b/175160751b/175160532b/175077829)。

  • 隆重推出 SelectionRegistrar.notifySelectableChange,向 SelectManager 通知可選取的更新。(I6ff30b/173215242)。

  • 導入 Outline.bounds 屬性,藉此取得各種外框實作的繫結矩形。(I16e74b/175093504)

  • 已淘汰 TestUiDispatcher。改用 Dispatchers.Main (Ic171fb/175385255)

  • ImeOptions 和 KeyboardOptions 已不再是資料類別 (I3c898b/168684531)

  • VisualTransform API 異動

    • 已將 OffsetMap 重新命名為 OffsetMap
    • 已將 OffsetMap.identityOffsetMap 重新命名為 OffsetMap.Identity
    • PasswordConversions 不再是資料類別
    • 已將 OffsetMap 移至其檔案
    • (I0bdf3)
  • 將 Position 重新命名為 DpOffset,並移除了 getDistance() (Ib2dfd)

  • 已將有趣的 Dp.isFinite() 變更為 val Dp.isFinite (I50e00)

修正錯誤

  • 重組工具現在會呈現目前狀態的流程,以便監控其活動及相關成效的活動。(Ifb2b9)
  • 原生 keyEvent 現在可以透過 keyEvent.nativeKeyEvent 存取 (I87c57b/173086397)
  • animate() 現已替換為 animateAsState(),後者會傳回 State<T> 而非 T。這樣可以改善效能,因為系統會將無效範圍縮小到讀取「狀態」值的位置。(Ib179e)
  • 新增 Semantics 角色 API,並將 Role 新增為可點選、選取和切換的 SemanticsModifier 參數。已將 Modifier.progressSemantics 變更成為 Slider 也能夠使用。(I216cd)
  • 以新的協同 API 為基礎的 Animatable,確保動畫中包含互斥性。

1.0.0-alpha09 版本

2020 年 12 月 16 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha091.0.0-alpha09 版包含以下修訂項目。

API 變更

  • 已淘汰的 KeyEvent.Alt 現已移除。請改用 KeyEvent.isAltPressed。(Idd695)
  • Modifier.keyInputFilter 和 Modifier.previewKeyInputFilter 已淘汰,請使用 Modifier.onKeyEvent 和 Modifier.onPreviewKeyEvent (Idbf1bb/175156384)
  • Modifier.focusObserver 已淘汰。請改用 Modifier.onFocusChanged 或 Modifier.onFocusEvent (I30f17b/168511863b/168511484)
  • 如要暫停遊標指標輸入 API,請將 RiverPointerInputScope 重新命名為 AwaitPointerEventScope,並將 HandlePointerInput() 重新命名為 awaitPointerEventScope()。(Idf0a1b/175142755)
  • AutoFill API 現為實驗性 API,必須啟用 (I0a1ec)
  • 新增刪除宣告以建立 FocuSRequester 執行個體 (I35d84b/174817008)
  • accessibilityLabel 已重新命名為 contentDescription,accessibilityValue 已重新命名為 statusDescription。(I250f2)
  • 將自訂事件從暫停指標輸入 API 中移除 (Ia54d5b/175142755)
  • 選擇性選項中增設了幾個新函式,並已重新命名為 onPositionChange notifynotifyChange。(Ifbaf7)
  • 標示為內部使用的 LayoutNode 成員更多 (I443c6)
  • 透過版面配置和測試加入 LayoutInfo (I9b190)
  • AndroidOwner 內部 (Ibcad0b/170296980)
  • 已移除 ExperimentPointerInput 註解 (Ia7a24)
  • 已新增巢狀捲動系統。詳情請參閱 Modifier.nestedScroll (I36e15b/162408885)
  • subcomposeInto(LayoutNode) 已設為內部 (Id724a)
  • Applier 介面經過變更,將樹狀結構建構程序從由上往下簡化為由下往上。

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

    加入新的方法 insertBottomUp()

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

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

  • 已將 dismissOnBackClick 和 dismissOnClickExternal 屬性新增至 AndroidDialogProperties。這些動作可讓您設定在對話方塊關閉 onDismissRequest lambda 時。(If5e17)

  • 新增 PainterResource API,以處理光 ster 化格式 (例如 PNG) 或 VectorDrawables 的不透明載入油漆物件。取用端不必再事先決定資產類型,所以能呼叫此方法,取得用於 Image 可組合項或 Painter 修飾詞的 Painter 物件。(I2c703b/173818471)。

  • 新增 Modifier.clearAndSetSemantics 以清除子系的語意,並設定新的語意。(I277ca)

  • 將 ContentDrawScope 移至 ui-graphics 模組,和 DrawScope 放在一起。(Iee043b/173832789)。

  • 推出 PathPath 圖形 API,為筆劃形狀提供不同模式。 已淘汰 NativePathImpact 的使用方式,傾向希望或實際導入 PathEffect。(I5e976b/171072166)。

  • 將 IdlingResource 介面新增至 Compose,做為 Espresso 的身分識別資源支援的 Compose 版本。可以透過 ComposeTestRule (I433f3) 註冊及取消註冊

  • 將 ComposeIdlingResource 全域 (非) 註冊和全域 (未註冊) 註冊狀態變更為 ComposeIdlingResource (I32660)

修正錯誤

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

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

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

    已淘汰梯度函式建構函式 API,並採用梯度物件的物件方法。(I511fcb/173066799)。

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

  • 已淘汰 BuildCompat.isAtLeastR (Idb37e)

  • 新增了 buildAnnotatedString 工廠函式,以建構 AnnotatedString。已淘汰 annotationdString 建構工具函式。(Idfe0b)

  • 移除 Float 和 Double 的擴充功能將值轉換為弧度。已移至實作 PathParser 中的私人函式,這是唯一使用的位置 (I25f52)

1.0.0-alpha08 版本

2020 年 12 月 2 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha081.0.0-alpha08 版本包含以下修訂項目。

API 變更

  • 新增語意動作 關閉 (I2b706)
  • 已將 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)。
  • 已加入新的 placeable.placeWithLayer() 和 placeable.placeRelativeWithLayer() 方法,允許自訂版面配置和版面配置修飾詞利用加入繪圖的圖層放置子項。有了這個檔案,我們首先可以將重新繪圖最佳化,這樣當我們需要移動子項時,就不必重新繪製其內容;再來,還能為子項套用繪圖轉換 (Ibd8f6b/170296989b/171493718b/173030831)
  • <T>」已從 SubcomposeLayout 宣告中移除。 您現在可以在不指定類型的情況下使用它。(Ib60c8)
  • 新增 Modifier.scale/rotate API,以便 DrawLayer 使用。
    • Modifier.drawOpacity 已重新命名為 Modifier.alpha
    • 已將 Modifier.drawShadow 重新命名為 Modifier.shadow (I264cab/173208140)
  • 將 PointerInputData 的運作時間和位置欄位設為不可為空值。(Id468a)
  • MaterialTopic 現可為選取範圍及選取背景設定正確的顏色。非 Material 應用程式可以手動使用 AmbientTextSelectionColors 自訂所選顏色。(I1e6f4b/139320372b/139320907)。
  • 已新增 WindowManager.isWindowFocused 來檢查主機視窗是否對焦,以及 WindowFocusObserver 提供 onWindowFocusChanged 回呼。(I53b2ab/170932874)
  • 更新 TransformOrigin API 為具有解構語法,以傳回 pivotFractionXpivotFractionYcomponent1component2 (If43c4b/173586560)
  • 已新增可組合 lambda 參數在於命名和位置的 Lint 檢查,以檢查是否與 Compose 準則一致。另外也根據 Lint 檢查和指引,使用 children 做為結尾 lambda 的名稱,將部分 API 遷移至 content。(Iec48e)
  • 新增 API,可檢查在傳送 keyevent 時是否按下 Alt、Ctrl、Meta 或 Shift 鍵。 (I50ed9)
  • 已新增 Modifier.drawLayer() 超載。 這會在新的 GraphicsLayerScope 放上 lambda 模塊,可讓您定義圖層參數,以便在狀態變更時可略過重組和重新版面配置程序。DrawLayerModifier 現已處於內部準備狀態,可將其邏輯遷移至 LayoutModifier 的 placeable.placeWithLayer() 方法 (I15e9fb/173030831)
  • 淘汰了在名稱後綴使用 Ambient 的 Ambient,並比照其他 Ambient 和 Compose API 指南規範,替換成在名稱前綴使用 Ambient 的新屬性。(I33440)
  • 已將 androidx.compose.ui.text.Typeface 移至 androidx.compose.ui.text.font.Typeface (Ic2b81)
  • 語意引數 mergeAllDescendants 已重新命名為 mergeDescendants。(Ib6250)
  • 新增拖曳手勢偵測工具暫停輸入 API,包括方向鎖定。(Icef25)
  • 根據 API 規範,將 VectorAsset 重新命名為 ImageVector 移動 VectorAsset 並重新命名,成為 ImageVector 的內部類別。 已新增 VectorAssetBuilder 的 typealias,以便連結至 compat ImageVector.Builder。(Icfdc8)
  • 已將 ImageAsset 和相關方法重新命名為 ImageBitmap。(Ia2d99)
  • 為 PlacementScope 的 place() 新增 zIndex 參數,以便 Modifier.zIndex() 做為 LayoutModifier 使用,任何自訂版面配置都能直接在刊登位置區塊中為孩子設定 zIndexes (I711f7b/171493718)。
  • 將基礎語意屬性移至 UI (I6f05c)
  • 淘汰 place(Offset) 和 placeRelative(Offset)。請改用含有 int 偏移的超載 (I4c5e7)
  • 移除了先前已淘汰的 API:移除了 Modifier.onPositioned,請改用 Modifier.onGloballyPositioned。Modifier.onDraw 已移除,請使用 Modifier.onDrawBehind。已移除 Modifier.plus,請使用 Modifier.then。已移除 Color.Unset,請使用 Color.Unspecified。 PxBounds 類別已移除,請改用 Rect (Ie9d02b/172562222)。
  • 更新了 Alignment 介面,使其能夠發揮作用。(I46a07b/172311734)
  • 使用新的暫停指標輸入,新增了輕觸、輕觸兩下、長按和輕按指示的手勢偵測工具。我們還新增了一些公用程式,讓開發人員更容易編寫自己的手勢偵測工具。(I00807)
  • id 已重新命名為 LayoutIdParentDatalayoutIdMeasurable.id 已重新命名為 Measurable.layoutId。(Iadbcbb/172449643)。
  • 新增多點觸控手勢偵測工具,包括偵測旋轉、縮放和平移的協助程式。(Ic459d)
  • 推出 SweepGradientShader 和 SweepGradientBrush API。(Ia22c1)
  • 測試中的時間控制項 (TestAnimationClock 及其運用) 現已處於實驗階段 (I6ef86b/171378521)
  • 新增依附式的捲動 API:

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

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

  • 在 AnimationClockTestRule 中針對可委派給其 clock 的方法和屬性提供預設實作 (I7ea3db/173399709)

  • AndroidComposeTestRule 現在可接受自訂活動啟動器 (Ib8288b/153623653b/154135019)

  • TextLayoutResult.getLineVisibleEnd 已淘汰。替代的 TextLayoutResult.getLineEnd 現已加入新參數「EndEnd」。(I73282)

  • 已更新 TextFieldValue API

    • 將 TextFieldValue.composition 設為唯讀
    • 已移除無效選取範圍的例外狀況 (I4a675b/172239032)
  • 支援文字轉語音引擎的 TtsAnnotation。(I54cc6)

  • 推出可在協同程式中執行動畫的新 API (Ied662)

修正錯誤

  • Box 的對齊參數已重新命名為 contentAlignment。(I2c957)
  • shiftPx 修飾詞已重新命名為 offset。且現已改用 lambda 參數,而不是 State。(Ic3021b/173594846)。
  • 已將 TextInputService 參數新增至 TextInputService#onStateUpdated (I3e8f5, b/172239032b/171860947)
  • 已新增 Lint 檢查,用於可組合函式中的修飾詞參數。這項檢查會檢查參數的命名、傳回類型、預設值和順序,確認是否符合 Compose 準則。(If493b)
  • 暫時新增選項,允許 TestAnimationClock 由 MonotonicFrameClock 驅動 (I1403bb/173402197)
  • 新增了 Android Typeface 包裝函式。您可以透過 typeface 函式 (例如 typeface(Typeface.DEFAULT)) 載入 Android 字體。已將 typefaceFromFontFamily() 重新命名為 typeface() (I52ab7)
  • 新增了 Lint 檢查,用於確認修飾詞工廠函式是否已定義為修飾詞的擴充功能,這樣才能順暢地鏈結在一起 (I07981)
  • 移除舊的 ui-test 模組及其虛設常式 (I3a7cb)
  • 重組工具不再接受 EmbeddingContext;系統會從 performanceCoroutineContext 取得必要的排程依附元件。FrameManager 已淘汰;平台在進行整合時應初始化其自己的全域快照處理程序。(I02369)
  • 將樣式資訊傳送至無障礙節點。(If5e8d)
  • TextUnit.Inherit 已重新命名為 TextUnit.Unspecified,以便與其他單位保持一致。(Ifce19)

Compose UI 1.0.0-alpha07 版本

2020 年 11 月 11 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha071.0.0-alpha07 版本包含以下修訂項目。

API 變更

  • 推出了 ScaleFactor 內嵌類別,用於表示相互獨立的水平軸和垂直軸的縮放比例係數,以支援縮放比例不統一的用途。
    • 已將 ComputeScaleFactor 方法新增至 ContentScale
    • 新增 ContentScale.FillBounds 以執行非統一的資源調度,藉此將 srcs 邊界延伸至完全符合目的地。
    • 新增運算子方法,以便使用大小參數計算 ScaleFactor 參數。
    • (Ic96a6b/172291582)。
  • 已新增用於建立對齊的 Biasalignment 和 BiasStatic 校內工廠。(Iac836b/169406772)。
  • 允許開發人員強制清除焦點。(I90372)
  • 已修正導致 Compose 內部的「瀏覽次數」無法繪製高度的錯誤。(If7782)
  • 在 ContentDrawScope 中建立 onDrawBehind API,以符合 Modifier.drawBehind 的命名慣例。(I4fc3ab/171955269)
  • 新增攝影機距離支援,以搭配圖層 API 上的 3D 轉換旋轉/旋轉(I40213b/171492100)。
  • 新增了沒有回呼的 SelectionContainer (Ibfadb)
  • 已移除 ExperimentSubcomposeLayoutApi 註解。現在可以在不新增 @OptIn 的情況下使用 SubcomposeLayout (I708ad)
  • FirstBaseline 和 LastBaseline 移至 androidx.compose.ui.layout 套件 (Ied2e7)
  • 從 DrawShadow() 修飾詞中移除透明度,因為這讓人感到混淆。(I82c62b/171624638)
  • MeasureResult 已從 MeasureScope 中移出。(Ibf96db/171184002)
  • 將數個版面配置相關符號從 androidx.compose.ui 移至 androidx.compose.layout.ui。(I0fa98b/170475424)。
  • 移除了已淘汰的 FocusState2 (I686cbb/168686446)
  • ZIndexModifier 現已轉為內部使用 (I1808bb/171493718)
  • 更新了 lerp 方法 Size 參數的傳回類型,以傳回非空值的 Size,避免不必要的方框設置。(Ib0044)
  • 新增了 TestMonotonicFrameClock,可運用 kotlinx-coroutines-test 的 runBlockingTest,對採用 Compose MonotonicFrameClock 等待組合外框事件的程式碼進行測試 (I4402f)
  • 已移除 手勢 Scope.localToGlobal (I15299b/171462785)
  • 已新增 onAllNodesWithSubstring Finder (I81dd7b/171462889)
  • androidx.ui.test 模組已淘汰。請遷移至 androidx.compose.ui.test 和 androidx.compose.ui.test.junit4 (I452e8)

修正錯誤

  • captureToBitmap 已移至 captureToImage。(I86385)
  • 淘汰了 foundation.Text,改用 material.Text。如需瞭解未使用主題來源值的非預設立場基本文字 API,請參閱 androidx.compose.foundation.BasicText。(If64cb)
  • 更新 TextFields 以接受 KeyboardOptions (Ida7f3)
  • 將 KeyboardOptions 重新命名為 ImeOptions (I82f36)
  • 已將 KeyboardType 和 ImeAction 移至 KeyboardOptions (I910ce)
  • 新增了 provideDefault 做為提供環境的替代方法,可針對未提供任何環境值的情況指定環境值。(Id6635b/171024925)
  • BaseTextField 已淘汰。請改用 BasicTextField。(I896eb)
  • 推出 ui-test-junit4 模組 (Ib91f8)
  • relativePaddingFrom 已重新命名為 paddingFrom。已新增 paddingFromBaseline 修飾詞,方便您指定版面配置邊界與文字基準線的距離。(I0440ab/170633813)
  • 將 LaunchedTask 重新命名為 LaunchedImpact,以便與 SideImpact 和 Disposableimpact API 保持一致。系統不允許使用不含主題參數的 LaunchedAction,以鼓勵採用最佳做法。(Ifd3d4)
  • 推出更新設定時會進行重組的資源可組合項。(I6387cb/167352819)
  • 這表示 Composer 必須在建構時提供 CoroutineContext (Ic4610)
  • 套用多個 Modifier.zIndex() 時,總共要計算 zIndex 的值。過去前者獲得好評。(Ic514cb/170623936)
  • 對內部 SlotTable 實作所做的變更,並不會影響公用 API。(If9828)
  • 新增了鍵盤自動更正輸入法編輯器選項 (I57b8d)
  • androidx.ui.test 移至 androidx.compose.ui.test (I9ffdb)
  • 已從公用 API 移除 KeyboardOptions.toImeOptions。(Ic2e45)

外部貢獻

  • 已停用內部構件 androidx.compose.ui:ui-text-android (Ib93fa) 的發布功能

1.0.0-alpha06 版本

2020 年 10 月 28 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha061.0.0-alpha06 版本包含以下修訂項目。

API 變更

  • Recomposer 現已成為 CompositionReference 以及有效的組合父項。現在只有少數情況必須使用明確的 Recomposer。(I4036f)
  • 淘汰 VectorPainter 並改用 rememberVectorPainter,更明確地指出可組合 API 會在內部利用「remember」持續保存各組合的資料。(Ifda43)
  • 更新了 Modifier.drawWithCache API,顯示 ContentDrawScope (而非 DrawScope) 為接收器範圍公開,以便為實作提供重新排序繪製指令的功能。這相當適合用於混合/調色用途;在這些情況中,必須先顯示內容像素,才能正確套用相應的混合模式演算法。(Ie7ec8)
  • 將 SimpleContainer 移至 PopupTestUtils.kt (I78c57)
  • ConsumedData 已不再是資料類別。詳情請參閱 https://android-review.googlesource.com/c/platform/frameworks/support/+/1455219 (I1737f)
  • 固定 Rtl 控點位置。(I6e1e0)
  • 將 DrawScope 和 ContentDrawScope 重構為介面,而不是抽象類別
    • 已建立 DrawScope 的 CanvasDrawScope 實作項目
    • 重構導入 DrawScope 以使用 CanvasScope
    • 建立 DrawContext 以納入 DrawScope 的依附元件
    • 已在 DrawScope 中移除已淘汰的方法 (I56f5e)
  • 破壞性變更:將傳回值從 PointerInputFilter.onPointerEvent(...) 中移除,因為在指標事件中唯一應支援變更的值是取用資料。 您不用修改 PointerInputFilter.onPointerEvent(...) 中的資料,只要修改已傳遞的 PointerEvents 使用資料即可。(I6acd0)
  • MeasureScope 和 IntrinsicMeasureScope 已成為介面。(I1a087b/170461665)
  • 系統已隱藏如何校正對齊 Line 的合併函式。(I9da1ab/170612900b/170611568)。
  • 新增以組合識別碼表示檢查器資訊的功能 (Idee08b/163494569)
  • 將 SelectAll 選項新增至選取選單 (Ief02b)
  • 更新 DrawTransform.rotate,採用預設的中心資料透視參數來比對說明文件。
    • 更新 DrawScope.rotateRad 以使用資料點的偏移偏移來符合其他轉換方法。
    • 已淘汰 DrawScope.rotateRad 超載,因此會針對資料透視表的 x 和 Y 座標使用浮點數。
    • (Iffcbb, b/170434992)

修正錯誤

  • 已為 androidx (I4bbeab/138602561) 啟用 API Lint 查找缺少 GetGetterMatchingBuilder
  • 新增測試(I6b8ae)
  • 在 ComposeTestRule 中啟用轉場功能,並從 ComposeTestRule 中移除啟用閃爍游標的選項 (If0de3)
  • 新增了 KeyboardCapitalization 輸入法編輯器選項 (I8ac38)
  • 在 CoreTextField 中新增了單行鍵盤選項 (I72e6d)
  • 將 SimpleContainer 移至 PopupTestUtils.kt (I65c3e)
  • 將 Radius API 重新命名為 CornerRadius,以更有效率地在 Compose 中明確使用 API。已更新說明文件,指出負值的角半徑會箝制為零。(I130c7b/168762961)。
  • 改善了 Android 互通性,具體做法是繼續將 MotionEvent 傳送至子項 Android View,針對 ACTION_DOWN 外的所有操作的 onTouchEvent 傳回 false (I94c5ab/170320973)
  • Box 是內嵌函式。(Ibce0cb/155056091)

外部貢獻

  • AnnotatedString.capitalizeAnnotatedString.decapitalize 支援不同的語言代碼 (I4aa7f)

1.0.0-alpha05 版本

2020 年 10 月 14 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha051.0.0-alpha05 版本包含以下修訂項目。

API 變更

  • 新增用於指定檢查器資訊的 DSL (Ic9a22)
  • 將 LongClick 移到文字中。(Iff2bc)
  • 實驗性 Modifier.pointerInput 暫停輸入修飾詞 (Ia77d2)
  • 新增了複製/貼上/剪下這三種無障礙操作 (I6db4f)
  • 移除 AndroidOwner 的公開建構函式 (Iacaef)
  • 彈出式視窗和對話方塊現在會沿用父項視窗的 FLAG_SECURE。 另外也新增了可明確設定這個標記的選項 (I64966b/143778148b/143778149)
  • 耗用資料現已變動。此外,呼叫這些耗用的擴充功能函式現在不會再傳回新的 PointerInputChange,而是變更提供的 PointerInputChange。

    這是完成 2 個步驟的步驟,讓所有人都能變更 PointerEvent 資料,讓使用者無法在使用者程式碼中編輯其他指標資料。第二個步驟是移除 PointerInputFilter.onPointerEvent(...) 中的 List<PointerInputChange> 傳回類型。(Id067e)

  • 停用 Text 中的選取功能,以及一個 Demo。(Ie7e97)

  • Made on 全域定位內嵌函式 (I15830)

  • OnPositionedModifier 已重新命名為 OnGloballyPositionedModifier,然後將 onPositioned() 重新命名為 onGloballyPositioned()。(I587e8b/169083903)。

  • 為擁有者新增了 hasPendingMeasureOrLayout 屬性,指出擁有者是否有任何待處理的版面配置工作 (I3d9f8b/169038599)

  • 新增 API 來透過程式清除焦點 (Ie1dc2b/161487952)

  • 已移除 PointerInputFilter.onPointerInput(...),並應改用 PointerInputFilter.onPointerEvent(...)。(I6f04a)

  • 大小調整

    • 已移除 size.getFlipped
    • 已移除 size.rem
    • 已移除 size.truncDiv (Ief44db/169790720)
  • 在內嵌類別標記值的標準化過程中,將 Color.Unset 重新命名為 Color.Unspecified,以便與其他內嵌類別保持一致 (I97611b/169797763)

  • 加入 TextOverflow.None。溢位為 None 時 Text 不再處理溢位,而是向 LayoutNode 報告其實際尺寸。(I175c9b/158830170)

  • AnnotatedString.Builder.addStringAnnotation 中的範圍參數已重新命名為代碼,以便進行 API 一致性。(I7c8cb)

修正錯誤

  • 改善了 LazyColumn/Row 的捲動效能,具體做法是針對每次捲動減少子組合中的工作項目。為組合類別新增了 hasInvalidations() 方法。將重組工具的 hasPendingChanges() 方法重新命名為 hasInvalidations() (Ib2f32b/168293643b/167972292b/165028371)
  • 將 size.Unspecified 的參數更新為 Float.NaN,而非 Float.POSITIVE_INFINITY。更新繪製工具實作,以檢查 Type.Unspecified 以及非有限大小。(I95a7e)
  • 自訂版面配置中的 place() 呼叫順序現在會定義子項的繪製順序 (Ibc9f6)
  • 支援將 AnnotatedString 轉換成 SpannableString,以提供無障礙功能。(Ief907)
  • 為較舊的 Android 平台新增虛設常式,以避免盡可能使用倒影。(Ia1790)
  • 已修正的錯誤:如果顯示的螢幕鍵盤導致應用程式平移,指標輸入座標將變的不正確。(Ic4cecb/163077821)

1.0.0-alpha04 版本

2020 年 10 月 1 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha041.0.0-alpha04 版本包含以下修訂項目。

API 變更

  • 新增 OwnerScope,以便收集已失效的版面配置和繪圖觀測範圍。(Ic4cf8)
  • 新增了 OnRemeasuredModifier 和 onSizeChanged(),可分別用於在內容版面配置完成重新測量時及大小有變動時接收回呼 (I657cfb/154108792)
  • 新增長按語意操作 (I6281bb/156468846)
  • 將 FocusManager 設為不公開。(I7872f)
  • 將實作方式更新為建立專屬的 DrawCacheModifier 實作,而不是在 DrawModifier 中加入選用屬性。

    更新各種方法的說明文件 (Ibd166)

  • 將 TextRange 設定為內嵌,避免建立物件。(Id034b)

  • PlacementScope#ParentWidth 和 PlacementScope#ParentLayoutDirection 無法再讀取自自訂版面配置的刊登位置區塊。(Icc1aeb/168295623)

  • 將 AccessibilityScrollState 新增至語意屬性。(Ifeda9)

  • 推出 Modifier.drawWithCache,支援建立特定物件,並根據條件/狀態資訊 (例如 I376dc) 重新建立依附元件。

  • 移除 ParagraphConstraints。寬度現在會直接傳給段落。(Ica712)

修正錯誤

  • 已更新多個圖形 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)
  • foundation.Box 已淘汰,請改用 foundation.layout.Box。(Ie5950b/167680279)
  • 將 Stack 重新命名為 Box。我們將淘汰原本已有的 Box,改用 compose.foundation.layout 中的新 Box。根據新 Box 的行為模式,當其擁有多個子項時,會將子項一個一個向上堆疊,這一點跟之前的 Box 不同,之前的行為較類似於 Column。(I94893b/167680279)
  • 淘汰了 Box 裝飾參數。如果要為您的方框加上裝飾/邊框間距,請改用 Modifier (Modifier.background、Modifier.border、Modifier.padding) (Ibae92b/167680279)
  • 已更新多個圖形 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)
  • 為 rootAnimationClockFactory、transitionsEnabled 和 textInputServiceFactory 加上 @VisibleForTesting 註解,將其設為內部 API 並隱藏其 kdoc (I554ebb/168308412)
  • 將 SelectContainer 從 Top 中移除,以停用預設選項並避免出現非預期行為。您可以特別使用 SelectContainer 來包裝需要選取的內容。(I8dfe0b/158459594)

1.0.0-alpha03 版本

2020 年 9 月 16 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha031.0.0-alpha03 版本包含以下修訂項目。

API 變更

  • 移除向前/向後語意語意。已在 AccessibilityRangeInfo 中新增步驟。(Ia47b0)
  • 已從 Owner 中移除 onInvalidate() - OwnedLayer 會處理無效判定。(Ica72bb/162061312)
  • 移除大小量 API 中採用偏移參數的運算子。這些作業的結果不明,所以這些結果的類型不是預期。例如:大小 - 偏移能否傳回偏移值或差額?

    另外也移除大小類別中已淘汰的方法。(Iec902b/166514214)。

修正錯誤

  • 修正 LazyColumn 項目有時會出現錯誤的情況 (某些情況也會導致當機情況)。(Ibcf17b/163066980b/165921895)。
  • 淘汰了 DpConstraints 和使用該項目的 API。(I90cdbb/167389835)
  • 已將 createAndroidComposeRuleAndroidInputDispatcherandroidx.ui.test.android 移至 androidx.ui.test (Idef08b/164060572)
  • 在版面配置 API 中將所有 gravity 用例重新命名為一致的 align 或 alignment。(I2421ab/164077038)
  • 已在 ComposeTestRule 中加入 onNode 和其他全域方法,因為目前的全域方法即將淘汰。(Ieae36)

1.0.0-alpha02 版本

2020 年 9 月 2 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha021.0.0-alpha02 版本包含以下修訂項目。

API 變更

  • 移除回呼,在版面配置節點邊界變更時通知擁有者。(If654eb/166106882)
  • 為向量圖形路徑新增 filltype 參數支援,以便依據 evenOdd 或 NonZero 路徑填滿規則挖剪形狀。(I43dd2)。
  • 運作時間與速度現已變成內嵌類別 (I48f4a)
  • 時間長度現在是內嵌類別 (I565eb)
  • 新增回呼,在版面配置節點邊界變更時通知擁有者。(Ic40b3)
  • 針對設有 Offset 和半徑的 Rect 函式建構函式,修正了其建立 Rect 時會遵循左、右、上、下順序,而非左、上、右、下順序的問題。

    移除了 Rect 中已淘汰的隨附物件方法,改用函式建構函式。

    新增在 Rect.kt 中驗證方法的測試 (I08460b/165822356)

修正錯誤

  • 新增 MutableRect,矩形可以修改。(I71bd2b/160140398)
  • Matrix4 已由 Matrix 取代。已移除 vectormath 套件的所有其他部分。(Ibd665b/160140398)
  • 變更了可組合函式的呼叫慣例。這是二進位檔破壞性變更。所有程式庫都必須重新編譯,才能與這個版本的 Compose 編譯器外掛程式搭配使用。

    這項變更不會對原程式碼層級產生重大影響,因為只有已變更的 API 屬於明確選擇啟用的編譯器 API。(I7afd2b/158123185)

  • 已修正分派到 PointerInputFilter 時可能發生的當機情形,可能導致 PointerInputFilter 遭到移除。(I58f25)

1.0.0-alpha01 版本

2020 年 8 月 26 日

發布 androidx.compose.ui:ui-*:1.0.0-alpha011.0.0-alpha01 版本包含以下修訂項目。

0.1.0-dev 版本

0.1.0-dev17 版本

2019 年 8 月 5 日

發布 androidx.compose.ui:ui-*:0.1.0-dev170.1.0-dev17 版本包含以下修訂項目。

API 變更

  • emitView 已淘汰。請盡可能使用 AndroidView,在 Compose 中產生觀看次數。請注意,系統日後將不再支援直接組合 View 和 ViewGroup 的做法,除非這是組合樹狀結構的一部分,且能透過 AndroidView 完成這項作業。(I29b1eb/163871221)
  • FocusState2 已淘汰,並由 FocusState 取代 (Ia8b79b/160822876b/160923332)
  • 我們淘汰了已移除的 AndroidView 超載。(I946b9b/163802393)
  • 自訂輸出項目現在可以宣告將其一或多個 setter 設為可略過,並在該輸出項目外獨立進行重組 (Ibbd13)
  • 將向量類別變更為資料類別,因為相同的物件執行個體會用於組合。

    為 VectorPainter 新增了 mutableStateOf 標記,以便在向量變更時依條件重新繪製。

    將 VectorComponent 執行個體重構為 VectorPainter,因為這在不同複合用途中重複使用。

    將 GroupComponent 和 PathComponent 更新為可變動的名稱欄位 (Ieae45b/151378808)

  • 已移除 onChildPositionedOnChildPositionedModifier。開發人員應改用子版面配置使用 onPositionedOnPositionedModifier。(I4522eb/162109766)

  • Offset 現在是內嵌類別 (Iaec70)

  • 將 modifier 參數新增至 SelectionContainer (I4aadab/161487952)

  • 已移除已淘汰的 FocusModifier (I0b4bab/160922116b/160821157b/162441435b/160822875b/160921940)

  • 已將 mergePolicy lambda 新增至 SemanticsPropertyKey。這可用於定義 mergeAllDescendants 語意合併的自訂政策。如果已設定預設值,預設政策會使用父項值,否則為子項值。(Iaf6c4b/161979921)

  • 限制條件現已改為內嵌類別 (I88736)

  • 新增 FocusManager,將常見的焦點邏輯移出 AndroidComposeView (I528efb/161487952b/162206799)

  • 已更新 Alpha 版本的 PointerEventPass 名稱。(Ifda6f)

  • IntOffset 現已改名為內嵌類別 (Iac0bf)

  • IntSize 現已改名為內嵌類別 (I2bf42)

  • PlacementScope.placeAbsolute() 重新命名為 PlacementScope.place(),而原先的 PlacementScope.place() 則重新命名為 PlacementScope.placeRelative()。因此,PlacementScope.place() 方法不再以由右至左的結構定義自動鏡射位置。如果需要這項功能,請改用 PlacementScope.placeRelative()。(I873acb/162916675)

  • AlertDialog 現在為按鈕使用 FlowRow (I00ec1b/161809319b/143682374)

  • 將部分測試公用程式設為非公開,因為這些工具不在其所在位置。日後會公開顯示。(I32ab1)

  • 重構的指標指標輸入內容。(Ie3f45)

  • 淘汰了 PxBounds,改用 Rect。將 PxBounds 的應用全部更新成應用 Rect,並新增適當的淘汰/取代備註來輔助遷移。(I37038b/162627058)

  • 移除已淘汰的 KeyEvent2。請改用 KeyEvent。(Ied2d0b/162097587)

  • KeyEvent 有一個萬國碼 (Unicode) 屬性,可用於取得指定鍵和中繼鍵狀態組合所產生的萬國碼字元 (If3afc)

  • 將 DelayUp 自訂事件和相關類別設為選擇性 API,因為這很可能會變更。(I56d6f)

  • 移除 2 個不再需要的 PointerEventPass。(I3dd9d)

  • 將參數顏色、陰影和 TextDecoration 新增至 Parachart. Paint。這項功能可以避免不必要的段落擷取作業。(I81689)

修正錯誤

  • 已從 TextField 移除 onFocusChanged 回呼。請改用 Modifier.focusObserver。(I51089b/161297615)
  • 已淘汰 Modifier.drawBorder。請改用 Modifier.border。Border 資料類別已由 BorderStroke 取代 (I4257db/158160576)
  • 移除了已淘汰的 FrameManager 呼叫。

    內部的 Compose API 經過變更,可減少追蹤狀態物件 (例如 mutableStateof()) 的負載 (I80ba6)

  • 移除了 VerticalScroller 和 HorizontalScroller。請改用捲動式資料欄/資料列。已移除 Modifier.drawBackground。使用 Modifier.背景 (I73b0db/163019183)

  • 修正了將可儲存狀態的項目用於 for 迴圈時發生的異常終止問題。現在可以在已儲存的 InstanceState() 中使用相同的鍵,但 UiSavedStateRegistry 的 API 現已調整為新的需求 (I4ab76b/160042650b/156853976b/159026663b/154920561)

  • 淘汰 state { ... } 可組合項,改為明確呼叫 remember { mutableStateOf(...) } 以求一目瞭然。這樣可以減少管理狀態所需的整體 API 介面和概念數量,且符合類別屬性委派作業的 by mutableStateOf() 模式。(Ia5727)

  • 將 RRect 重新命名為 RoundRect,以更符合 Compose 命名模式 建立了與 RRect 類似的函式建構函式,並淘汰了 RRect 函式建構函式 (I5d325)

0.1.0-dev16 版本

2020 年 8 月 5 日

發布 androidx.compose.ui:ui-*:0.1.0-dev160.1.0-dev16 版本包含以下修訂項目。

API 變更

  • 淘汰了 OnChildPositioned,請改用子項的 OnPosition。(I87f95b/162109766)
  • 淘汰了 setViewContent,應改用 setContent。(I7e497b/160335130)
  • 新增 AndroidViewBinding API,以根據 ViewBinding 進行及組合版面配置資源。(I081c6)
  • KeyEvent2 已由 KeyEvent (I2d770b/162097585) 取代
  • 新增 Alt 硬體金鑰支援 (I9036b)
  • FocusManager 已淘汰。請改用 Modifier.focus()、Modifier.focusObserver() 和 Modifier.focusRequester()。(I74ae4b/162211322)
  • loadVectorResource 支援 trimPath 屬性 (I808fe)
  • 將對話方塊移至 ui (I47fa6)
  • 移除 2 個不再需要的 PointerEventPass。(I33ca7)
  • 實作 PointerInteropModifier 可讓您接收 MotionEvents 功能,以及與 Compose 互動,就像您導入 Android View 一樣。(Ieb08c)
  • 移除了已淘汰的標記修飾詞。請改用版面配置 ID。(Idaa05b/162023919)
  • 更新了支援由右至左書寫的 API。新增了 LayoutDirectionAmbient,可用於讀取及變更版面配置方向。移除了 Modifier.rtl 和 Modifier.ltr。(I080b3)
  • 支援減少向量圖形的路徑 (Ie16c9b/158188351)
  • 新增 Modifier.layout(),方便您建立自訂版面配置調節係數 (I73b69b/161355194)
  • 推出了新的 AndroidView API,並淘汰了現有的 API。(I5bcfd)
  • 淘汰了 Modifier.plus,請改用 Modifier.then。「Then」可以更明確地指出先後順序,同時也禁止輸入會破壞鏈結且降低可讀性的 Modifier.padding().background() + anotherModifier (Iedd58b/161529964)
  • 新增 [摘要]ComposeView View 子類別,以託管在 View 階層中的 Compose 內容。(I46357)
  • RowColumn 現在是內嵌函式,可大幅減少使用這些項目的負擔。(I75c10)
  • 已新增 SubcomposeLayout。這是一種低階原始物件,如果我們想要使用僅在測量子樹狀結構組合後期可用的某些值,便可利用這個原始物件在測量期間組合子項。例如 WithConstraints 不會使用 SubcomposeLayout 導入。(I25cc8)
  • 新增了 SemanticsNode.positionInRoot,可用於取得 SemanticsNode 相對於 Compose 根階層的位置 (Icdf26b/161336532)
  • MotionEvents 從 Android 會先通過 Android 的設定程序,然後寫回 Android 應用程式中。(I14be8b/158034713)
  • 已移除 下拉式選單彈出式視窗。(I00430)
  • 修正了挖剪式顯示區中的彈出式視窗位置。(Idd7dd)
  • 新增無障礙動作以取得 TextLayoutResult (I9d6e6)
  • 已新增 RemeasurementModifier。可同步重新評估版面配置。重新連線時,您不必重新設定,因為系統會自動重新測量/重新調整版面配置,但會在捲動過程中使用 LazyColumnItems。(I5f331b/160791058)
  • 移除 getLineEllipsisOffset/getLineEllipsisCount。請改用 getLineVisibleEnd/getLineEnd/isLineEllipsize。(I85aa2)
  • 新增一些標記/註解做為最佳做法。(I66b20)
  • 在 TextLayoutResult 中顯示更多行 API。(I79bd2)
  • 內建向量轉換工具,讓用來轉換內建單位的使用者可透過 Foo.VectorConverter 存取。例如 Dp.VectorConverter、Color.VectorConverter、Float.VectorConverter 等 (I3e273)

修正錯誤

  • 解決廣泛的 API 問題 (I077bc)
    1. 移除未使用的 OffsetBase 介面
    2. 對齊 Offset 和 IntOffset 類別,以便採用一致的 API 介面
    3. 將 IntOffset.Origin 重新命名為 IntOffset.Zero,使其與 Offset API 一致
    4. 已將 nativeCanvas 方法從 Canvas 介面移出,以支援取用端建立自己的 Canvas 執行個體
    5. 建立 stub EmptyCanvas 類別以重構 DrawScope 做為非空值參數,而不是延遲參數,並確保欄位不會為空值
    6. 已將 ClipOp 列舉重新命名為 Pascal 案件
    7. 已將 FilterQuality 列舉重新命名為 Pascal 案件
    8. 已將 StrokeJOIN 列舉重新命名為 Pascal 案件
    9. 已將 PotMode 列舉重新命名為 Pascal 案件
    10. 已將 PaintingStyle 列舉重新命名為 Pascal 案件
    11. 已將 PathFillType 列舉重新命名為 Pascal 案件
    12. 已將 StrokeCap 列舉重新命名為 Pascal 案件
    13. 已更新 DrawCache 實作項目,不再使用 lateinit 參數
    14. 已更新 DrawScope,以不再為可讓 fillPaint 和 strokePaint 內部參數使用延遲委派功能
    15. 已更新映像檔以避免使用 Box 使用,以降低成本
    16. 已更新 Outline 類別,以納入 @Immutable 註解
    17. 已更新 PathNode,為各個路徑指示提供 @Immutable 註解
    18. 由於撰寫作業已經完成,更新向量分子,移除等式的多餘性檢查
    19. 已淘汰矩形隨播廣告建構函式方法,改用函式建構函式
    20. 已使用 @Immutable 和 @Stable API 更新 Brush 類別和函式建構函式
    21. 已將 VertexMode 列舉更新為 PascalCase
    22. 已更新 DrawScope selectedPaint 方法,以在條件變更時覆寫筆劃參數
    23. 更新了 Size 來新增解構 API、將 UnspecifiedSize 重新命名為 Unspecified,以及移除未使用的方法
  • 更新撰寫的 BlendMode API 使用量,根據 API 層級,在 Android 架構 BlendModes 和 PorterDuff 模式之間正確對應。引進 BlendMode#isSupported API 做為功能查詢,確認裝置是否支援 BlendMode 模式。(I0ef42)
  • 已為 Lazy 清單的 itemContent 參數新增 LazyItemScope。這可讓修飾詞填滿父項大小上限,從而解決項目應填滿可視區域時,一般 Modifier.fillMaxSize() 卻由於項目使用無限限制測量而無法運作的問題。(Ibd3b2b/162248854)。
  • 已移除SemanticsNodeInteraction.performPartialGesture。請改用 SemanticsNodeInteraction.performGesture。(Id9b62)
  • LazyColumnItems已重新命名為「LazyColumnFor」。LazyRowItems 已重新命名為 LazyRowFor (I84f84)
  • foundation.shape.corner 套件已分割為 foundation.share (I46491b/161887429)
  • AndroidComposeTestRule 已重新命名為 createAndroidComposeRule。(I70aaf)
  • 已將更多 API 新增至 TextLayoutResult。(Id7e04)
  • 素材 FilledTextField 已重新命名為 TextField,基礎 TextField 已重新命名為 BaseTextField,以方便尋找及使用 (Ia6242b/155482676)
  • Modifier.draw 背景 已重新命名為 Modifier.background (I13677)

0.1.0-dev15 版本

2020 年 7 月 22 日

發布 androidx.compose.ui:ui-*:0.1.0-dev150.1.0-dev15 版本包含以下修訂項目。

依附元件更新

  • 如要使用 0.1.0-dev15 版本的 Compose,需依據上述的宣告依附元件章節中出示的新程式碼片段來更新依附元件。

API 變更

  • 淘汰了 FocusModifier,改用 Modifier.focus、Modifier.focusRequester、Modifier.focusObserver。淘汰了 FocusState 和 FocusDetailsState,改用 FocusState2 (I46919b/160822875b/160922136)
  • 新增觀測焦點狀態變更的修飾詞。(I05866b/160924455b/160923326)
  • 新增修飾詞以要求變更焦點 (I8dd73b/161182057b/160924778)
  • 清除工具列選單,以正確顯示複製、剪下、貼上內容。(Id3955)
  • 單一值語意屬性現在使用呼叫樣式。舉例來說,「Maths { hidden = true }」目前會顯示為:semantics { hidden() }。(Ic1afdb/145951226b/145955412)。
  • 新增 Modifier.focus,取代 FocusModifier。(Ib852ab/160924778)
  • 為 TextField Select 新增 FloatingToolbar。(Ie8b07)
  • 為金鑰輸入相關 API (I53c0a) 新增實驗性 API 註解
  • 已為所有 Focus 相關的 API 新增實驗性 API 註解 (I53b24b/160903352)
  • 新增的 FocusState2 將取代 FocusDetailsState (I0a3ba, b/160822595)
  • 已新增 ExperimentFocus,此為 Focus API 的 @OptIn 註解。(I1544bb/160820961)
  • 已新增 IntBounds 單位類別,代表版面配置中的整數像素邊界。已更新 PopupPositionProvider 的 API 以使用。(I0d8d0b/159596546)
  • Applier 現在必須使用 clear() 方法來棄置組合 (Ibe697)
  • KeyEvent 已淘汰,並由 KeyEvent2 取代 (I68730)
  • 為測試搜尋工具新增了一個選用標記 useUnMergedTree。(I2ce48)
  • Made LayoutNode 實驗功能 API (I4f2e9)
  • 為各種內嵌類別類型新增複製方法,包括:

    • Offset
    • Size
    • Radius
    • Motion
    • TransformOrigin

    • 淘汰了 Size.copy 這個隨附物件方法,改用執行個體複製方法 (Ife290b/159905651)

  • 彈出式視窗、對話方塊和選單現在可以沿用相關 MaterialTheme (Ia3665b/156527485)

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

  • 從 Layout() 函式的評估區塊移除版面配置方向參數。不過,在回呼內可透過測量範圍物件取得版面配置方向 (Ic7d9d)

  • 重構用於 SelectR 來重複使用。(I420e0)

  • 已移除可點擊項目。使用 Modifier.clickable (I84bdf)

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

  • 在這項變更前,如果有輸出運算子,Compose 編譯器外掛程式會以非隨意的方式,攔截對 @Composable 函式所含建構函式的呼叫 (I5205ab/158123804)

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

  • 從 Placeable#get(AlignmentLine) 傳回的對齊線 Int 位置現在不可為空值。如果遺失了對齊的對齊行,會傳回 AlignmentLine.Unspecified。(I896c5b/158134875)

  • AndroidView 可組合項已新增修飾詞參數。(I48a88b/158746303)

  • Semantics() 已淘汰,請改用 Modifier.intents()。(I72407b/158841414)

  • 新增 viewModel() 可組合項,以便建立 ViewModel,或讓已經建立的 ViewModel 以在「活動」或「片段」中相似的方式運作 (I5fdd1)

  • 搭配使用 IntPx 和 Int。用 IntOffset 取代 IntPxPosition。將 IntPxSize 換成 IntSize。(Ib7b44)

  • 為了整合用於呈現調整大小資訊的類別數量,請將 Size 類別 (而非 PxSize) 的使用方法進行標準化。這樣可具有內嵌類別的優勢,即利用一個時長型數值封裝 2 個浮點型數值,呈現以浮點數表示的寬度和高度。(Ic0191)

  • 為了整合用於呈現地點資訊的資訊類別數量,請將偏移量類別 (而非 PxPosition) 的用量標準化。這樣就能使用內嵌類別,利用較長的 2 個浮點值來表示 x 和 y 偏移量 (以浮點表示)。(I3ad98)

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

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

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

  • 取代了 Px 類別在各個 Compose 類別中的用例;這是大規模重構工作的一個環節,目標是讓像素參數僅採用 Dp 和基元類型 (I97a5a)

  • TestTag 現已淘汰。請改用 Modifier.testTag。(If5110b/157173105)

  • 我們已移除 ParentDataModifier#modifyParentData 的預設執行動作,這與一開始沒有實作介面的功能相同。(I0deaa)

  • 移除了先前已淘汰的 ScaleFit。請改用 ContentScale。(Ifbc5b)

  • 取代了 Px 類別在各個 Compose 類別中的用例;這是大規模重構工作的一個環節,目標是讓像素參數僅採用 Dp 和基元類型 (I19d02)

  • 在 ui-material 中新增了 DropdownMenu 元件,此為質感設計選單實作。(I9bb3d)

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

  • 取代了 Px 類別在各個 Compose 類別中的用例;這是大規模重構工作的一個環節,目標是讓像素參數僅採用 Dp 和基元類型 (I57bff)

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

  • 整合 CanvasScope 實作項目,因此現在 DrawScope 和 ContentDrawScope 重新命名為 CanvasScope 重新命名為 DrawScope。已更新 DrawScope 以實作 Density 介面,並在 ContentDrawScope 中提供 LayoutDirection Deleted DrawScope 子類別。Painter 和 PainterModifier 經更新後不會再自行維護 RTL 屬性,原因是 DrawScope 已提供這項資訊,不必自行提供 (I1798e)

  • DoubleTapTouchFilter 現可於樹狀結構中區分 SingleTap 手勢篩選器。(If92b1)

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

  • 變更了 DrawLayer 修飾詞 API:outlineShape 已重新命名為 shape,採用 RectangleShape 做為預設值,而且現在不可設為空值;clipToOutline 已重新命名為 clip;移除了 clipToBounds,原因是其等同於 RectangleShape 的 clip == true (I7ef11b/155075735)

  • 更新了較高階的 Compose API,讓 Canvas 改為顯示 CanvasScope。如此一來,消費者就不需要維護自己的 Paint 物件。如果是仍需要存取 Canvas 的取用端,則可以使用 DrawCanvas 擴充功能方法提供回呼,對基礎 Canvas 發出繪圖指令。(I80afd)

  • WithConstraints 結尾的 lambda API 已變更。如今,除了 2 個參數外,它還有一個接收器範圍,除了限制與版面配置之外,還提供 Dp 中的 minWidth、maxWidth、minHeight 和 maxHeight 屬性 (I91b9ab/149979702)

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

  • 移除已淘汰的 LayoutModifier 介面。(I2a9d6)

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

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

  • 新增了 Modifier.zIndex() 來控制同一個上層版面配置的子項繪製順序。DrawLayerModifier 的 elevation 屬性已重新命名為 shadowElevation,不再控制繪製順序。變更了 DrawShadow 的參數順序:elevation 現在的順序為第一個,shape 為第二個並採用 RectangleShape 做為預設值。(I20150b/152417501)

  • 已移除擁有者的 onSizeChange 和 onPositionChange。(I5c718)

  • 已新增 Constraints2 副本,該副本僅支援 Int Connstraints 值,不支援 IntPx。系統將會移除 IntPx,並假設所有整數限制都是 Android 等像素。

    • 同時新增 IntSize,最終會取代 IntPxSize。(I4b43a)
  • 可使用任意值快速校正。已新增 1D 對齊方式。(Ia0c05)

  • 對齊 ToSiblings 現在可接受 Measured 而非「Placeable」。(I5788d)

  • (I45f09b/152842521)

    • 已將 ScaleFit 重新命名為 ContentScale
    • 將 ContentScale 從 ui-graphic 移至 ui-core 模組,然後移至與 Edge API 相同的模組。
    • 已將 ReMaxMax 重新命名為 裁剪
    • 已將 MinMinDimensions 重新命名為 Fit
    • 將 Fit 重新命名為 Inside
    • ImageView.ScaleType 對應項
    • 新增了說明文件,指出 Crop 和 Alignment.Center 的組合可達到與 ImageView.ScaleType.CENTER_CROP 相同的結果,而 Fit 與 Alignment.Center 搭配使用時,可達到與 ImageView.ScaleType.FIT_CENTER 相同的結果。 Inside 與 Alignment.Center 搭配使用時,則可達到與 ImageView.ScaleType.CENTER_INSIDE 相同的結果
  • Rtl 支援繪製修飾詞。(I0aaf9)

  • 推出新的 API,從 XML 加載 Android 資料檢視。詳情請參閱 ViewInCompose 示範。(I42916)

  • 改善 DrawModifier API:

    • 確定了 draw() ContentDrawScope的接收範圍
    • 已移除 Draw() 的所有參數
    • DrawScope 的介面與之前的 CanvasScope 介面相同
    • ContentDrawScope 含有 DrawContent() 方法 (Ibacedb/152919067)
  • 為 LayoutCoordinates 新增了 positionInParent 和 boundsInParent。(Icacddb/152735784)。

  • DrawLayerModifier 和 DrawLayer() 現已預設 clipToBounds 和 clipToOutline 設為 false。(I0eb8bb/152810850)

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

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

  • 將修飾詞和運算子替換成工廠擴充功能函式 (I225e4)

  • 已新增 TranslationX/Y 屬性,以支援特定圖層的繪圖指令顯示清單。移動動畫或觸控事件時,這項功能非常實用。(I8641c)

  • 在 Layer API 中新增 PivotX 和 PivotY 參數,以支援在圖層上的特定位置旋轉及調度資源 (Icf7c3)

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

  • 新增 LayerModifier 這項編輯器,可為版面配置新增 RenderNode。可讓您設定剪輯、不透明度、旋轉、縮放和陰影。這將取代 RepaintBoundary。(I7100db/150774014)

  • 將版面配置方向設為從上層版面配置節點往下層元素傳播。已新增版面配置方向修飾詞。(I3d955)

  • 堆疊元件支援從右至左方向性 (Ic9e00)

  • 在 Compose 版面配置中提供 Rtl 初始支援 (Ia5519)

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

  • 變更了 LayoutCoordinates,將 providedAlignmentLines 設為 Set (而非 Map),同時讓 LayoutCoordinates 導入 get() 運算子,而不是擷取一個值。這樣一來,修改器就能更輕鬆地修改組合的一或多個值,而不必為每個修改項目建立新的集合。(I0245a)

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

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

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

  • 建立 CanvasScope API,以便納入 Canvas 物件以顯示無狀態、宣告式 API 介面。變形作業侷限在其本身的接收器範圍內,大小調整資訊的範圍也對應插邊的邊界。不需要讓取用端保有自己的 Paint 狀態物件來設定繪圖作業。

    • 新增了 CanvasScopeSample 並更新了試用版應用程式,以納入宣告式圖形演示 (Ifd86d)
  • 移除了未使用的 MaskFilter API,原因是該 API 的用途有限,且在大多數應用中皆未針對硬體加速完成最佳化 (I54f76)

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

  • 將 API 中所有可取代的色彩取代為非空值,並使用 Color.Unset 取代 null (Iabaa7)

  • 為 ImagePainter 推出其他選用矩形參數,以支援繪製基礎 ImageAsset (I0ea9e) 的子區段

  • 已新增「未設定顏色」,代表不設定方塊的顏色。(If901a)

  • 新增 Canvas.rotate 和 Canvas.scale 擴充功能,用以執行轉換作業的選用資料座標。這些會預設成目前畫布平移的左上角。

    也將 Canvas.rotateRad 移至擴充用的一致性方法 (Ibaca6)

  • 建立 PixelMap API 來支援 ImageAsset 查詢像素資訊。(I69ad6)

  • 將名為 FrameworkRect/toFrameworkRectF 重新命名為 AndroidRect/toAndroidRectF,以符合在撰寫和在其建構之 Android 架構 API 之間的物件轉換命名慣例。也更新了這些 API 的說明文件 (I86337)

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

    將 Image(Painter) API 重新命名為 PaintBox(Painter) 已建立向量可組合項,其行為類似 Image 可組合項,但改用 VectorAsset 而非 ImageAsset (I9af9a, b/149030271)

  • 將 Image 重新命名為 ImageAsset,以進一步區分 Image 資料與即將推出並用於參與版面配置及繪製內容的 Image 可組合項。_Body:在 android.graphics.Bitmap、Bitmap.asImageAsset() 上建立了擴充功能方法,可用於建立 ImageAsset 執行個體,協助結合傳統的 Android 應用程式開發與 Compose 架構 (Id5bbd)

  • 新增了 TextDirection.Content (I48f36)

  • 新增了 TextDecoration.plus 運算子 (I0ad1a)

  • Force 從 TextDirectionAlgorithm 列舉值中移除 (Icc944)

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

  • 實作 TextClickAndDrag 以便選取文字欄位。(I17919)

  • 新增了 AnnotatedString.getStringAnnotations,用來傳回範圍內的所有註解。(I1fa00)

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

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

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

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

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

  • 現在可以使用 onTextInputStarted 回呼提供的 SoftwareKeyboardController 來隱藏/顯示螢幕鍵盤 (I8dc44b/151860051)

  • 已新增 (Text/ParaGraph/Span)Style 的加號運算子,可委派到 Merge() 函式。(Ia1add)

  • FontWeight.lerp 不再提出貼齊功能。這仍然是資料類別。(I521c2)

  • FontWeight 建構函式為公開狀態,不再是資料類別。(Id6b1f)

  • 將 getLineStart、getLineEnd、getEllipsisOffset 和 getEllipsisCount 新增至 TextLayoutResult (Ibc801)

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

  • 移除未使用的尺寸類別,因為 ui-幾何圖形模組有重複的大小類別。(I1b602)。

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

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

修正錯誤

  • 文字欄位中 onFocusChange 回呼已重新命名為 onFocusChanged (Ida4a1)
  • VerticalScroller 和 HoriziontalScroller 現已淘汰,使用 ScrollableColumn 和 ScrollableRow,透過資料欄/資料列行為和參數或使用內建功能,或是對元素使用 Modifier.verticalScroll 和 Modifier.horizontalScroll。同樣地,ScrollerPosition 也已淘汰,改為使用 ScrollState (I400ceb/157225838b/149460415b/154105299)
  • runOnIdleCompose 已重新命名為 runOnIdle (I83607)
  • 許多測試 API 已重新命名,提供更直覺化的使用體驗。將所有 FindXYZ API 都重新命名為 onNodeXYZ。將所有 doXYZ API 都重新命名為 performanceXYZ。(I7f164)
  • 您現在不必在 Gmail 中撰寫郵件,就能撰寫撰寫 UI。如需範例,請參閱 ViewInteropDemo。(I9ab0bb/160455080)
  • 為 MutableVector 新增了 sortWith 和 removeRange (Icccf7)
  • 實作「拖曳選取控點」來變更 TextField 的選取範圍。(I27032)
  • 移除包裝 NativeShader 類別的 Shader 內嵌類別,取代預期的 NativeShader 類別。已包裝的 Shader 內嵌類別在 API 介面上並未新增任何有價值的項目,並且是內嵌類別,因此請直接使用 NativeShader 類別。(I25e4d)
  • 將 PainterModifier 重構為不再根據特定限制和 ContentScale 參數提供資源調度。Paint 的實作方式,是依據其所繪製的 DrawScope 特定大小,自行擴充繪圖內容。

    修正了 VectorPainter 的快取點陣圖遭調整成其預設大小,而非指定繪製大小的問題。

    更新 ImagePainter,而非仰賴 PainterModifier 擴充內容。(I6ba90)

  • 使用動畫頁框新增動畫動畫的頂層函式 (Ie34c5)

  • @Untracked 註解已淘汰。替換為 @ComposableContract(tracked=false) (Id211e)

  • androidx.ui.foundation.TextFieldValue 和 androidx.ui.input.EditorValue 已淘汰。也已淘汰使用該類型的 TextField、FilledTextField 和 CoreTextField 元件。請改用 androidx.ui.input.TextFieldValue (I4066db/155211005)

  • 修正問題:在分離過程中,如果透過子元件移除 PointerInputFilters,指標輸入作業會導致當機。不過現在我們已順利解決這項問題。(I1f48bb/157998762)

  • 修正問題:在分離過程中,如果透過子元件移除 PointerInputFilters,指標輸入作業會導致當機。不過現在我們已順利解決這項問題。(Iab398b/157998762)

  • 將 Radius 類別重構為內嵌類別。移除具有預設參數的函式建立方法,並使用預設參數讓半徑 Y 軸與必要 X 軸半徑參數的 y 軸相符。

    更新 DrawScope.drawRoundRect 以使用單一 Radius 參數,而非 2 軸的 X 和 y 軸半徑值 (I46d1b)

  • Recompose 可組合項已經不再是實用的抽象層。多數重組作業應該都是因為 MutableState 指派項目才會執行。除此之外,建議您使用 invalidate 函式來觸發針對目前範圍的重組作業。(Ifc992)

  • 取代了 Px 類別在各個 Compose 類別中的用例;這是大規模重構工作的一個環節,目標是讓像素參數僅採用 Dp 和基元類型 (Iede0b)

  • 變更 Compose 編譯器的程式碼產生策略。在變更之前,Compose 編譯器會將呼叫轉換為可組合函式。經此變更之後,我們現在可以轉換可組合函式的主體,並在多數情況下維持呼叫位置不變。

    也就是說,與 Compose 執行階段進行通訊的大多數邏輯,都是在函式主體的開頭 (而不是在呼叫位置) 執行。

    這應該是針對所有 Compose 使用情形的原始碼相容性變更。這項變更生效後,大多數 Compose 使用者都無需更新任何程式碼。

    為了配合這項異動,所有可組合函式的 JVM 簽名皆已變更。接受單一參數的可組合函式已轉換為接受 3 個參數的函式,外加的參數為 Composer (也就是「key」整數),是用於透過呼叫傳播中繼資料的位元遮罩整數。

    Compose 也會將預設引數轉換為可組合的函式。此舉不會引入函式本身的額外合成預設超載,因此這項變更將導致接受定義的函式變少。

    由這種情況產生的已知預期行為變更:

    1. 部分呼叫會略過先前不會略過的部分
    2. 系統現可正確訂閱及處理預設引數運算式中的可組合運算式

    這項工作包含以下最佳化作業: 1. 參數的比較結果會透過呼叫圖傳播到其他可組合函式。這將導致執行階段的比較項目更少、縮減運算單元資料表的大小,以及略過更多先前未略過的可組合函式。 2. 系統在執行階段不會再比較或儲存在編譯時間判定為「靜態」的參數。這樣可以減少比較項,並縮減運算單元資料表的大小。 3. 函式主體的控制流結構可用於盡可能減少產生的群組數量。這麼做可減少運算單元資料表大小,並降低執行階段 4 的工作負擔。如果未在函式主體內使用調度和接收器參數,則在判斷函式是否可略過時不會將這些參數納入考量。

    多數破壞性變更都是針對編譯器直接指定的 API,因此不會影響 Compose 的一般使用情形: 1. Composer::startExpr 已移除 2. Composer::endExpr 已移除 3. Composer::call 已淘汰 4. 移除 key 的非變化版本超載。往後請使用 vararg 版本。5. Pivotal 註解已淘汰。請改為使用 key。 6. ScopeUpdateScope::updateScope 已變更,現在預期接收 Function3,而不是 Function1 7. restartableFunction 和 restartableFunctionN 經更新後可納入其他編譯時間參數 (I60756b/143464846)

  • 移除了已淘汰的 LayoutAlign 修飾詞。(I10877)

  • 移除了 RepaintBoundary,改用 DrawLayerModifier (I00aa4)

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

  • 將 ButtonStyle 替換成專用函式,並移除了文字 (字串) 超載。如需使用資訊,請參閱更新後的範例。(If63abb/146478620b/146482131)

  • 突破 Environments API 的變更。詳情請參閱記錄檔和 Ambient<T> 說明文件 (I4c7eeb/143769776)

  • 將 TextDirection 的預設行為改由 LayoutDirection 判定。例如,如果 LayoutDirection 為 RTL,預設的 TextDirection 就會是 RTL。過去為 TextDirection.ContentOrLtr/Rtl (I4e803)

  • 漏洞修正:將 AntatedString 設為字型粗細和字型樣式時,文字無法正常顯示。(I77a9d)

  • 為 Text() 新增常用參數。如果您目前建立的本機文字樣式旨在傳遞少量參數,例如 Text(style = TextStyle(textAlign = TextAlign.Center)),您現在可以直接提供參數:Text(textAlign = TextAlign.Center) (I82768)

  • ui-android-text 模組已重新命名為 ui-text-android (I68cbe)