Jetpack Compose 更新一览 | 2022 Android 开发者峰会
作者 / Android 开发者关系工程师 Jolanda Verhoef
去年我们发布了 Jetpack Compose,此后一直在进行优化。我们已添加了新的功能并创造出功能更强大的工具,帮助您获得更高效、更直观、更有趣的 Android 界面开发体验。如果您正在开发一款新应用,那现在是时候用 Compose 来编写了!这一激动人心的 Compose 版本现可支持 Material Design 3、新的 BOM (Bill Of Materials)、稳定版 Compose for Wear OS 和 Android TV Alpha 版、Compose Camp,以及更多新功能!
Jetpack Compose
https://developer.android.google.cn/jetpack/compose稳定版 Compose for Wear OS
https://android-developers.googleblog.com/2022/07/compose-for-wear-os-10-stable.html
社区中的 Compose
去年,我们了解到许多公司在大规模使用 Compose 进行开发,实现了新功能并将编译界面从 View 迁移至 Compose。例如,我们在与 Lyft 的工程师交谈后得知,他们超过 90% 的新功能代码是用 Compose 编写而成,并且改用 Compose 能够更加轻松便捷地维护代码。他们还分享道: "我们使用 Compose 在应用中重新编写了按钮组件。在此之前,编写该组件需要在三个文件外加 17 个不同 XML 文件中编写 800 行代码,而现在减少到只需一个 Kotlin 文件和 300 行代码即可完成。单就 Kotlin 代码而言,工作量就减少了 60%"。Zepeto 团队同样已在多个功能中使用 Compose,并从中受益,因为 "Compose 简化了我们的界面层逻辑,有助于我们更轻松地理解同事所编写的代码"。
大规模使用 Compose 进行开发
https://developer.android.google.cn/jetpack/compose/adopt#what-developers-are-saying改用 Compose 使 Lyft 团队能够更加轻松便捷地维护代码
https://android-developers.googleblog.com/2022/10/lyft-reduced-their-code-for-ui-components-using-jetpack-compose.html有助于 Zepeto 团队更轻松地理解同事所编写的代码
https://android-developers.googleblog.com/2022/10/zepeto-plans-to-migrate-80-percent-of-apps-ui-to-jetpack-compose.html
如何在您的团队中采用 Compose 的指南
https://developer.android.google.cn/jetpack/compose/adopt/for-large-teams
Jetpack Compose 2022 年 10 月版发布
现在,我们发布了全新的稳定版 Compose,并为您介绍一些激动人心的功能和最新资讯。
首先,根据用户反馈,我们了解到追踪不同工件的版本会让人望而生畏,因为这些工件可能出现在不同的发布时间表中。因此我们现将一同发布 Bill of Materials 功能,即 BOM,包含所有 Compose 工件的稳定版本,让您能够更轻松地使用。
首版 BOM 发布的同时,Compose 2022 年 10 月版也带来了交错网格支持、直接在画布中绘制文本,下拉刷新,同时包含性能改进和问题修复。
Compose BOM
BOM 是一个 Maven 模块,用于声明一组内容库及其版本。这将很大程度上简化您在 Gradle 依赖项部分定义 Compose 内容库版本的方式,尤其是在我们对不同的 Jetpack Compose 内容库采用独立版本的情况下。您不用再单独定义每个版本,这一过程往往繁重且容易在内容库版本出现不同时出错,现在您只需定义一个 BOM 版本,就能够从中提取所有 Compose 内容库版本。每当 Compose 工件有新的稳定版本时,我们就会发布新的 BOM 版本,因此可更轻松地从一个稳定版转移到另一个稳定版。
dependencies {
// 导入 Compose BOM
implementation platform('androidx.compose:compose-bom:2022.10.00')
// 为尚未标明版本的目标 Compose 库声明依赖项
implementation 'androidx.compose.foundation:foundation'
androidTestImplementation 'androidx.compose.ui:ui-test-junit4'
...
}
对不同的 Jetpack Compose 内容库采用独立版本
https://android-developers.googleblog.com/2022/06/independent-versioning-of-Jetpack-Compose-libraries.html
快速入门指南
https://developer.android.google.cn/jetpack/compose/setup
深入了解修饰符
△ Compose 修饰符深入研究 | 2022 Android 开发者峰会
Compose 修饰符深入研究
https://developer.android.google.cn/events/dev-summit/technical-talks
弹出式窗口和对话框高度更改
版本说明
https://developer.android.google.cn/jetpack/androidx/releases/compose-ui
新功能
我们在 Compose 中添加了许多新功能。部分重要内容如下:
使用全新 LazyHorizontalStaggeredGrid 和 LazyVerticalStaggeredGrid 实现交错网格; 使用 DrawScope.drawText 直接在画布中绘制文本; 使用 FontVariation 对象在应用中添加可变字体并更改其属性; 在带注释的字符串中添加 UrlAnnotation 以改进与文本互动的无障碍服务; 使用全新 LineBreak API 在您的文本中添加断字功能; 使用全新 pullRefresh 修饰符下拉刷新; 使用 SnapFlingBehavior 在您的惰性列表中添加贴靠行为; LookAheadLayout 是一种新的布局类型,可以提供关于子项的最终测量与放置信息,帮助您决定中间层布局。
LazyHorizontalStaggeredGrid
http://link.gevents.cn/DYyk4wLazyVerticalStaggeredGrid
http://link.gevents.cn/GviHF9FontVariation
https://developer.android.google.cn/reference/kotlin/androidx/compose/ui/text/font/FontVariation可变字体
https://fonts.google.com/knowledge/topics/variable_fontsUrlAnnotation
https://developer.android.google.cn/reference/kotlin/androidx/compose/ui/text/UrlAnnotationLineBreak
https://developer.android.google.cn/reference/kotlin/androidx/compose/ui/text/style/LineBreakpullRefresh
http://link.gevents.cn/TAA2d2下拉刷新
https://material.io/design/platform-guidance/android-swipe-to-refreshSnapFlingBehavior
https://developer.android.google.cn/reference/kotlin/androidx/compose/foundation/gestures/snapping/SnapFlingBehaviorLookAheadLayout
http://link.gevents.cn/ETYAtK
Compose Material 3 稳定版
我们还推出了 Compose Material 3 内容库的第一个稳定版本!您可以使用 Compose 构建应用,并根据 Material Design 的最新版本 Material Design 3 设置主题。使用 Material Design 3 进一步自定义您应用的颜色、排版和外观,帮助您的品牌脱颖而出!内容库包含许多界面组件的全新和更新版本,例如按钮、卡片、复选框、开关、导航栏、抽屉式导航栏等,并支持其他即将推出的更新。您可以前往官方文档,查看受支持的所有组件列表,也可以在我们近期的推文中了解详情。
Compose Material 3 内容库
https://developer.android.google.cn/jetpack/androidx/releases/compose-material3Material Design 3
https://m3.material.io/官方文档
https://developer.android.google.cn/reference/kotlin/androidx/compose/material3/package-summary#overview
您可以查看我们新的迁移指南,帮助您使用 Material 3,我们在指南中清楚地介绍了如何将 Material 2 概念转化成 Material 3。Android Studio Flamingo 中的默认模板现在会使用 Material 3 来指引您即时正常运行。我们还更新了许多示例应用、教程、模板和 Codelab 以助您轻松使用 Material 3,方便您在实践中学习!
迁移指南
https://developer.android.google.cn/jetpack/compose/themes/material2-material3
新工具
动画协调
MultiPreview 注释 布局检查器中的重组计数
Android Studio Dolphin
https://developer.android.google.cn/studio/releases#new_in_compose
实时编辑 (实验性)
突出显示组合渲染效果
配置预览版设备
预览版中的 Live Updates
Android Studio Electric Eel
https://developer.android.google.cn/studio/preview/features#2022.1.1
Android Studio Flamingo 内含 Canary 版功能,比如:
新项目模板默认使用 Compose 和 Material 3 默认开启实时编辑 改进后的组合跟踪,助您更好地检查性能问题。
Android Studio Flamingo
https://developer.android.google.cn/studio/preview/features#2022.2.1
Relay
我们还发布了 Relay 的首个 Alpha 版本,作为设计稿转代码的解决方案,可优化设计者与开发者之间的协作。设计者使用 Figma 插件创建界面组件,开发者则使用 Android Studio 插件将这些组件自动应用到他们的应用中。生成的组件是可组合函数,并可直接被集成到您的 Compose 应用中。您可以查看官方文档,详细了解 Relay。
Relay
https://relay.material.io/Figma 插件
https://www.figma.com/community/plugin/1041056822461507786Android Studio 插件
https://plugins.jetbrains.com/plugin/19721-relay-for-android-studio/官方文档
https://developer.android.google.cn/jetpack/compose/tooling/relay
面向 Wear OS、大屏幕设备和电视的 Compose
我们在 7 月发布了首个稳定版 Compose for Wear OS,可随时在生产环境中使用。推荐您使用 Compose for Wear OS 来为 Wear OS 应用构建界面。我们在其中加入了二十余种专为可穿戴设备设计的 Compose 界面组件,如 TimeTextPositionIndicator,以及 ScalingLazyColumn。
Compose for Wear OS
https://android-developers.googleblog.com/2022/07/compose-for-wear-os-10-stable.html
我们将持续改进,使其更易于为可折叠设备、平板电脑等大屏幕设备和 ChromeOS 设计、开发和测试应用。material3-window-size-class 内容库已升级为稳定版,为您提供了一组可供使用的视口划分点。大屏幕设备设计通常包含交错网格,新增的 LazyHorizontalStaggeredGrid 和 LazyVerticalStaggeredGrid 有助于实现这些网格。
material3-window-size-class
https://developer.android.google.cn/jetpack/androidx/releases/compose-material3LazyHorizontalStaggeredGrid
http://link.gevents.cn/DYyk4wLazyVerticalStaggeredGrid
http://link.gevents.cn/GviHF9
Android 社区的反馈一直推动我们继续向前。我们根据您的反馈更新了路线图,更加侧重于能够帮助您成功使用 Compose 的领域。现在我们正专注于支持更多案例,包括更多 Material 3 组件,改进平台支持、工具和性能。
路线图
https://developer.android.google.cn/jetpack/androidx/compose-roadmap
全新的和更新后的指南
无论您处于学习旅程的哪个阶段,我们都会为您提供帮助!我们新增和优化了有关 Compose 的许多指南:
如果想要体验实践操作,您可以参阅更新后的面向 Android 开发者的 Compose 课程。这一课程涵盖了多种主题,从基础知识到进阶内容,一应俱全。 如果您更喜欢观看视频,可查看 MAD 技巧: Compose 基础知识系列视频,当然,您也可以观看 Android 开发者峰会中有关 Compose 的所有技术分享内容。 您可以阅读有关图像和图形的扩展文档。 想知道使用哪种动画?答案尽在全新的动画备忘单中! 通过全新的调试重组截屏视频和博文,了解如何发现并修复性能问题。 如果考虑在您的现有应用中采用 Compose,您可以参阅扩展版指南: 在应用中采用 Compose。
面向 Android 开发者的 Compose 课程
https://developer.android.google.cn/courses/jetpack-compose/courseMAD 技巧: Compose 基础知识
https://youtube.com/playlist?list=PLWz5rJ2EKKc-CG9riunK996aI6cRhXFDCAndroid 开发者峰会
https://developer.android.google.cn/events/dev-summit/technical-talks#modern-android-development图像和图形
https://developer.android.google.cn/jetpack/compose/graphics动画备忘单
https://storage.googleapis.com/android-stories/compose/Compose_Animation_Cheat_Sheet.pdf截屏视频
https://www.youtube.com/watch?v=SWBN0y0lFNY调试重组博文
https://medium.com/androiddevelopers/jetpack-compose-debugging-recomposition-bfcf4a6f8d37在应用中采用 Compose
https://developer.android.google.cn/jetpack/compose/interop
Compose Camp
Compose Camp
https://developer.android.google.cn/compose-camp如火如荼地进行中
https://twitter.com/search?q=%23ComposeCamp&src=typeahead_click视频
https://space.bilibili.com/64169458/channel/collectiondetail?sid=735148
祝您拥有愉快的 Compose 使用体验!
希望您和我们一样对这些进展感到兴奋!如果您尚未开始,现在就是学习 Jetpack Compose,并帮助您的团队和开发流程从中受益的最佳时机。准备好体验更快的开发速度和更高的工作效率吧。祝您拥有愉快的 Compose 使用体验!也欢迎您持续关注我们,及时了解更多开发技术和产品更新等资讯动态。
Jetpack Compose
https://developer.android.google.cn/jetpack/compose
推荐阅读