Compose Material 3

使用 Material Design 3(新一代 Material Design)组件构建 Jetpack Compose UI。Material 3 中包括了更新后的主题和组件,以及动态配色等 Material You 个性化功能,旨在与新的 Android 12 视觉风格和系统界面相得益彰。
最近更新时间 稳定版 候选版 Beta 版 Alpha 版
2024 年 2 月 21 日 1.2.0 - - 1.3.0-alpha01

结构

Compose 由 androidx 中的 7 个 Maven 组 ID 构成。每个组都包含一套特定用途的功能,并各有专属的版本说明。

下表介绍了各个组的内容,点击链接即可查看其版本说明。

说明
compose.animation在 Jetpack Compose 应用中构建动画,丰富用户体验。
compose.compiler借助 Kotlin 编译器插件,转换 @Composable functions(可组合函数)并启用优化功能。
compose.foundation使用现成可用的构建块编写 Jetpack Compose 应用,还可扩展 Foundation 以构建您自己的设计系统元素。
compose.material使用现成可用的 Material Design 组件构建 Jetpack Compose UI。这是更高层级的 Compose 入口点,旨在提供与 www.material.io 上描述的组件一致的组件。
compose.material3使用 Material Design 3(新一代 Material Design)组件构建 Jetpack Compose UI。Material 3 中包括了更新后的主题和组件,以及动态配色等 Material You 个性化功能,旨在与新的 Android 12 视觉风格和系统界面相得益彰。
compose.runtimeCompose 编程模型和状态管理的基本构建块,以及 Compose 编译器插件的目标核心运行时。
compose.ui与设备互动所需的 Compose UI 的基本组件,包括布局、绘图和输入。

声明依赖项

如需添加 Compose 的依赖项,您必须将 Google Maven 制品库添加到项目中。如需了解详情,请参阅 Google 的 Maven 制品库

在应用或模块的 build.gradle 文件中添加所需工件的依赖项:

Groovy

dependencies {
    implementation "androidx.compose.material3:material3:1.2.0"
    implementation "androidx.compose.material3:material3-window-size-class:1.2.0"
    implementation "androidx.compose.material3:material3-adaptive:1.0.0-alpha06"
    implementation "androidx.compose.material3:material3-adaptive-navigation-suite:1.0.0-alpha04"
}

android {
    buildFeatures {
        compose true
    }

    composeOptions {
        kotlinCompilerExtensionVersion = "1.1.1"
    }

    kotlinOptions {
        jvmTarget = "1.8"
    }
}

Kotlin

dependencies {
    implementation("androidx.compose.material3:material3:1.2.0")
    implementation("androidx.compose.material3:material3-window-size-class:1.2.0")
    implementation("androidx.compose.material3:material3-adaptive:1.0.0-alpha06")
    implementation("androidx.compose.material3:material3-adaptive-navigation-suite:1.0.0-alpha04")
}

android {
    buildFeatures {
        compose = true
    }

    composeOptions {
        kotlinCompilerExtensionVersion = "1.1.1"
    }

    kotlinOptions {
        jvmTarget = "1.8"
    }
}

如需详细了解依赖项,请参阅添加 build 依赖项

反馈

您的反馈将帮助我们改进 Jetpack。如果您发现了新问题,或对此库有任何改进建议,请告诉我们。创建新问题前,请先查看此库中的现有问题。您可以点击星标按钮,为现有问题投票。

创建新问题

如需了解详情,请参阅问题跟踪器文档

Compose Material3 自适应导航套件版本 1.0

版本 1.0.0-alpha03

2024 年 2 月 7 日

发布了 androidx.compose.material3:material3-adaptive-navigation-suite:1.0.0-alpha03androidx.compose.material3:material3-adaptive-navigation-suite-android:1.0.0-alpha03androidx.compose.material3:material3-adaptive-navigation-suite-desktop:1.0.0-alpha03版本 1.0.0-alpha03 中包含这些提交内容

API 变更

  • 将软件包名称从 navigation-suite 更新为 navigationsuite (I7eff7)
  • 更新了 API 中提供 MutableInteractionSource 的 Material3 组件,现在公开了默认值为 null 的可为 null MutableInteractionSource。这里不存在语义更改:传递 null 意味着您不想提升 MutableInteractionSource,并将根据需要在组件内创建它。更改为 null 可让某些组件从不分配 MutableInteractionSource,并允许其他组件仅在需要时延迟创建实例,从而提升这些组件的性能。如果您未使用传递给这些组件的 MutableInteractionSource,建议您改为传递 null。此外,我们还建议您在自己的组件中进行类似的更改。(I41abbb/298048146

版本 1.0.0-alpha02

2023 年 12 月 13 日

发布了 androidx.compose.material3:material3-adaptive-navigation-suite:1.0.0-alpha02androidx.compose.material3:material3-adaptive-navigation-suite-android:1.0.0-alpha02androidx.compose.material3:material3-adaptive-navigation-suite-desktop:1.0.0-alpha02版本 1.0.0-alpha02 中包含这些提交内容

新功能

bug 修复

  • 修复了当根 surface 具有 modifier.fillMaxSize 时导航组件会填满整个屏幕的问题。(c9cf250b/312664933

版本 1.0.0-alpha01

2023 年 11 月 15 日

发布了 androidx.compose.material3:material3-adaptive-navigation-suite:1.0.0-alpha01版本 1.0.0-alpha01 中包含这些提交内容

新功能

Compose Material3 自适应版本 1.0

版本 1.0.0-alpha06

2024 年 2 月 7 日

发布了 androidx.compose.material3:material3-adaptive:1.0.0-alpha06androidx.compose.material3:material3-adaptive-android:1.0.0-alpha06androidx.compose.material3:material3-adaptive-desktop:1.0.0-alpha06版本 1.0.0-alpha06 中包含这些提交内容

新功能

  • ThreePaneScaffoldNavigator 返回导航添加了其他行为选项。(I858aa
  • 向导航历史记录添加了可选的目的地内容。(Ibd7e6

版本 1.0.0-alpha05

2024 年 1 月 24 日

发布了 androidx.compose.material3:material3-adaptive:1.0.0-alpha05androidx.compose.material3:material3-adaptive-android:1.0.0-alpha05androidx.compose.material3:material3-adaptive-desktop:1.0.0-alpha05版本 1.0.0-alpha05 中包含这些提交内容。

新功能

  • 在 Scaffold 导航和值计算中支持历史记录感知 (I71d46)

版本 1.0.0-alpha04

2024 年 1 月 10 日

发布了 androidx.compose.material3:material3-adaptive:1.0.0-alpha04androidx.compose.material3:material3-adaptive-android:1.0.0-alpha04androidx.compose.material3:material3-adaptive-desktop:1.0.0-alpha04版本 1.0.0-alpha04 中包含这些提交内容

新功能

  • 在窗格基架中添加了无边框支持 (I1b462)

API 变更

  • 将 Posture 中的合页边界属性移到了合页信息列表 (I24f90)

bug 修复

  • 修复了 AnimatedPane 未重组的问题 (c3f573d)

版本 1.0.0-alpha03

2023 年 12 月 13 日

发布了 androidx.compose.material3:material3-adaptive:1.0.0-alpha03androidx.compose.material3:material3-adaptive-android:1.0.0-alpha03androidx.compose.material3:material3-adaptive-desktop:1.0.0-alpha03版本 1.0.0-alpha03 中包含这些提交内容

API 变更

  • 将基架角色更改为 ThreePaneScaffoldRole 的别名。(I65bd1
  • 为 Scaffold 角色创建基类 (I4784d)
  • AnimatedPane 的内容中移除了不必要的参数 (Ibc73b)
  • 重命名了 collectWindowSizeAsState 并改为返回原始值 (I480f4)

版本 1.0.0-alpha02

2023 年 11 月 29 日

发布了 androidx.compose.material3:material3-adaptive:1.0.0-alpha02androidx.compose.material3:material3-adaptive-android:1.0.0-alpha02androidx.compose.material3:material3-adaptive-desktop:1.0.0-alpha02版本 1.0.0-alpha02 中包含这些提交内容

API 变更

  • 将导航 API 从自适应 Scaffold API 中分离出来。(Ic4045
  • 移除了 GutterSize 类。(I785b3

bug 修复

  • 修复了未使用 AnimatedPane 时窗格无法切换的问题 (d88f181)

版本 1.0.0-alpha01

2023 年 11 月 15 日

发布了 androidx.compose.material3:material3-adaptive:1.0.0-alpha01版本 1.0.0-alpha01 中包含这些提交内容

新功能

Material3 自适应条件 API:

Material3 自适应窗格 Scaffold 指令 API:

Material3 自适应窗格 Scaffold API:

Compose Material 3 版本 1.3

版本 1.3.0-alpha01

2024 年 2 月 21 日

发布了 androidx.compose.material3:material3-*:1.3.0-alpha01版本 1.3.0-alpha01 中包含这些提交内容

新功能

  • 更新了 Compose M3 ModalBottomSheet,以支持 U+ 上的预测性返回(Iccf32b/281967264b/304850357
  • 更新了 Compose M3 SearchBar,以支持在 U 及更高版本上使用预测性返回 (I657f8)
  • 更新了滑块,通过添加间隙和停止指示器来改进无障碍功能。(I3058e
  • 更新了 ProgressIndicator,通过添加间隙和停止指示器来改进无障碍功能。(I21451
  • 添加了适用于富媒体提示的默认插入符号,新的富媒体提示 API 现在允许在给定锚点 LayoutCoordinates 绘制自定义插入符号。(Ifd42c

行为变更

  • Material 组件已迁移为使用新的涟漪 API,并且不再查询 RippleTheme

API 变更

  • 有趣的 drawStopIndicator 现已公开。(I3f59f
  • DatePickerformatWithSkeleton 函数标记为内部函数 (Ic65dc)
  • DropdownMenu 现在支持自定义颜色、形状、高度和边框。(I8e981b/289554448b/301887035b/283654243
  • 更新了 API 中提供 MutableInteractionSource 的 Material3 组件,现在公开了默认值为 null 的可为 null MutableInteractionSource。这里不存在语义更改:传递 null 意味着您不想提升 MutableInteractionSource,并将根据需要在组件内创建它。更改为 null 可让某些组件从不分配 MutableInteractionSource,并允许其他组件仅在需要时延迟创建实例,从而提升这些组件的性能。如果您未使用传递给这些组件的 MutableInteractionSource,建议您改为传递 null。此外,我们还建议您在自己的组件中进行类似的更改。(I41abbb/298048146
  • 添加了 RippleConfigurationLocalRippleConfiguration,以允许使用固定值按组件 / 子树自定义涟漪效果。例如,您可以更改无法控制的组件的颜色,或者为组件停用涟漪效果。在大多数情况下,应使用默认值:这些 API 是自定义个别组件 / 有限的子树的应急方法。如需进行更广泛的更改和自定义设计系统,您应改用 createRippleModifierNode 构建自己的涟漪效果。(I7b5d6b/298048146
  • 在 Material3 中添加了新的涟漪 API,以取代已废弃的 rememberRipple。此外,还添加了临时 CompositionLocal LocalUseFallbackRippleImplementation,以将 Material3 组件还原为使用已废弃的 rememberRipple / RippleTheme API。此变更将在下一个稳定版中移除,仅在您提供自定义 RippleTheme 的情况下作为临时的迁移辅助工具。(I34cbcb/298048146

bug 修复

  • 移除了 ModalBottomSheet 中的子组合,以提高性能。修复了 ModalBottomSheetLookaheadScope 结合使用在特定情况下可能会崩溃的问题。(I2a198
  • 移除了 BottomSheetScaffold 中的子组合,以提高性能。修复了 BottomSheetScaffoldLookaheadScope 组合在特定情况下会崩溃的问题。(Ie6401
  • 调整徽章对齐方式,使其相对于右上角更接近锚定内容的中心。(I18a28
  • 修复了 DateRangePicker 存在的 a11y 问题,即年份文本标题被传达为可供屏幕阅读器、开关控制和 Voice Access 用户可操作的问题。(I2ac55)
  • 修复了 mediumTopAppBarColors 参数顺序 bug。(Ibe64a

版本 1.2

版本 1.2.0

2024 年 2 月 7 日

发布了 androidx.compose.material3:material3-*:1.2.0版本 1.2.0 中包含这些提交内容

已知问题

  • 作为性能改进变更的一部分,PrimaryTabRow 中引入了 View-Compose 互操作渲染 bug。解决方法是将 TabRowTabRowDefaults.PrimaryIndicator 一起使用

自 1.1.0 以来的重要变更

新的 Material Design 3 组件

增强了现有 Material Design 3 组件。

将实验性 API 升级到了稳定版!

性能提升

版本 1.2.0-rc01

2024 年 1 月 24 日

发布了 androidx.compose.material3:material3-*:1.2.0-rc01版本 1.2.0-rc01 中包含这些提交内容

bug 修复

  • 修复了 mediumTopAppBarColors 参数顺序 bug。(Ibe64a
  • 修复了 CardDefaults.cardColors1.2.0-beta02 中引入的未根据 containerColor 参数值更新 contentColor 的 bug。(Iee041b/319671246
  • 修复了 1.2.0-beta02 中引入的 disabledContentColor 中的 bug,并添加了小的优化。(I6dda1b/318428829

版本 1.2.0-beta02

2024 年 1 月 10 日

发布了 androidx.compose.material3:material3-*:1.2.0-beta02版本 1.2.0-beta02 中包含这些提交内容

已知 bug

  • 默认情况下,IconButtonColors 中的 bug 会将 disabledContentColor 分配给 LocalContentColor 的 Alpha 版 (0.38f),而不是用户指定的 contentColor。解决方法是明确设置 disabledContentColor。此问题将在下一版本中修复。

API 变更

  • 添加了为普通 Tooltip API 启用提示插入符号的功能。(Ibf767)
  • SwipeToDismissStaterememberSwipeToDismissSwipeToDismissValue 均已重命名为具有 _SwipeToDismissBox_。(I68d6d

bug 修复

  • 修复了 ListItem 结束内边距值,以符合规范。(Ibd68bb/305342674
  • 轮廓卡片的轮廓颜色现已正确映射到 OutlineVariant。(I75480b/310979715
  • 动态配色现在会从系统定义的颜色角色中提取。这可以提高可访问内容的对比度,并使动态配色更符合 Material 规范。(I1de96)
  • 修复了当 android:enableOnBackInvokedCallback="true" 时,Android T/13 及更高版本上的 ModalBottomSheet 返回处理问题。(I728dcb/306196110

版本 1.2.0-beta01

2023 年 12 月 13 日

发布了 androidx.compose.material3:material3-*:1.2.0-beta01版本 1.2.0-beta01 中包含这些提交内容

API 变更

  • TabIndicatorScope 标记为实验性。(I45c88
  • 移除了提示的已废弃的实验性 API。(I438cb)
  • 将新的 TabRow 重载更改为不使用子组合。这会导致使用提供的自定义修饰符构建 TabRow 指示器的不同方式。(Ife741)
  • 废弃了 DismissDirectionDismissValue API。这些控件已合并到 SwipeToDismissValue,其值同时表示 SwipeToDismissBox 的位置和方向。DismissState.progress 现在标记为 0.01.0 之间的 FloatRange。现已移除了 DismissState 已废弃的 Saver 和 Constructor。SwipeToDismiss 组件、状态和默认对象已标记为实验性。(Ib54f2

bug 修复

  • 现在,PullToRefresh 的默认指示器是开放式箭头,而不是实心三角形。(I67be3

版本 1.2.0-alpha12

2023 年 11 月 29 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha12版本 1.2.0-alpha12 中包含这些提交内容

API 变更

  • RangeSlider 现在接受 Kotlin 范围(例如,0f..1f),而不是自定义 FloatRange 值类。SnapFlingBehavior.kt 现在也使用 Kotlin 范围。(I025cb)
  • 将修饰符工厂函数标记为 @Stable。(Ib109f

版本 1.2.0-alpha11

2023 年 11 月 15 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha11版本 1.2.0-alpha11 中包含这些提交内容

新功能

  • 实现 PullToRefreshContainerPullToRefreshState,它们共同在 Material3 中提供了一个拉取刷新实现。(I16456b/261760718

API 变更

  • SwipeToDismissBox DismissDirectionDismissValue 标记为实验性。(I517b0
  • 已将 SwipeToDismiss 重命名为 SwipeToDismissBox。已将 background 重命名为 backgroundContent,并将 dismissContent 重命名为尾随 content lambda。(I7f4d3
  • ChipElevationSelectableChipElevation 的构造函数设为公开。(Ie0c48b/308432421
  • 正在添加“ModalBottomSheetProperties”。正在将 securePolicy 移入 ModalBottomSheetProperties。正在将 isFocusableshouldDismissOnBackPress 添加到 ModalBottomSheetProperties。这些新的布尔值有助于确定模态底部动作条应如何处理 IME 事件。(Iea56fb/278216859
  • 更新了 RangeSliderSlider 状态,以移除 initialOnValueChange、初始前缀和相应的 kdocs。(I57d30
  • 废弃了 ChipBorder 类及其关联的函数调用,建议直接使用 BorderStroke。(I89cc2
  • Foundation 工具提示 API 现为 @ExperimentalFoundationApi。(I30b0b
  • 不再废弃 TabRowScrollableTabRow。新的主要变体和次要变体标记为实验性。(I0def6
  • 过滤和输入条状标签现在直接使用 BorderStroke。(I07a8d
  • SegmentedButton 现在直接使用 BorderStroke。(I89b9b
  • 将通用 AlertDialog 函数重命名为 BasicAlertDialog,并废弃了以前的函数。(Idbe52)
  • SwipeToDismiss API 重命名为了 SwipeDismiss,并将新的 SwipeDismiss API 提升到了稳定版。(I14cbe)
  • 向提示 API 添加了 tonalElevationshadowElevation。此外,将 TooltipBoxPlainTooltipRichTooltip API 移回实验性 API,因为它们被意外发布为稳定版。(If0f66b/293939035
  • 将实验性条状标签 API 升级为稳定版。(Iea2c3)
  • 从 Material3 可点击卡片中移除了 @ExperimentalMaterial3Api 注解。(I88dbf)

bug 修复

  • 修复了在使用嵌套 Lookahead 和延迟布局时 SwipeToDismiss 在某些情况下会崩溃的问题。(Ica8d1b/297226562

版本 1.2.0-alpha10

2023 年 10 月 18 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha10版本 1.2.0-alpha10 中包含这些提交内容

API 变更

  • BadgeBadgedBox 提升到了稳定版。(I67f16b/261565132
  • securePolicy 作为参数添加到 ModalBottomSheet,以便用户可以定义 WindowManager.LayoutParams.FLAG_SECURE 的行为。(Icdac8b/296250262
  • 添加了将 progress 作为 lambda 的新 LinearProgressIndicatorCircularProgressIndicator 过载。这些版本的性能应该比以前的版本更高。(I824e6b/295616656
  • StandardSizeClasses 重命名为 AllSizeClasses。(I8cb07)
  • 组合窗口大小类的计算函数。(Iad935

bug 修复

  • 修复了当显示的月份处于允许的年份范围边缘时,快速点击导航箭头按钮会导致 DatePicker 崩溃的问题。(I46f36b/290954897b/297002119
  • [侧边导航栏/导航栏] 支持指示符使用透明颜色。(Ie0a9bb/267289987

版本 1.2.0-alpha09

2023 年 10 月 4 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha09版本 1.2.0-alpha09 中包含这些提交内容

API 变更

  • 迁移了 ModalNavigationDrawerDismissibleNavigationDrawer,以使用新的 AnchoredDraggable API。DrawerStateanimateTo 已替换为 open 和 close 方法,并且偏移现在作为浮点数(而不是状态对象)公开。您可以直接通过 currentOffset 访问该偏移量。(I0a72c
  • 添加了非可组合函数,用于直接创建 DatePickerStateDateRangePickerState。在需要时,这些函数可用作可组合的 rememberDatePickerStaterememberDateRangePickerState 函数的替代函数。(I70326b/291524052
  • 已修复和可滚动的 TabRows 现在具有主要变体和次要变体。这些控件会正确映射到 Material3 中定义的颜色和指示器行为。
  • PrimaryScrollableTabRowSecondaryScrollableTabRow 现在公开滚动状态。(Iec8f5b/260572337
  • 添加了新的 sheetMaxWidth 参数,开发者可以设置该参数来指定工作表将跨越的最大宽度。如果需要跨屏幕宽度的工作表,可以为该参数传入 Dp.Unspecified。(Ifb7c9b/266697696
  • PlainTooltipBoxRichTooltipBox API 重新添加为已废弃的方法。(I246fa

bug 修复

  • 修复了以下问题:使用 DatePickerFormatter(在转换为日期模式(例如 YY)后,日期框架会保持不变)对 DatePicker 进行初始化时会出现崩溃问题。(I01f29

版本 1.2.0-alpha08

2023 年 9 月 20 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha08版本 1.2.0-alpha08 中包含这些提交内容

行为破坏性变更

  • ColorScheme 现在不可变,这使得个别颜色更新的效率较低,但会让更普遍的颜色使用变得更加高效。之所以采用这种更改,是因为大多数应用都不会将更新个别颜色作为主要用例。这仍然可以实现,但其重组次数比以前要多,反过来我们会通过所有 Material 代码大幅减少状态订阅量,并影响更多标准用例的初始化和运行时费用。(Ic447db/297212873
  • 色调高度不再以动画形式呈现在不同的互动状态下,以符合规范。(Icdd12)

API 变更

  • 添加了以 BottomAppBarScrollBehavior 作为参数的新 BottomAppBar,以便在滚动内容时自动隐藏它。还添加了 FabPosition.EndOverlay,允许 FAB 叠加在 Scaffold 中的底部应用栏上,而不是锚定在 Scaffold 上方。(Iecb47
  • 添加了一个简单的 Label 组件,该组件基于 BasicTooltipBox,该组件在标签边界之外点按时不会关闭。(I821f9

bug 修复

  • 不再使用 rememberSaveable 作为提示。(Icc131b/299500338
  • 引入了临时标志来控制 Scaffold 是否应在测量期间或放置期间测量其子项。默认情况下,系统会以衡量为单位进行衡量。如果您遇到与新行为相关的问题,请提交问题。(I0b354
  • 通过对设备屏幕宽度使用正确的测量值,修复了 BottomSheet 中的水平边缘到边缘问题。(I1df0cb/299058752
  • 修复了 ModalBottomSheet 通过在工作表上向下滑动来关闭它时不调用 onDismissedRequest 的 bug。(Idfdd8)

版本 1.2.0-alpha07

2023 年 9 月 6 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha07版本 1.2.0-alpha07 中包含这些提交内容

新功能

  • compose material 1.6.0-alpha05 中新增了对自动镜像图标的支持。如需详细了解自动镜像图标,请参阅版本说明

API 变更

  • SliderState 实现了 DraggableState (I9b116)
  • 将形状更改为必需参数。形状辅助函数中的 position 已重命名为 index。(I34941
  • 更新 DatePicker formatWithSkeleton,以包含一个地图,作为缓存来提升性能。(I3195f
  • compose.foundation 添加了 BasicTooltipBox,并更新了 PlainTooltipBoxRichTooltipBox,以便将 TooltipBox 与新的 PlainTooltipRichTooltip 可组合项搭配使用。(I79e1d

bug 修复

  • dynamicLightColorSchemedynamicDarkColorScheme 现在会为 Surface 和 surfaceContainer 角色返回更高的色度颜色。(I5e901
  • 修复了在 LookaheadScope 内的 Scaffold 中使用 Subcomposition 的某些组件(例如 BottomSheetScaffold)会过早读取其大小的问题。(I297b4I871f1b/295536718

版本 1.2.0-alpha06

2023 年 8 月 23 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha06版本 1.2.0-alpha06 中包含这些提交内容

bug 修复

  • 修复了 DropdownMenuoffset 计算问题,使 x 偏移量仅取决于本地布局方向,并且在菜单靠近屏幕底部时不会再反转 y 偏移量。(Iccc74b/294103942
  • 修复了 DropdownMenuoffset 计算问题,使 x 偏移量仅取决于本地布局方向,并且在菜单靠近屏幕底部时不会再反转 y 偏移量。(Ib87a2b/294103942

版本 1.2.0-alpha05

2023 年 8 月 9 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha05版本 1.2.0-alpha05 中包含这些提交内容

API 变更

  • 更新了复选框和 TriStateCheckbox 颜色。CheckboxDefaults.colors() disabledUncheckedColor 现在仅影响复选框的边框。在停用和未勾选时,需要您设置内部框颜色的特殊情况需要一个自定义构造的 CheckboxColors 实例,其中包含所需的颜色值。(I77d17b/291943198

版本 1.2.0-alpha04

2023 年 7 月 26 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha04版本 1.2.0-alpha04 中包含这些提交内容

新功能

  • 实验性 Segmented Button API (Ifc8fb)
  • 分隔线现在包含一个参数,用于控制方向以支持垂直分隔线。(I4c899b/288438593

API 变更

  • 我们正在将密度依赖项移至组件级别。这适用于以下组件:SwipeToDismiss 和基于工作表的组件。请使用提供的新重载(其中密度是参数)。(I1846e
  • 用于向可组合项指定允许的输入的额外注解 (Ief234)
  • 分别使用 SelectableSegmentedButtonRowToggelableSegmentedButtonRow 为细分按钮添加了图标参数、分屏语义,以便可以选择分割按钮以实现单选,还可以切换按钮来实现多选。(I38740
  • 分隔线已重命名为 HorizontalDivider。添加了 VerticalDivider 功能。(I5975c
  • 在实验性 Material3 API 中,更改了 ClosedFloatingPointRange 用于更轻量的 FloatRange,以最大限度地减少自动装箱。(I4aab5
  • FabPosition 添加了新的开始对齐(Ib7aeab/170592777

bug 修复

版本 1.2.0-alpha03

2023 年 6 月 21 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha03版本 1.2.0-alpha03 中包含这些提交内容

行为变更

  • 现在,在 Material 3 排版中,includeFontPadding 默认为 false。默认行高样式也已更改为 Trim.NoneAlignment.Center,并且显式 lineHeight(在 sp 中)已添加到 TypographyTextStyle。如果您想自定义这些值,请参阅 API 文档;如需更深入地了解这些更改,请参阅这篇博文。(I6266fIcabc3

新功能

  • RangeSlider 添加了重载,它是组件的有状态版本。创建了 RangeSliderState,用于保存当前活跃轨道的所有信息、RangeSlider 组件的测量结果,以及拖动和手势逻辑。(I8c270
  • 搜索栏现在通过新添加的 shadowElevation 参数支持阴影。(Ia5369b/271040353
  • ColorScheme 现在支持新的 SurfaceContainer 角色
  • 现在可以使用 LocalTonalElevationEnabled CompositionLocal 停用 Surface 色调高度叠加层。(Ic203cb/277774590

API 变更

  • 打开组件颜色构造函数。(I8c4a6
  • 向两个提示 API 添加了可聚焦参数,以便开发者决定是否使用触摸事件。请注意,这可能会破坏无障碍功能焦点的自动遍历。(Ie32d8
  • 优化了性能和内存分配的可访问性。(Iede48
  • 公开了 DefaultSizeClasses 并为 WindowSizeClasses 创建 StandardSizeClasses (I91838)
  • WindowWidth/HeightSizeClass 更改为浮点值类 (Ie686e)

bug 修复

  • Scaffold 的 contentWindowInsets 参数现在遵循所使用的窗口边衬区。请注意,如果提供了这些参数,基于 topBarbottomBar 的内容内边距行为将保持不变。(I08b73b/264601542
  • 修正了顶部应用栏居中的对齐方式,以确保长标题不会呈现在操作图标或导航图标之上。(I4369fb/236994621
  • 标签页位置现在强制将内容宽度下限设为 24dp。这样可以为标签页指示器提供可访问的触摸目标。(Id8861
  • dynamicLightColorSchemedynamicDarkColorScheme 中的动态调色板现在支持新的 Surface 角色。(I1252e
  • 更新了标志通知对齐方式,以便在与曾祖父/外祖父发生冲突时不被裁剪。(Idf75a

版本 1.2.0-alpha02

2023 年 5 月 24 日

发布了 androidx.compose.material3:material3-*:1.2.0-alpha02版本 1.2.0-alpha02 中包含这些提交内容

API 变更

  • ModalBottomSheet 添加了窗口边衬区参数。
    • 现在可以在状态栏后面绘制 ModalBottomSheet 的纱罩,并将 windowInsets 设为 0
    • 更新了默认的 ModalBottomSheet 功能,使其不在系统栏(包括导航栏)之外
    • 在无边框模式下,通过拖动手柄处理状态栏边衬区。
    • BottomSheetDefaults 包含 BottomSheetWindow 的窗口边衬区。(I31200b/274872542b/272973615b/272334475b/268432129b/275849044、、、、、275}106}
  • 废弃了 Indicator,并添加 Primary/SecondaryIndicator 以符合 M3 规范。PrimaryIndicator 用于匹配标签页内容的宽度,而 SecondaryIndicator 会跨越整个可用宽度。SecondaryIndicator 相当于现已废弃的 Indicator,可以作为直接替换项。(I27604
  • 添加了一个选项,可在构造 DropdownMenuExposedDropdownMenu 时传入 ScrollState,以控制所显示菜单项的垂直滚动状态。(Ia0734b/185304441
  • Slider 添加了重载,它是组件的有状态版本。创建了 SliderState,用于保存当前活跃轨道的所有信息、Slider 组件的测量结果,以及拖动和手势逻辑。(I124a5
  • 将语义属性 isContainer 重命名为 isTraversalGroup (I121f6)
  • 添加了具有完整参数列表的经过优化的 TextStyle.merge(...)。(Iad234b/246961787
  • 创建了 TooltipStateRichTooltipStatePlainTooltipState 公共接口。为默认状态添加了 RichTooltipStateImplPlainTooltipStateImpl。添加了 remember*State 函数来获取这些已实现的状态。移除了 TooltipSync,改为使用 TooltipDefault.GlobalMutatorMutex。(I7813d
  • 更新了 DatePickerColors,针对日期选择器分隔线、导航和文本输入字段颜色添加了额外的自定义选项。(I1a685b/274626815
  • DatePickerStateDateRangePickerState 现在是具有默认实现的公共接口,可由 rememberDatePickerStaterememberDateRangePickerState 检索。(I71c52
  • DatePickerDateRangePicker 中移除了 dateValidator,并引入了 SelectableDates 接口,该接口可对状态进行设置,以控制界面中可供选择的日期或年份。(Ic2fc6)
  • 从稳定版 API 中移除了 TimePicker,状态 API 预计会进一步更改 (I3f39a)
  • ModalBottomSheet 已改为仅限 Android。不建议将 ModalBottomSheet 用于桌面设备,而且相应功能目前未得到积极维护。(Ib3778

bug 修复

  • 修复了当操作相互堆叠以适应对话框宽度时,AlertDialog 关闭操作会显示在确认操作下方。此修复使实现符合 Material Design 规范。(I029deb/235454277
  • 修复了 ListItem 为三行项目使用不正确的内边距的 bug。(I6e235
  • ModalBottomSheet 现在可以显示 IME 键盘(Idc508b/262140644b/268380384b/272483584

版本 1.2.0-alpha01

2023 年 5 月 10 日

发布了 androidx.compose.material3:material3:1.2.0-alpha01androidx.compose.material3:material3-window-size-class:1.2.0-alpha01版本 1.2.0-alpha01 中包含这些提交内容

版本 1.1

版本 1.1.2

2023 年 9 月 20 日

发布了 androidx.compose.material3:material3:1.1.2androidx.compose.material3:material3-window-size-class:1.1.2版本 1.1.2 中包含这些提交内容

bug 修复

  • 修复了修饰符错误地传递给两个可组合项的问题。(b/282761472)
  • 修复了 TimePickerState 在初始化为 23 小时时会返回错误小时的问题。(b/278242122)
  • 修复了中午和分钟验证的初始切换状态。(b/269768197b/282790635
  • 修复了 state.hour 在晚上 11 点返回错误值的问题。(b/282761472b/278242122

版本 1.1.1

2023 年 6 月 21 日

发布了 androidx.compose.material3:material3:1.1.1androidx.compose.material3:material3-window-size-class:1.1.1版本 1.1.1 中包含这些提交内容

bug 修复

  • 添加了对不带 windowInset 参数的 ModalBottomSheet 的调用,以实现二进制文件兼容性。(Ib7959
  • ModalBottomSheet 添加了窗口边衬区参数。
    • 现在可以在状态栏后面绘制 ModalBottomSheet 的纱罩,并将 windowInsets 设为 0
    • 更新了默认的 ModalBottomSheet 功能,使其不在系统栏(包括导航栏)之外
    • 在无边框模式下,通过拖动手柄处理状态栏边衬区。
    • BottomSheetDefaults 包含 BottomSheetWindow 的窗口边衬区。(I31200b/274872542b/272973615b/272334475b/268432129b/275849044、、、、、275}106}

版本 1.1.0

2023 年 5 月 10 日

发布了 androidx.compose.material3:material3:1.1.0androidx.compose.material3:material3-window-size-class:1.1.0版本 1.1.0 中包含这些提交内容

1.1.0 的主要功能

新的 Material Design 3 组件

增强了现有 Material Design 3 组件。

将实验性 API 升级到了稳定版!

如需了解详情,请参阅这篇博文

版本 1.1.0-rc01

2023 年 4 月 19 日

发布了 androidx.compose.material3:material3:1.1.0-rc01androidx.compose.material3:material3-window-size-class:1.1.0-rc01版本 1.1.0-rc01 中包含这些提交内容

API 变更

  • 从稳定版 API 中移除了 TimePicker,状态 API 预计会进一步更改 (I3f39a)
  • ModalBottomSheet 已改为仅限 Android。不建议将 ModalBottomSheet 用于桌面设备,而且相应功能目前未得到积极维护。(Ib3778

版本 1.1.0-beta02

2023 年 4 月 5 日

发布了 androidx.compose.material3:material3:1.1.0-beta02androidx.compose.material3:material3-window-size-class:1.1.0-beta02版本 1.1.0-beta02 中包含这些提交内容

API 变更

  • SheetState 现在有可选的 skipHiddenState 参数
  • rememberStandardBottomSheetState 现在有可选的 skipHiddenState 参数
  • BottomSheetScaffold 现在具有定义的隐藏锚点,但默认情况下处于停用状态
  • 已更新 SheetState.requireOffset 文档
  • BottomSheetDefaults.MinimizedShape 已重命名为 BottomSheetDefaults.HiddenShapeI839f4b/273870234

bug 修复

  • 启用触摸探索后,不要将表盘从小时切换为分钟。(I717d0
  • ModalBottomSheetBottomSheetScaffold 拖动手柄语义现已合并。(I05afb)
  • BottomSheetScaffold 修饰符、containerColorcontentColor 参数现在仅影响内容。(I992cb)
  • 工作表内容的 BottomSheetScaffold nestedScroll 现在会实现快速滑动。(I992cb)

版本 1.1.0-beta01

2023 年 3 月 22 日

发布了 androidx.compose.material3:material3:1.1.0-beta01androidx.compose.material3:material3-window-size-class:1.1.0-beta01版本 1.1.0-beta01 中包含这些提交内容

API 变更

  • TimePicker 可组合项添加了布局类型参数。它允许根据屏幕配置使用不同的布局 (Ia0e16)
  • SearchBarDefaults 已被标记为实验性。(I65561
  • BottomSheetScaffold 添加了阴影高度 (I94e0f)
  • 添加了对显示不含标题部分的日期选择器的支持。API 进行了更改,以允许在创建日期选择器时传递 null 标题。您现在可以传递 null 标题、标题和 showToggleMode = false,以便显示无头选择器。(Id3f3ab/266132421b/267194809

bug 修复

  • 现在,搜索栏在闲置时会自动清除焦点。(I22a7cb/261444487
  • 更新了 DateRangePicker,以允许选择开始日期和结束日期相同的范围。(I16529b/272882497
  • 现在,当字体大小小于预期时,文本字段可以正确定位其文本元素。这可能会导致应用中的像素出现一些变化,具体取决于字体设置和脚本。(I8b8d0
  • 底部动作条语义操作现在具有标签。(I277b0

版本 1.1.0-alpha08

2023 年 3 月 8 日

发布了 androidx.compose.material3:material3:1.1.0-alpha08androidx.compose.material3:material3-window-size-class:1.1.0-alpha08版本 1.1.0-alpha08 中包含这些提交内容

新功能

  • 添加了对 BottomSheetScaffoldBottomSheetScaffoldState 的支持。(I063d4

API 变更

  • DatePickerStateDateRangePickerState 添加了功能,以允许在初始创建状态之后设置日期,以及通过设置 null 时间戳来重置选择。手动设置日期时应谨慎。如果所提供的日期不符合前提条件,新的 setSelection 函数将抛出异常(请参阅文档)。(Ifa645b/268609314b/270427389
  • 将收起的 SheetValue 重命名为 PartiallyExpanded,以更准确、更灵活地描绘此状态下的行为。(Ia1491)
  • ListItem 参数名称更新为 _content,而不是 _text。在相关情况下,默认 getter 现在为 ReadOnlyComposables。(I69a25
  • 从实验性版本升级交互式 Surface API。(I90d59b/261561812

bug 修复

  • 修复了以下问题:ModalBottomSheetHalfExpanded 状态计算不正确,且动作条看起来像是悬浮的。(I45e84b/268411386
  • ModalBottomSheet 添加了 confirmValueChange 检查,用于点按纱罩。(I2311ab/270425759
  • 将语义 BottomSheet 操作移至拖动手柄。(I158ba
  • ModalBottomSheet 现在命令聚焦于启动,处理返回按钮。(I4d2ab
  • 现在,在嵌套滚动快速滑动期间也会处理 ModalBottomSheet onDismissRequest。(I655c5b/268433166

版本 1.1.0-alpha07

2023 年 2 月 22 日

发布了 androidx.compose.material3:material3:1.1.0-alpha07androidx.compose.material3:material3-window-size-class:1.1.0-alpha07版本 1.1.0-alpha07 中包含这些提交内容

新功能

  • 添加了可与 rememberTimePickerState() 搭配使用的时间输入可组合项,它遵循 M3 时间输入规范 (Ia4fab)
  • 添加了用于选择日期范围的 Material 3 DateRangePicker API。(I7a6c3b/267194809
  • 添加了 Material 3 输入模式支持,以便通过 DateRangePicker API 选择日期范围。(Ifdbc4)
  • 文本字段颜色现在允许自定义:
    • 输入字段和占位符文本的颜色基于焦点和错误状态。textColor 参数已重命名为 unfocusedTextColorplaceholderColor 已重命名为 unfocusedPlaceholderColor
    • 已填充文本字段的容器颜色(基于错误状态),其中包含新的 errorContainerColor 参数。
  • 公开的下拉菜单文本字段颜色已更新为包含参数,以支持新的前缀和后缀 API。(I9c8b4b/254284181b/264766350

API 变更

  • 还原了部分 Slider API 版本,并移除了带自定义滑块和滑道的新实验性滑块所涵盖的冗余滑块重载。提升 RangeSlider 以使其稳定。(Ie8fbd)
  • 在条状标签的高度函数中,已将 defaultElevation 重命名为 elevation。(I0f872
  • 以下 Material 3 文本字段 API 不再处于实验阶段:TextFieldOutlinedTextFieldtextFieldWithLabelPaddingtextFieldWithoutLabelPaddingoutlinedTextFieldPadding。(Ieb5c0b/261561819
  • TimePickers is24Hour 使用系统设置 (I18856)
  • 从 Scaffold API 中移除了实验性注解。(Ibb51eb/261565765b/261436953

bug 修复

  • ModalBottomSheet 的默认形状现在始终为 SheetDefaults.ExpandedShape。(I0dfca)
  • 改进了 Material 3 DatePickerDateRangePicker 的无障碍功能。(I5087e
  • 修复了最大高度约束条件传播且可能崩溃的 bug。(I30d8c
  • 从可点击和可选择的 Surface 中移除了语义角色,更新了通过它们使用修饰符.semantics 设置角色的组件 (I793d9)

版本 1.1.0-alpha06

2023 年 2 月 8 日

发布了 androidx.compose.material3:material3:1.1.0-alpha06androidx.compose.material3:material3-window-size-class:1.1.0-alpha06版本 1.1.0-alpha06 中包含这些提交内容

新功能

  • 文本字段现在支持前缀和后缀文本(Ia8578b/179884561
  • 添加了 TimePicker 函数,以显示符合 Material 3 规范的时间选择器。该函数会与 TimePickerState 和便捷方法 rememberTimePickerState 结合使用 (I71910)
  • 日期输入现在是 DatePicker 中的显示模式。添加了对在日期选择器模式和日期输入模式之间切换的支持。(Ieeff7)
  • RichTextTooltips 添加了 API。(I58ef3)
  • 新增了 Material 3 的模态底部动作条实现(包括 ModalBottomSheetModalBottomSheetDefaults)。此外,还引入了 SheetStaterememberSheetState,它们可用于未来的动作条组件。(I0853ab/244189383

API 变更

  • 稳定了 API showSnackbarI195c2b/261424370
  • 为辅助条状标签和建议内容信息条稳定了 API(Ibb67bb/261424370
  • ListItemListItemDefaultsListItemColors API 提升为非实验性 API(I7e7fab/261438882
  • SliderPositionsSliderDefaults.ThumbSliderDefaults.Track 提升到了稳定版,并添加了包含自定义滑块和滑道的非实验性 SliderRangeSlider API。同时废弃了之前的 SliderRangeSlider API。(Ie5ea6b/261566890
  • Modifier.tooltipAnchor() 设为了公开模式,以便开发者可以将其传递给锚点,以指示应在长按时显示提示。更新了 PlainTooltipBox API,使 TooltipState 不再可为 null,而是现在有默认值。(Ie2fb7)
  • ProgressIndicatorDefaults.circularTrackColor 已被标记为 @Composable,以保持一致。(Id29cc)
  • 恢复了属性 getter LocalMinimuTouchTargetEnforcement,然后将其标记为已废弃并重定向到 LocalMinimumInteractiveComponentEnforcement。(I60dd5)

版本 1.1.0-alpha05

2023 年 1 月 26 日

发布了 androidx.compose.material3:material3:1.1.0-alpha05androidx.compose.material3:material3-window-size-class:1.1.0-alpha05版本 1.1.0-alpha05 中包含这些提交内容

新功能

  • DatePickerDialog 和无障碍功能支持
  • RangeSlider 添加了自定义滑块和滑道。

依赖项更新

版本 1.1.0-alpha04

2023 年 1 月 11 日

发布了 androidx.compose.material3:material3:1.1.0-alpha04androidx.compose.material3:material3-window-size-class:1.1.0-alpha04版本 1.1.0-alpha04 中包含这些提交内容

新功能

  • 推出了通过日历界面选择单个日期的初始 DatePicker API。此 API 仍在更改中。(I722b9)
  • 通过 PlainTooltipBox 添加了对普通提示的支持。(I0cdfb)
  • 搜索栏 (Iad128)
  • SwipeToDismissI458a8b/242889540

API 变更

  • 在 Surface 上添加了 IsContainer 语义属性。此属性将在稍后的更改中使用,它会根据 Surface 等元素的语义含义确定遍历顺序。(I63379)
  • 将与抽屉式导航栏相关的 API 标记为稳定。(Iab01eb/261439597
  • 为圆形进度指示器添加了滑道颜色参数,并为圆形和线形进度指示器添加了描边上限参数。(Ie668cb/216325962b/222964817
  • 更多已废弃隐藏函数的返回值类型可为 null (Ibf7b0)
  • 添加了 Modifier.minimumInteractiveComponentSize。它可用于预留至少 48dp 的大小,以便在元素尺寸较小时消除触摸交互的歧义。(I33f58b/258495559
  • 为具有内容槽位的 AlertDialog 可组合项添加了实验性 API。(Iec4a2)

bug 修复

  • 进度指示器的进度现已正确限定到预期范围。(I8a7ebb/262262727

已知问题

  • androidx.compose.foundation:1.4.0-alpha03 更新为 androidx.compose.foundation:1.4.0-alpha04 时,您可能会遇到 java.lang.NoSuchFieldError 错误。您可以在此处查看最初报告的问题。修复程序已提交,将在下一个 Compose 更新中发布。若要解决此问题,请将您的 androidx.compose.materialandroidx.compose.material3 库更新到最新版本 (1.1.0-alpha04),或将您的 androidx.compose.foundation 降级到 1.4.0-alpha03。

版本 1.1.0-alpha03

2022 年 12 月 7 日

发布了 androidx.compose.material3:material3:1.1.0-alpha03androidx.compose.material3:material3-window-size-class:1.1.0-alpha03版本 1.1.0-alpha03 中包含这些提交内容

API 变更

  • consumedWindowInsets() 重命名为 consumeWindowInsets(),将 withConsumedWindowInsets() 重命名为 onConsumedWindowInsetsChanged(),并将 Modifiers 公开。(Ie44e1)
  • 为具有图标的文本按钮添加了新的默认内容内边距供使用。(I8f662)
  • 为导航栏和侧边栏添加了已停用的颜色。(Ia7892b/258867034
  • 添加了 Modifier API,用于查询祖先实体滚动信息。(I2ba9db/203141462
  • 在手势可以变为滚动事件时,用于在 Clickable 中正确延迟按下互动。
  • 修复了在 Scrollable ViewGroup 内使用时 Clickables 无法正确延迟涟漪效果的问题。
  • 更新了抽屉式导航栏和动作条,以便在手势可变为滚动事件时正确延迟按下操作。

依赖项更新

  • Compose UICompose Material 现在依赖于 Lifecycle 2.5.1。(I05ab0b/258038814

版本 1.1.0-alpha02

2022 年 11 月 9 日

发布了 androidx.compose.material3:material3:1.1.0-alpha02androidx.compose.material3:material3-window-size-class:1.1.0-alpha02版本 1.1.0-alpha02 中包含这些提交内容

API 变更

  • awaitFirstDownwaitForUpOrCancellation 现在可接受 PointerEventPass,增加了灵活性(也修复了 ExposedDropdownMenuBox 在滚动时显示菜单的问题)。(I7579ab/212091796
  • 在 Material 和 Material3 Text、TextFieldOutlinedTextField 中添加了 minLines 参数,从而能够根据行数设置组件的最小高度 (I4af1d)
  • 废弃了 TopAppBarDefaults smallTopAppBarColors 函数,取而代之的是创建 TopAppBar 时应使用的新 topAppBarColors 函数。(Ie6cb9)
  • BasicTextBasicTextField 添加了 minLines 参数。它允许根据行数设置这些可组合项的最小高度(I24294b/122476634

bug 修复

  • 将 Material3 IconButtonIconToggleBotton 的内容裁剪到组件的状态层形状(例如圆形)上。(I9da8f)
  • 更新了 Material3 Medium 和 Large 顶部应用栏,以在整个界面上应用相同的背景颜色,并允许设置使用透明颜色值替换默认颜色。(I67659b/249688556b/250838918

版本 1.1.0-alpha01

2022 年 10 月 24 日

发布了 androidx.compose.material3:material3:1.1.0-alpha01androidx.compose.material3:material3-window-size-class:1.1.0-alpha01版本 1.1.0-alpha01 中包含这些提交内容

bug 修复

  • 修复了使用 TextStyle 和 Brush 应用顶部应用栏标题时存在的问题。(If667e)

版本 1.0

版本 1.0.1

2022 年 11 月 9 日

发布了 androidx.compose.material3:material3:1.0.1androidx.compose.material3:material3-window-size-class:1.0.1版本 1.0.1 中包含这些提交内容

bug 修复

  • 更新了 Material3 Medium 和 Large 顶部应用栏,以在整个界面上应用相同的背景颜色,并允许设置使用透明颜色值替换默认颜色。(I67659b/249688556b/250838918

版本 1.0.0

2022 年 10 月 24 日

发布了 androidx.compose.material3:material3:1.0.0androidx.compose.material3:material3-window-size-class:1.0.0版本 1.0.0 中包含这些提交内容

1.0.0 的主要功能

这是 Compose Material 3 的第一个稳定版本!

Material Design 3 主题和 Material You 动态配色

Material Design 3 组件

窗口大小类别

  • material3-window-size-class 是一个为窗口大小类别提供支持的新库:一组主观的视口划分点,您可以根据它们设计、开发和测试可调整大小的应用布局。您可以使用 calculateWindowSizeClass 检索窗口大小类别实例,该实例可用于确定界面的显示方式,例如针对较大的窗口显示侧边导航栏(而非底部导航栏)。如需了解详情并查看用法示例,请参阅 WindowSizeClass 的 API 参考文档

  • 如需了解详情,请参阅这篇博文

版本 1.0.0-rc01

2022 年 10 月 5 日

发布了 androidx.compose.material3:material3:1.0.0-rc01androidx.compose.material3:material3-window-size-class:1.0.0-rc01版本 1.0.0-rc01 中包含这些提交内容

API 变更

版本 1.0.0-beta03

2022 年 9 月 21 日

发布了 androidx.compose.material3:material3:1.0.0-beta03androidx.compose.material3:material3-window-size-class:1.0.0-beta03版本 1.0.0-beta03 中包含这些提交内容

API 变更

  • ExposedDropdownMenuDefaults 现在公开了菜单项的内边距值。(I34ee1)
  • ExposedDropdownMenuBoxScope 现在具有 Modifier.menuAnchor() 修饰符,应将其传递到文本字段,以实现适当的 a11y 行为。(I27fa3)
  • 为当前的 Slider API 添加了两个过载方法,以允许用户传入滑块或滑道来填充此滑块。(I21c00)

bug 修复

  • 已将“On Error”容器的深色主题颜色映射更新为色调 90 (Ic5612)
  • 修复了相应问题,以允许为小型 Material 3 顶部应用栏设置透明背景。(I645e2b/245575782

版本 1.0.0-beta02

2022 年 9 月 7 日

发布了 androidx.compose.material3:material3:1.0.0-beta02androidx.compose.material3:material3-window-size-class:1.0.0-beta02版本 1.0.0-beta02 中包含这些提交内容

API 变更

  • beta01 版 m3 组件中引入的默认组件边衬区不再包括 IME 边衬区。
  • Material3 Scaffold 组件现在包含一个 contentWindowInsets 参数,可用于指定要为内容槽处理的边衬区量。(Icf11ab/243713323
  • 废弃了实验性 Material 3 SmallTopAppBar 函数,并引入了等效的 TopAppBar 函数。请改为使用新的 TopAppBar 函数。(I74404b/226918634
  • 添加了对顶部应用栏滑动和贴靠行为的控制。(I15c81)
  • 从 Divider 中移除了 startIndent,并移动了颜色以作为最后一个参数。(If7be2)

bug 修复

  • 通过在对话框显示时读出 Dialog 一词,让 TalkBack 用户能识别出对话框。(I857ef)

版本 1.0.0-beta01

2022 年 8 月 24 日

发布了 androidx.compose.material3:material3:1.0.0-beta01androidx.compose.material3:material3-window-size-class:1.0.0-beta01版本 1.0.0-beta01 中包含这些提交内容

API 参考文档

如需查看最新的主题、组件和其他可组合项,请参阅 Compose Material 3 API 参考文档概览

API 变更

  • 更新了 Material 3 顶部应用栏,以扣合至完全收起到完全展开的状态。此外,还将 TopAppBarDefaults 行为函数更新为可组合项,并为其顶部应用栏状态和动画规格提供默认值。(I642b3)
  • 更新了 FAB 组件签名,以与 Surface API 匹配 (I3afaa)
  • 添加了对顶部应用栏、抽屉式导航栏、导航栏和侧边栏的边衬区内置支持。这些组件单独使用或与 Scaffold 搭配使用时,会自动为开发者处理边衬区。注意:此变更不会自动处理状态栏图标以及状态栏和导航栏的透明度。请继续手动完成上述操作,以确保实现最佳无边框体验。(I7e4e6b/183161866
  • 更新了组件默认对象,以缩减 API Surface,便于未来实现灵活性和性能改进。(I31820)
  • 对条状标签和抽屉式导航栏动作条参数进行了重新排序,以便在 API 内保持一致 (I45d0b)
  • 从 Divider 中移除了 startIndent,并移动了颜色以作为最后一个参数。(If7be2)

版本 1.0.0-alpha16

2022 年 8 月 10 日

发布了 androidx.compose.material3:material3:1.0.0-alpha16androidx.compose.material3:material3-window-size-class:1.0.0-alpha16版本 1.0.0-alpha16 中包含这些提交内容

新功能

  • 支持在抽屉式导航栏中指定自定义宽度。(Ia7f10)

API 变更

  • 对 Tab 和 LeadingIconTab 的参数进行了重新排序,以便在 API 内保持一致 (Ie2637)
  • BadgeDefaults 标记成了实验性对象。(I98ef3)
  • 移除了已废弃的抽屉式导航栏函数。(I4f2db)
  • 对 Material 3 中的滑块参数进行了重新排序,以便在 API 内保持一致 (I0aee7)
  • NavigationBarNavigationRail 参数重新排序,以便在 API 中保持一致 (I51cda)
  • 对 Material 3 中的参数进行了重新排序,以便在整个 API 中保持一致。(If4ae1)
  • 对 Material 3 中的滑块参数进行了重新排序,以便在 API 内保持一致 (I62673)
  • 图标参数已重命名为相关操作,以便与顶部应用栏保持一致 (Id75be)
  • BadgeBadgedBox 标记成了实验性,因为锚点对齐仍为 influx。(I1712eb/236524516
  • 将图标按钮变体上的 @ExperimentalMaterial3Api 注解更改为 @OptIn (I070b5)
  • 将抽屉式导航栏的内容拆分到自己的可组合项中,以支持在其上指定自定义宽度。(Ia7f10)
  • MenuDefaultsTabDefaults 中移除了 Divider (I4e33c)

版本 1.0.0-alpha15

2022 年 7 月 27 日

发布了 androidx.compose.material3:material3:1.0.0-alpha15androidx.compose.material3:material3-window-size-class:1.0.0-alpha15版本 1.0.0-alpha15 中包含这些提交内容

新功能

API 变更

  • 更新了 FilterChipElevatedFilterChip API,以移除 selectedIcon 槽并促进重复使用 leadingIcon 以显示所选状态。(Ie5dc2)
  • 添加了纱罩和轮廓变体颜色角色。(Id6d54)
  • 修复了可组合项默认值的命名惯例。(I62b27)
  • ListItemDefaultsListItemColors 标记成了实验性。(I1f3ec)
  • 更改了顶部应用栏 API,以更好地反映其状态属性的含义。此外,将顶部应用栏 API 标记成了实验性。(Ic0ad8)
  • 现已将文字选择颜色添加到了 TextFieldColors 中,以便用户更容易发现。(Iba1b8)
  • 添加了 ButtonDefault.ButtonWithIconContentPadding,以便与包含图标的按钮一起使用。(I2bf9c)
  • 将文本字段标记成了实验性,以便日后更灵活地变更 API。(I127b5)
  • Checkbox 函数中移除了 @ExperimentalMaterial3Api 注解。(I5eefc)
  • RadioButton 函数中移除了 @ExperimentalMaterial3Api 注解。(I17e2a)
  • 从非交互式卡片中移除了 @ExperimentalMaterial3Api 注解。(I9bd49)
  • 更新了各种组件默认对象,以包含颜色、形状等。(I96e11)

bug 修复

  • 针对目录应用,从输入条状标签示例中移除了无效的尾随图标,以避免用户在此类应用中感到困惑。(I9846a)

版本 1.0.0-alpha14

2022 年 6 月 29 日

发布了 androidx.compose.material3:material3:1.0.0-alpha14androidx.compose.material3:material3-window-size-class:1.0.0-alpha14版本 1.0.0-alpha14 中包含这些提交内容

新功能

  • 添加了 M3 列表实现,请参阅用法示例文档 (Id7a20)

API 变更

  • RangeSlider 中的参数名称从 values 更改为 value (I3b79a)
  • InputChip 的实现进行了 API 方面的更改,以根据 Material Design 规范支持可选状态。针对所选停用状态,为 FilterChip 颜色提供了额外的支持。(I55244b/235792432
  • 添加了 BottomAppBar 默认 FAB (Ida4c8)
  • 添加了 ColorScheme.surfaceColorAtElevation (Id41af)
  • Compose 库中的接口现在使用 jdk8 默认接口方法构建 (I5bcf1)
  • WindowWidthSizeClassWindowHeightSizeClass 现在实现了 Comparable,因此可以使用运算符(<、<=、>=、>)和其他 API 进行比较。(I747d0)

bug 修复

  • 更新了标记示例以提供更有意义的内容说明。(I10b9d)
  • 向 Material 3 目录主题选择器添加了使用系统字体大小的选项。(I10605)
  • 添加了标记和不确定性进度指示器的示例代码。(I8fbe0)

版本 1.0.0-alpha13

2022 年 6 月 1 日

发布了 androidx.compose.material3:material3:1.0.0-alpha13androidx.compose.material3:material3-window-size-class:1.0.0-alpha13版本 1.0.0-alpha13 中包含这些提交内容

API 变更

  • 支持在配置更改时保持顶部应用栏的位置。(I10459b/216160958

版本 1.0.0-alpha12

2022 年 5 月 18 日

发布了 androidx.compose.material3:material3:1.0.0-alpha12androidx.compose.material3:material3-window-size-class:1.0.0-alpha12版本 1.0.0-alpha12 中包含这些提交内容

bug 修复

  • 滑块父项的宽度现在可以为 0。(b/231707291)

版本 1.0.0-alpha11

2022 年 5 月 11 日

发布了 androidx.compose.material3:material3:1.0.0-alpha11androidx.compose.material3:material3-window-size-class:1.0.0-alpha11版本 1.0.0-alpha11 中包含这些提交内容

新功能

  • 向 Material 3 添加了 RangeSlider (I18e38)
  • 添加了对 Material3 AssistChipInputChip 的支持 (I0d25a)
  • 添加了对 Material3 FilterChipSuggestionChip 的支持 (I9fdf3)

API 变更

  • TextFieldDefaults.BorderStroke 可组合项(用于在 OutlinedTextField 中绘制边框描边)重命名为 TextFieldDefaults.BorderBox。(I5f295)
  • 切换 m3 视觉变化 (Iab30e)
  • 允许将颜色传递给标准图标按钮。(Ia2445)

bug 修复

  • 向 material3/Scaffold 添加了 lint 检查,以确保使用了内部内边距(I72293b/226951418

版本 1.0.0-alpha10

2022 年 4 月 20 日

发布了 androidx.compose.material3:material3:1.0.0-alpha10androidx.compose.material3:material3-window-size-class:1.0.0-alpha10版本 1.0.0-alpha10 中包含这些提交内容

新功能

  • material3-window-size-class 是一个为窗口大小类别提供支持的新库:一组主观的视口划分点,您可以根据它们设计、开发和测试可调整大小的应用布局。您可以使用 calculateWindowSizeClass 检索窗口大小类别实例,该实例可用于确定界面的显示方式,例如针对较大的窗口显示侧边导航栏(而非底部导航栏)。如需了解详情并查看用法示例,请参阅 WindowSizeClass 的 API 参考文档。如需详细了解窗口大小类别的定义,请参阅有关支持不同屏幕尺寸的公开指南。

API 变更

  • BottomAppBar 添加了默认的 FAB 高度,从带有 FAB 的 BottomAppBar 中移除了尾随 lambda。(I92c47)
  • 添加了 Material3 FilledIconButtonFilledTonalIconButtonOutlinedIconButton。(Ib2bda)
  • 更新了 Material 3 Snackbar API,以接受可选操作和关闭操作的颜色值。(Ibe4b4)
  • 废弃了 PointerInputChange 中的部分操作(向下或定位)。您可以借助 consume() 完全使用此更改。您可以使用 isConsumed 来确定其他人之前是否使用过此更改。
  • PointerInputChange::copy() 现在始终会创建浅层副本。这意味着,在使用完其中一个副本后,将会使用 PointerInputChange 的副本。如需创建未绑定的 PointerInputChange,请改用构造函数。(Ie6be4b/225669674
  • 更改了 Cards API,以通过 CardColors 接口接收容器颜色和内容颜色,并支持可点击卡片的停用状态。(I927df)
  • Material 3 文本字段中的参数 backgroundColor 已重命名为 containerColor,以提高与其他组件的一致性。(I6fbd9)

bug 修复

  • 更新了标准 IconButton,使其符合 Material3 规范。(I09eab)
  • 将 Material3 Scaffold 的顶部栏高度移动到传递给内容的内边距,使内容能够在顶部应用栏下方呈现。如果 PaddingValues 被忽略,顶部栏可能会遮盖内容。(I83cbcb/217776202

版本 1.0.0-alpha09

2022 年 4 月 6 日

发布了 androidx.compose.material3:material3:1.0.0-alpha09版本 1.0.0-alpha09 中包含这些提交内容

新功能

  • 添加了 Material 3 Switch API (I2c3ad)

API 变更

  • 新增了对包含文本字段的下拉菜单(即“公开下拉菜单”或“组合框”)的支持。(I1b832)
  • 向 MaterialTheme 和 Shape 子系统添加了形状参数。(I37426)
  • ExtendedFloatingActionButton 添加了一个扩展参数,用于控制 FAB 处于展开状态还是收起状态,并在每种状态之间添加了动画效果。为处于展开状态的 FAB 添加了扩展型 FAB 过载,并为不带图标的 ExtendedFAB 添加了尾随文本。(Iba7f1)

版本 1.0.0-alpha08

2022 年 3 月 23 日

发布了 androidx.compose.material3:material3:1.0.0-alpha08版本 1.0.0-alpha08 中包含这些提交内容

新功能

API 变更

  • 为菜单添加了默认分隔线 (I01374)
  • ColorScheme 类添加了 surfaceTint 颜色参数。(I2f558)

bug 修复

  • 修复了 Material3 按钮,以从 MaterialTheme 读取其默认文本样式值。(Ie62fc)

版本 1.0.0-alpha07

2022 年 3 月 9 日

发布了 androidx.compose.material3:material3:1.0.0-alpha07版本 1.0.0-alpha07 中包含这些提交内容

API 变更

  • 更新了 Material 3 Surface API,以恢复可点击 Surface 的过载函数,并添加了一个函数来支持可选择和可切换的 Surface。(I4bf18)
  • LazyVerticalGridLazyHorizontalGrid 现已稳定。(I307c0)
  • LazyVerticalGrid/LazyHorizontalGrid 和所有相关 API 已移至 .grid 子软件包。请将您的导入从 androidx.compose.foundation.lazy 更新为 androidx.compose.foundation.lazy.grid。(I2d446)
  • 恢复了之前仅依赖于 WindowInsetsControllerCompat 的 View 的变更,再次需要一个 Window,这对于管理某些窗口标记来说是必需的。废弃了 ViewCompat.getWindowInsetsController,改为使用 WindowCompat.getInsetsController,以确保使用正确的 Window(例如,如果 View 位于对话框中)。(I660aeb/219572936
  • 新增了 LazyVerticalGrid API,用于定义交叉轴的大小 (I17723)

bug 修复

  • 更新了 Card API,以跟踪 Surface API 的更改 (I3c8b9)

版本 1.0.0-alpha06

2022 年 2 月 23 日

发布了 androidx.compose.material3:material3:1.0.0-alpha06版本 1.0.0-alpha06 中包含这些提交内容

API 变更

  • 添加了表示抽屉式导航栏中单个目的地的 NavigationDrawerItemIc396fb/218286829
  • 以实验性 API 的形式添加了 PermanentNavigationDrawerDismissibleNavigationDrawer。这些抽屉式导航栏非常适合大屏幕设备。(I5f8abb/218286829
  • 添加了 Material 3 底部应用栏支持 (Ic432a)
  • NavigationDrawer 已重命名为 ModalNavigationDrawerI1807db/218286829
  • 添加了 Material 3 滑块类和令牌 (I1ccee)
  • 添加了 Tab 实现,请参阅用法示例文档 (Ie0146)

bug 修复

  • 修复了 TalkBack 屏幕阅读器线性导航选择空白的顶部应用栏标题的问题。(Id4690)
  • FloatingActionButtonDefaults 添加了 IconSize。(Ia71cf)
  • 修复了在使用 LazyColumn 添加长文本时隐藏 AlertDialog 按钮的bug。(Ib2cc9b/216663029

版本 1.0.0-alpha05

2022 年 2 月 9 日

发布了 androidx.compose.material3:material3:1.0.0-alpha05版本 1.0.0-alpha05 中包含这些提交内容。

新功能

添加了 Material Design 3 组件

API 变更

  • 废弃了使用 onClick 回调的 Surface 函数。应使用 InteractionSourceModifier.clickable() 创建可点击界面。(I211c6)
  • 为 FAB 添加了对“按下”和“聚焦”状态高度的支持。(Ibb584)
  • Surface API 更改为接收 InteractionSource,允许控制其在不同状态下的外观。(Iafbc8)

bug 修复

版本 1.0.0-alpha04

2022 年 1 月 26 日

发布了 androidx.compose.material3:material3:1.0.0-alpha04版本 1.0.0-alpha04 中包含这些提交内容

API 变更

  • 针对无复杂逻辑的现有方法,向其重载的方法添加了 NonRestartableComposable。对于在所调用内部函数中重复的所有参数,这会减少编译器产生的记忆检查 (equals)。(I90490)
  • 添加了 Material 3 分隔线。(Ica5fc)
  • 使用实验性 API 注解标记了 Checkbox 和 RadioButton。(Ie44bb)
  • 添加了对 Material 3 进度指示器的支持。(Iff232b/205023841

bug 修复

版本 1.0.0-alpha03

2022 年 1 月 12 日

发布了 androidx.compose.material3:material3:1.0.0-alpha03版本 1.0.0-alpha03 中包含这些提交内容

bug 修复

  • 向 Material 3 的 MaterialTheme 中添加了 LocalIndication。(I7ce4e)
  • 修复了向复选框应用的圆角半径存在的问题(I38b03b/175198975b/202309440

依赖项更新

  • 现在依赖于 Kotlin 1.6.10

版本 1.0.0-alpha02

2021 年 12 月 1 日

发布了 androidx.compose.material3:material3:1.0.0-alpha02版本 1.0.0-alpha02 中包含这些提交内容

新功能

  • 添加了对复选框和单选按钮的支持。
  • 完成更新,现与 Kotlin 1.6.0 兼容

API 变更

  • 从 Material 3 的 scaffold 中移除了抽屉式导航栏。(I04f51)
  • 添加了 Material 3 Checkbox 支持。(Id5542)
  • 添加了 Material 3 RadioButton 支持。(I20334)

bug 修复

  • IconButton 涟漪效果半径从 40dp 缩减到了 20dp。(I68bbeb/206674345
  • compose.material 中移植了用于 Text 更改的字符串快速路径 (I30b03)
  • 修复了硬编码按钮始终处于启用状态的 bug。(Iea832b/205335456

版本 1.0.0-alpha01

2021 年 10 月 27 日

发布了 androidx.compose.material3:material3:1.0.0-alpha01版本 1.0.0-alpha01 中包含这些提交内容

新功能

Material Design 3 主题和 Material You 动态配色

Material Design 3 组件

如需了解详情,请参阅《Compose 中的 Material 主题设置》指南中的“Material Design 3 和 Material You”部分。