欢迎体验 | Wear OS 版 Compose 开发者预览版

2021 年 12 月 15 日 谷歌开发者

作者 / 开发者关系工程师 Jeremy Walker


在今年的 Google I/O 大会上,我们宣布将 Jetpack Compose 的优秀特性引入 Wear OS。在顺利发布多个 alpha 版本之后,Wear OS 版 Compose 现已推出开发者预览版。


Compose 能简化并加速 UI 开发,Wear OS 版 Compose 也是如此,借助内置的 Material You 支持,您可以用更少的代码构建更精美的应用。


  • 简化并加速 UI 开发
    https://developer.android.google.cn/jetpack/compose/why-adopt#less-code


除此之外,您在使用 Jetpack Compose 构建移动应用的经验,也可以直接运用在 Wear OS 版本上。就像在移动设备上一样,欢迎您立即着手测试,我们也希望在发布 Beta 版前,将您的反馈纳入库的早期迭代中。


  • 反馈
    https://issuetracker.google.com/issues/new?component=1077552&template=1598429&pli=1


本文将回顾我们构建的几个主要可组合项,并介绍帮助您开始使用的多种资源。
 
现在就开始吧!


依赖项


您对 Wear 设备作出的大部分更改都将位于顶部 架构分层

  • 架构分层
    https://developer.android.google.cn/jetpack/compose/layering


这就意味着面向 Wear OS 设计时,您搭配 Jetpack Compose 使用的许多依赖项不会发生变化。例如,UI、运行时间、编译器和动画依赖项都将保持不变。

不过,您需要使用合适的 Wear OS Material、导航及基础开发库,这与您之前在移动应用中所使用的开发库是不一样的。

下方是相关对比,可帮助您区分两者差异:

Wear OS 依赖项

(androidx.wear.*)

对比

移动依赖项

(androidx.*)

androidx.wear.compose:compose-material 替换 androidx.compose.material:material¹
androidx.wear.compose:compose-navigation 替换 androidx.navigation:navigation-compose
androidx.wear.compose:compose-foundation 额外添加 androidx.compose.foundation:foundation

1. 开发者可以继续使用其他与 Material 相关的开发库,如 Material 涟漪和通过 Wear Compose Material 开发库进行扩展的 Material 图标。


  • androidx.wear.compose:compose-material
    https://developer.android.google.cn/reference/kotlin/androidx/wear/compose/material/package-summary

  • androidx.wear.compose:compose-navigation
    https://developer.android.google.cn/reference/kotlin/androidx/wear/compose/navigation/package-summary

  • androidx.wear.compose:compose-foundation
    https://developer.android.google.cn/reference/kotlin/androidx/wear/compose/foundation/package-summary


尽管从技术上说,可以在 Wear OS 上使用移动依赖项,但我们还是建议您使用专用于 Wear 的版本以获取最佳体验。


注意: 我们将在未来版本中添加更多 Wear 可组合项。如果您认为有任何遗漏, 欢迎与我们分享

https://issuetracker.google.com/issues/new?component=1077552&template=1598429&pli=1


下面是一份示例 build.gradle 文件:
// Example project in app/build.gradle filedependencies {    // Standard Compose dependencies...
// Wear specific Compose Dependencies // Developer Preview starts with Alpha 07, with new releases coming soon. def wear_version = "1.0.0-alpha07" implementation "androidx.wear.compose:compose-material:$wear_version" implementation "androidx.wear.compose:compose-foundation:$wear_version"
// For navigation within your app... implementation "androidx.wear.compose:compose-navigation:$wear_version"
// Other dependencies...}


在添加了正确的 Wear Material、基础及导航依赖项后,您就可以着手开始了。



可组合项


我们来了解一些可以立即着手使用的可组合项。


一般来说,许多相当于移动版本的 Wear 可组合项可使用相同代码。样式颜色、排版及使用 MaterialTheme 的形状的代码亦如此。


  • 样式
    https://developer.android.google.cn/jetpack/compose/themes

  • MaterialTheme
    https://developer.android.google.cn/training/wearables/components/theme


例如,要创建 Wear OS 按钮,您的代码如下所示:
Button(    modifier = Modifier.size(ButtonDefaults.LargeButtonSize),    onClick = { /*...*/ },    enabled = enabledState) {    Icon(        painter = painterResource(id = R.drawable.ic_airplane),        contentDescription = "phone",        modifier = Modifier            .size(24.dp)            .wrapContentSize(align = Alignment.Center),    )}

以上代码与移动端代码十分相似,但该库创建了 Wear OS 优化版本的按钮,即由 ButtonDefaults 确定大小的圆形按钮,以遵循 Wear OS Material 准则。

  • ButtonDefaults
    https://developer.android.google.cn/reference/kotlin/androidx/wear/compose/material/ButtonDefaults#DefaultButtonSize()


以下是开发库中一些可组合项的示例:

按钮

卡片

图标

文本


  • 按钮
    http://link.gevents.cn/RDjku4

  • 卡片

    http://link.gevents.cn/Dsm9aB

  • 图标

    http://link.gevents.cn/fbj8q9

  • 文本

    http://link.gevents.cn/pHJN8d


除此之外,我们还引入了许多可提升 Wear 体验的全新可组合项:

Chip

ToggleChip

BasicCurvedText

TimeText


  • Chip
    http://link.gevents.cn/LqEeU5

  • ToggleChip

    http://link.gevents.cn/XPLrAd

  • BasicCurvedText

    http://link.gevents.cn/LtbPDG

  • TimeText

    http://link.gevents.cn/wW7n2v


我们还为列表提供了一个针对 Wear 优化的可组合项 ScalingLazyColumn ,扩展了 LazyColumn 并添加了缩放和透明度更改,以更好地支持圆形界面。您可在下方应用中看到,内容在屏幕顶部和底部被缩减和淡化,以提高可读性:

  • ScalingLazyColumn
    http://link.gevents.cn/QE5L4A


查看代码,您可看到代码与 LazyColumn 相同,只是名称不同。

val scalingLazyListState: ScalingLazyListState =     rememberScalingLazyListState()
ScalingLazyColumn( modifier = Modifier.fillMaxSize(), verticalArrangement = Arrangement.spacedBy(6.dp), state = scalingLazyListState,) { items(messageList.size) { message -> Card(/*...*/) { /*...*/ } }
item { Card(/*...*/) { /*...*/ } }}



滑动关闭


Wear 有自己的 Box 版本,即 SwipeToDismissBox。此版本添加了对开箱即用的滑动关闭手势的支持 (类似于移动设备中的返回按钮/手势)。


下面是代码的一个简单示例:

// Requires state (different from Box).val state = rememberSwipeToDismissBoxState()
SwipeToDismissBox( modifier = Modifier.fillMaxSize(), state = state) { swipeBackgroundScreen ->
// Can render a different composable in the background during swipe. if (swipeBackgroundScreen) { /* ... */ Text(text = "Swiping Back Content") } else { /* ... */ Text( text = "Main Content") }}

  • SwipeToDismissBox
    http://link.gevents.cn/AtvYxn


下面是更为复杂的一个示例:




导航


最后,我们还提供了导航可组合项 SwipeDismissableNavHost,该可组合项与移动设备中 NavHost 的工作原理很像,不过也支持开箱即用的滑动关闭手势 (实际在后台使用 SwipeToDismissBox)。下面是一个示例 (代码):


  • SwipeDismissableNavHost
    http://link.gevents.cn/ZYTGDZ

  • SwipeToDismissBox
    http://link.gevents.cn/AtvYxn

  • 代码
    http://link.gevents.cn/dH2yzC



Scaffold


Scaffold 提供了布局结构,以帮助您像移动设备一样,用常见模式排列屏幕,但并非应用栏、悬浮操作按钮 (FAB) 或抽屉式导航栏等模式。Scaffold 可支持 Wear 专属布局,并提供时间、曲线文本样式及滚动/位置指示器等顶层组件。


  • Scaffold
    http://link.gevents.cn/QguBSZ


  • TimeText
    http://link.gevents.cn/wW7n2v

  • 曲线文本样式
    http://link.gevents.cn/DhFVDw

  • PositionIndicator
    http://link.gevents.cn/str7dQ


这部分代码与您在移动应用上使用的代码十分相似:

http://link.gevents.cn/dH2yzC



开始使用吧!


我们很高兴将 Jetpack Compose 引入 Wear OS,使手表开发更加快捷轻松。如要直接体验并创建应用,欢迎查看我们的 快速入门指南 :
http://developer.android.google.cn/training/wearables/compose-setup

若想查看可行示例 (简单与复杂皆有),您可以访问 我们的示例 repo :
https://github.com/android/wear-os-samples#samples

您的反馈有助于我们在开发者预览版中增加和改进 API,欢迎您向我们分享您的反馈,或加入 Slack #compose-wear 频道与我们分享!也欢迎您持续关注 "谷歌开发者" 微信公众号了解更多最新内容。

  • 分享您的反馈
    https://issuetracker.google.com/issues/new?component=1077552&template=1598429&pli=1
  • 加入 Slack
    https://surveys.jetbrains.com/s3/kotlin-slack-sign-up


欢迎您通过下方二维码向我们提交反馈,或分享您喜欢的内容、发现的问题。您的反馈对我们非常重要,感谢您的支持!



推荐阅读

如页面未加载,请刷新重试



 点击屏末  | 即刻查看快速入门指南




登录查看更多
0

相关内容

机器学习损失函数概述,Loss Functions in Machine Learning
专知会员服务
81+阅读 · 2022年3月19日
专知会员服务
42+阅读 · 2021年8月4日
【2020新书】Ruby 3 编程: 从小白到专家,598页pdf
专知会员服务
29+阅读 · 2020年12月17日
FPGA加速系统开发工具设计:综述与实践
专知会员服务
62+阅读 · 2020年6月24日
【电子书】Flutter实战305页PDF免费下载
专知会员服务
20+阅读 · 2019年11月7日
使用 Jetpack Compose 提升 Play 商店的用户体验
谷歌开发者
0+阅读 · 2022年3月31日
欢迎体验 | Android 13 开发者预览版 2
谷歌开发者
1+阅读 · 2022年3月18日
使用 Compose 构建 Wear OS 应用
谷歌开发者
0+阅读 · 2022年3月17日
借助 Material You 为您的用户提供个性化的流畅体验
谷歌开发者
1+阅读 · 2022年3月14日
Jetpack Compose 1.1 现已进入稳定版!
谷歌开发者
0+阅读 · 2022年3月7日
Android 13 首个开发者预览版到来
谷歌开发者
0+阅读 · 2022年2月12日
新版本系统适配: Android 12 中的兼容性变更
谷歌开发者
0+阅读 · 2022年1月13日
Android 12 正式发布 | 开发者们的全新舞台
谷歌开发者
0+阅读 · 2021年10月11日
国家自然科学基金
0+阅读 · 2015年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
2+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
2+阅读 · 2008年12月31日
VIP会员
相关资讯
使用 Jetpack Compose 提升 Play 商店的用户体验
谷歌开发者
0+阅读 · 2022年3月31日
欢迎体验 | Android 13 开发者预览版 2
谷歌开发者
1+阅读 · 2022年3月18日
使用 Compose 构建 Wear OS 应用
谷歌开发者
0+阅读 · 2022年3月17日
借助 Material You 为您的用户提供个性化的流畅体验
谷歌开发者
1+阅读 · 2022年3月14日
Jetpack Compose 1.1 现已进入稳定版!
谷歌开发者
0+阅读 · 2022年3月7日
Android 13 首个开发者预览版到来
谷歌开发者
0+阅读 · 2022年2月12日
新版本系统适配: Android 12 中的兼容性变更
谷歌开发者
0+阅读 · 2022年1月13日
Android 12 正式发布 | 开发者们的全新舞台
谷歌开发者
0+阅读 · 2021年10月11日
相关基金
国家自然科学基金
0+阅读 · 2015年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
2+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
2+阅读 · 2008年12月31日
Top
微信扫码咨询专知VIP会员