Wear Compose

  
ウェアラブル固有のデバイス、サイズ、形状、ナビゲーション操作をサポートする機能を提供して、ウェアラブル デバイス向けの Jetpack Compose アプリを作成します。
最新の更新 安定版リリース リリース候補版 ベータ版リリース アルファ版リリース
2023 年 2 月 22 日 1.1.2 - - 1.2.0-alpha05

依存関係の宣言

Wear への依存関係を追加するには、Google の Maven リポジトリをプロジェクトに追加する必要があります。詳しくは、Google の Maven リポジトリをご覧ください。

アプリまたはモジュールの build.gradle ファイルに、必要なアーティファクトの依存関係を追加します。

Groovy

dependencies {
    implementation "androidx.wear.compose:compose-foundation:1.1.2"

    // For Wear Material Design UX guidelines and specifications
    implementation "androidx.wear.compose:compose-material:1.1.2"

    // For integration between Wear Compose and Androidx Navigation libraries
    implementation "androidx.wear.compose:compose-navigation:1.1.2"

    // NOTE: DO NOT INCLUDE a dependency on androidx.compose.material:material.
    // androidx.wear.compose:compose-material is designed as a replacement
    // not an addition to androidx.compose.material:material.
    // If there are features from that you feel are missing from
    // androidx.wear.compose:compose-material please raise a bug to let us know.
}

Kotlin

dependencies {
    implementation("androidx.wear.compose:compose-foundation:1.1.2")

    // For Wear Material Design UX guidelines and specifications
    implementation("androidx.wear.compose:compose-material:1.1.2")

    // For integration between Wear Compose and Androidx Navigation libraries
    implementation("androidx.wear.compose:compose-navigation:1.1.2")

    // NOTE: DO NOT INCLUDE a dependency on androidx.compose.material:material.
    // androidx.wear.compose:compose-material is designed as a replacement
    // not an addition to androidx.compose.material:material.
    // If there are features from that you feel are missing from
    // androidx.wear.compose:compose-material please raise a bug to let us know.
}

依存関係について詳しくは、ビルド依存関係の追加をご覧ください。

フィードバック

お寄せいただいたフィードバックは Jetpack 改善の参考にさせていただきます。新しい問題が見つかった場合や、このライブラリを改善するアイデアをお持ちの場合は、お知らせください。新しい問題を報告していただく前に、このライブラリの既存の問題をご確認ください。スターボタンをクリックすると、既存の問題に投票できます。

新しい問題を報告する

詳細については、Issue Tracker のドキュメントをご覧ください。

バージョン 1.2

バージョン 1.2.0-alpha05

2023 年 2 月 22 日

androidx.wear.compose:compose-*:1.2.0-alpha05 がリリースされました。バージョン 1.2.0-alpha05 に含まれる commit については、こちらをご覧ください。

API の変更

  • オプションとして最小制約をコンポーザブルに伝播できるように PickerGroup API を更新しました。true に設定すると、親コンポーザブルから渡された最小制約が PickerGroup で許可されます。false に設定すると、PickerGroup は最小制約をリセットします。(I3e046
  • 特定の Picker オプションへのプログラマティック アニメーションをサポートするため、Picker API に animateScrollToOption を追加しました。(I6fe67

バグの修正

  • 右から左へのレイアウトをサポートするように HorizontalPageIndicator を更新しました。(Ia4359
  • HorizontalPageIndicator での右から左へのレイアウトに対するスクリーンショット テストを追加しました。(I6fbb8
  • TestNavHostController を使用する SwipeDismissableNavHostTest にテストを追加しました。(I61d54

バージョン 1.2.0-alpha04

2023 年 2 月 8 日

androidx.wear.compose:compose-*:1.2.0-alpha04 がリリースされました。バージョン 1.2.0-alpha04 に含まれる commit については、こちらをご覧ください

新機能

  • focus API を使用して複数の Picker をまとめて処理するための PickerGroup。さまざまな Picker 間でフォーカスを処理し、パラメータに基づいて Picker の自動中央揃えを有効にします。デベロッパーは、この機能を使って、グループのイベントを処理する一方でさまざまな Picker の間でフォーカスを変更できます。TalkBack モードでは、PickerGroup は、選択された Picker にグループからフォーカスを移動することで、TalkBack のフォーカスを処理します。(I60840

API の変更

  • デフォルトの範囲セマンティクスの無効化をスムーズに進めるため、enableRangeSemantics パラメータとともに Stepper にオーバーロードを追加しました。(Ia61d4

バグの修正

  • ScalingLazyColumn を横方向のスクロール ページ内にネストできるようにしました。(Iec3f8b/266555016
  • Stepper の kdocs と StepperTest テストのクリーンアップを改善しました。(Ic118e
  • androidx.navigation の依存関係をバージョン 2.5.3 に更新しました。(If58ed

バージョン 1.2.0-alpha03

2023 年 1 月 25 日

androidx.wear.compose:compose-*:1.2.0-alpha03 がリリースされました。バージョン 1.2.0-alpha03 に含まれる commit については、こちらをご覧ください

API の変更

  • ScalingLazyColumn(および関連するクラス)を androidx.wear.compose.material.ScalingLazyColumn から andrdoidx.wear.compose.foundation.lazy.ScalingLazyColumn に移行しました(移行については、こちらの例をご覧ください)。独自のマテリアル コンポーネントではないため、この新しい移行先は compose.foundation.lazy.LazyColumn の場所に近くなり、より自然になりました。この変更は、既存のマテリアル ライブラリと並行して取り組むことになる、新しい Material3 ライブラリに備えて行われたものです。(I060e7

以下の変更はマテリアルから Foundation.Lazy への ScalingLazyColumn の移行の一環です。

  • マテリアルの ScalingLazyColumn をターゲットとする PositionIndicator は非推奨となりました。Foundation.Lazy ScalingLazyColumn に更新してください。また、anchorType フィールドが ScalingLazyListLayoutInfo に追加されました。(I29d95
  • ScalingLazyColumn が Wear Compose Material パッケージで非推奨になりました。(I16d34
  • Wear Compose Foundation.LazyScalingLazyListState を使用するよう ScrollAway 修飾子を更新し、Wear Compose Material の ScalingLazyListState を取得するオーバーロードを非推奨としました。(Ifc42c
  • Foundation.LazyScalingLazyListState を使用するよう Dialog API を更新し、マテリアルの ScalingLazyListState を使用するオーバーロードを非推奨としました。(Ic8960
  • Foundation.LazyScalingParams を使用するよう Picker API を更新し、マテリアルの ScalingParams を使用するオーバーロードを非推奨としました。(Idc3d8

バグの修正

  • 値が実際に変更された場合にのみ更新をプッシュするようにすることで ScalingLazyListState.centerItemIndex での不要な再コンポジションの原因となっていたバグを修正しました。(Ia9f38
  • SwipeToDismissBox のパフォーマンスを改善しました。(I3933b
  • Wear Compose Foundation に ScalingLazyColumn のベンチマーク テストを追加しました。(Ie00f9
  • Foundation.Lazy の同等のものを使用するようにマテリアルの一部の内部 ScalingLazyColumn クラスメソッドを更新しました。(I38aab
  • Picker テストの問題を修正し、オフセットありのスクロールをチェックするためのテストを追加しました。(I6ac34
  • マテリアルの ScalingLazyColumn ではなく Foundation.Lazy に依存するように ScalingLazyColumn の統合デモを移行しました。(Ic6caa
  • DatePicker デモにオプションの fromDate/toDate パラメータを追加しました。(I961cd

バージョン 1.2.0-alpha02

2023 年 1 月 11 日

androidx.wear.compose:compose-*:1.2.0-alpha02 がリリースされました。バージョン 1.2.0-alpha02 に含まれる commit については、こちらをご覧ください

API の変更

  • Android Compose UI テストが、フレームを(waitForIdle などを介して)アイドル状態にするためフレームの実行時にフレームごとにレイアウトパスを実行するようになりました。この変更は、レイアウト アニメーションの個々のフレームでアサートするテストに影響する可能性があります。(I8ea08b/222093277
  • BasicText と動作を同一にするためパラメータ minLines が Wear Text に追加されました。(I24874
  • CompactChipTapTargetPadding が一般公開され、ドキュメントに掲載されるようになりました。(If1e70b/234119038

バグの修正

  • wear.compose パッケージのマルチプラットフォーム ビルドを無効にしました。(Iad3d7
  • scrollToOption の KDocs を修正しました。(I6f9a0
  • rememberUpdatedState を使用するよう PlaceholderState.rememberPlaceholderState() を更新し、onContentReady ラムダの場合に状態が更新されるようにしました。(I02635b/260343754
  • Modifier.graphicsLayer に追加された新しい合成戦略を利用して Picker コンポーネントでテキストの揺れが発生する問題を修正しました。(I99302
  • DatePicker デモでのちらつきの原因だったバグを修正しました。(I660bd
  • 12 時間形式と日付選択ツールのデモのユーザー補助を改善しました。(I05e12
  • 時間形式と日付選択ツールのデモを更新し、選択ツールが選択解除時に RSB の変更の影響を受けないようにしました。(I4aecb

バージョン 1.2.0-alpha01

2022 年 12 月 7 日

androidx.wear.compose:compose-*:1.2.0-alpha01 がリリースされました。バージョン 1.2.0-alpha01 に含まれる commit については、こちらをご覧ください

新機能

  • 次のアニメーション ループが開始するのを待つのではなく、コンテンツの準備ができたらすぐに「ワイプオフ」効果が適用されるように、試験運用版のプレースホルダ機能を更新しました。また、シマーとワイプオフのアニメーションも更新しました。(I5a7f4

API の変更

  • HierarchicalFocusCoordinator コンポーザブルを追加して、コンポジションのサブツリーをフォーカス有効またはフォーカス無効としてマークできるようにしました。(I827cb
  • ToggleButton のセマンティック ロールをオーバーライドする新しいプロパティを追加しました。(I67132
  • TimeText の AM/PM を削除するように TimeTextDefaults.TimeFormat12Hours を更新しました。これにより、TimeText API の timeSource パラメータのデフォルト値が変更されます。(I1eb7f
  • マルチ選択ツールによる画面のユーザー補助機能を改善するために、Picker API を拡張しました。選択ツールがユーザーのスクロールに対してアクティブかどうかを制御する、新しいプロパティ userScrollEnabled が追加されました。(I3c3aa

バグの修正

  • 最終的な UX の仕様に合わせて、OutlinedButton/OutlinedCompactButton のデフォルトの枠線の太さを 2.dp から 1.dp に変更しました。(Icf84d
  • 空の ScalingLazyColumn に最初に追加された項目が所定の位置でスクロールされるように見える効果を軽減するために、コンテンツが空のときに推定 autoCentering topPadding を追加しました。この変更により、最初の項目の高さ 0.dp であると想定して必要なトップ パディングの量が計算されます。ScalingLazyListAnchorType.ItemStart の場合、正しいトップ パディングが計算されます。ScalingLazyListAnchorType.ItemCenter の場合、この計算は正しくありません。これは、コンテンツのサイズを正しく設定するために項目の高さが必要なためです。その結果、項目の実際の高さに基づいて所定の位置で少しスクロールされるように見える効果が発生します。(I239a4
  • Wear プラットフォームに合わせて SwipeToDismiss アニメーションに適用される背景スクリムを更新しました。(I9003e
  • 0 で除算するエラーを回避するために、サイズ 0 のリスト項目に対する LazyListStateScalingLazyListStatePositionIndicator の処理を修正しました。(Ic28dd

バージョン 1.1

バージョン 1.1.2

2023 年 2 月 8 日

androidx.wear.compose:compose-foundation:1.1.2androidx.wear.compose:compose-material:1.1.2androidx.wear.compose:compose-navigation:1.1.2 がリリースされました。バージョン 1.1.2 に含まれる commit については、こちらをご覧ください

バグの修正

  • 値が実際に変更された場合にのみ更新をプッシュするようにすることで ScalingLazyListState.centerItemIndex での不要な再コンポジションの原因となっていたバグを修正しました。(Ia9f38

バージョン 1.1.1

2023 年 1 月 11 日

androidx.wear.compose:compose-foundation:1.1.1androidx.wear.compose:compose-material:1.1.1androidx.wear.compose:compose-navigation:1.1.1 がリリースされました。バージョン 1.1.1 に含まれる commit については、こちらをご覧ください

バグの修正

  • rememberUpdatedState を使用するよう PlaceholderState.rememberPlaceholderState() を更新し、onContentReady ラムダの場合に状態が更新されるようにしました。(I02635b/260343754

バージョン 1.1.0

2022 年 12 月 7 日

androidx.wear.compose:compose-foundation:1.1.0androidx.wear.compose:compose-material:1.1.0androidx.wear.compose:compose-navigation:1.1.0 がリリースされました。バージョン 1.1.0 に含まれる commit については、こちらをご覧ください

1.0.0 以降の重要な変更

  • Wear OS 1.1.0 向け Compose の安定版リリースです(詳細)。
  • Wear Compose 1.1 の主な変更点の一覧については、リリースノート(Compose for Wear OS 1.1 Beta01)をご覧ください。

新機能

  • 次のアニメーション ループが開始するのを待つのではなく、コンテンツの準備ができたらすぐに「ワイプオフ」効果が適用されるように、試験運用版のプレースホルダ機能を更新しました。また、シマーとワイプオフのアニメーションも更新しました。(I5a7f4

バグの修正

  • 最終的な UX の仕様に合わせて、OutlinedButton/OutlinedCompactButton のデフォルトの枠線の太さを 2.dp から 1.dp に変更しました。(Icf84d
  • 空の ScalingLazyColumn に最初に追加された項目が所定の位置でスクロールされるように見える効果を軽減するために、コンテンツが空のときに推定 autoCentering topPadding を追加しました。この変更により、最初の項目の高さ 0.dp であると想定して必要なトップ パディングの量が計算されます。ScalingLazyListAnchorType.ItemStart の場合、正しいトップ パディングが計算されます。ScalingLazyListAnchorType.ItemCenter の場合、この計算は正しくありません。これは、コンテンツのサイズを正しく設定するために項目の高さが必要なためです。その結果、項目の実際の高さに基づいて所定の位置で少しスクロールされるように見える効果が発生します。(I239a4
  • Wear プラットフォームに合わせて SwipeToDismiss アニメーションに適用される背景スクリムを更新しました。(I9003e
  • 0 で除算するエラーを回避するために、サイズ 0 のリスト項目に対する LazyListStateScalingLazyListStatePositionIndicator の処理を修正しました。(Ic28dd

バージョン 1.1.0-rc01

2022 年 11 月 9 日

androidx.wear.compose:compose-foundation:1.1.0-rc01androidx.wear.compose:compose-material:1.1.0-rc01androidx.wear.compose:compose-navigation:1.1.0-rc01 がリリースされました。バージョン 1.1.0-rc01 に含まれる commit については、こちらをご覧ください

バグの修正

  • PlaceholdersScrollAwayRadioButtonSwitchCheckboxOutlinedButtonOutlinedCompactButtonOutlinedChipOutlinedCompactChip のベースライン プロファイル ルールを追加しました。(I8249c
  • Modifier.scrollAway のバグを修正しました。これにより、指定された itemIndex が無効である(たとえば、アイテム インデックスが範囲外である)場合でも TimeText が表示されるようになりました。(I2137a
  • プラットフォームの実装に合わせて SwipeToDismissBox アニメーションを更新しました。最初のスクイーズ アニメーションの後、非表示がトリガーされると、画面が右にスライドして隠れるようになります。(I41d34
  • 最適化の一環として、Modifier.scrollAway を更新し、測定ブロック内の scrollState のみを読み取るようにしました。これにより、再測定のたびに修飾子が再コンポーズされることを回避できます。(I4c6f1
  • プレースホルダにドキュメントとサンプルを追加して、同じコンポーザブルに適用した場合の Modifier.placeholderModifier.placeholderShimmer の正しい順序を示しました。(Ie96f4b/256583229
  • 最終的な UX の仕様に合わせて、OutlinedCompactChip/OutlinedChip のデフォルトの枠線の太さを 2.dp から 1.dp に変更しました。(Ib3d8e
  • rememberPickerState で更新された入力が保存されず、入力の変更後にコンポーザブルが更新されないバグを修正しました。(I49ff6b/255323197
  • プレースホルダの UI を更新し、1)シマー グラデーションを画面サイズの 1.5 倍に変更し、2)シマーの進行のイージング(3 次ベジェ)を追加し、3)wipeOff アニメーションを高速化しました(250 ミリ秒)。(Id29c1
  • 画面上のコンポーネントの位置が考慮されていないため、チップとカードの背景が少し早めに消えるという、プレースホルダの wipeOff エフェクトにおける UI のバグを修正しました。(I2c7cb
  • プレースホルダの背景の描画を更新して、可能であれば色を重ねるのではなく合成するようにしました。これにより、切り抜いた複数のレイヤのアルファ ブレンディングのリスクを減らし、プレースホルダの背景の端で下の色がはみ出ないようにしました。(I2ea26
  • ビューポートの中心線の両側に 2 つのアイテムが 1 つずつある場合、最も近いものが centerItem と見なされるように、ScalingLazyListState.centerItemIndex/centerItemOffset の計算を修正しました。(I30709b/254257769
  • ScalingLazyColumn の初期化中に誤ったオフセットをレポートする ScalingLazyListState.layoutInfo.visibleItemsInfo のバグを修正しました。すべてのリスト アイテムが表示され、正しいオフセットが設定されるまで、空のリストが返されるようになりました。ScalingLazyListState.layoutInfo.visibleItemsInfo.isNotEmpty() をチェックして、ScalingLazyColumn の初期化が完了してアイテムが表示されていることを確認してください。(I3a3b8

バージョン 1.1.0-beta01

2022 年 10 月 24 日

androidx.wear.compose:compose-foundation:1.1.0-beta01androidx.wear.compose:compose-material:1.1.0-beta01androidx.wear.compose:compose-navigation:1.1.0-beta01 がリリースされました。バージョン 1.1.0-beta01 に含まれる commit については、こちらをご覧ください

Wear OS 向け Compose 1.1 の概要

Wear OS 向け Compose 1.1.0-beta01 では、ライブラリのこのリリースは機能が完成し、API がロックされていることが表明されました。

  • Wear Compose 1.1 リリースには、次の新機能が含まれています。
    • Picker - Picker のユーザー補助機能を改善して、マルチ選択ツールの画面をスクリーン リーダーで操作できるようにし、コンテンツの説明をわかりやすくしました。
    • Picker の contentDescription パラメータが、選択された Picker オプションでのみ使用され、null 許容型の文字列を取るようになりました(以前の commit では、オプションからのマッピングをコンテンツの説明に渡す必要がありましたが、選択されたオプションしか使用されませんでした)。
    • Picker の項目が常に中央揃えになり、gradientRatio をゼロに設定すると配置が変更されるという副作用のバグを修正しました。
    • Chip/ToggleChip - 最新の UX 仕様に合わせて Chip/ToggleChip のデフォルト グラデーションを更新しました。プライマリの 32.5% ではなく 50% から開始するように ChipDefaults.gradientBackgroundChipColors を更新しました。
    • Chip/ToggleChip - チップ形状を変更するためのオーバーロードを追加しました。
    • Chip/Button/ToggleButton - チップとボタン用の新しい枠線付きスタイルと、細い枠線付きの透明な Chip/Button を提供する新しいコンポーザブル OutlinedChip および OutlinedButton を追加しました。
    • カード - 最新の UX 仕様に合わせてカードのデフォルトのグラデーションを更新しました。プライマリの 30% から開始して onSurfaceVariant の 20% で終了するように CardDefaults.cardBackgroundPainter を更新しました(以前は 20% から開始して onSurfaceVariant の 10% で終了していました)。ToggleChip.toggleChipColors は、「75% サーフェスから 32.5% プライマリへの線形グラデーション」から「0% サーフェスから 50% プライマリへの線形グラデーション」に変わります。
    • Button/ToggleButton - ボタンの形状を変更するためのプロパティを追加しました。
    • テーマ - ユーザー補助機能の改善のため、MaterialTheme のデフォルトの色をいくつか更新しました。元の色はコントラストが不十分だったため、ユーザーがチップ / カード / ボタンの背景をテーマの背景色から区別することが困難でした。
    • InlineSlider/Stepper - Talkback がこれらをボタンとして認識できるように、ボタンの役割を追加しました。
    • Scaffold - 必要なスペースのみを占有するよう PositionIndicator が配置されてサイズが設定されるようになりました。これは、セマンティック情報が追加された場合などに役立ち、TalkBack が画面上の PositionIndicator の正しい境界を取得するようになりました。
    • CurvedText/TimeText - スクロール状態に応じて、ビューの内 / 外に垂直方向に項目をスクロールする Modifier.scrollAway を追加しました(オーバーロードによって ColumnLazyColumnScalingLazyColumn と連動します)。一般に、ユーザーが項目リストを上方向にスクロールし始めたときは ScrollAway を使用してビューの外に TimeText をスクロールします。
    • CurvedText/TimeText - CurvedTextStylefontFamilyfontStylefontSynthesis のサポートを追加しました。curvedTextbasicCurvedText で使用できます。
    • CurvedText/TimeText - CurvedTextStyle のコンストラクタとコピーメソッドに fontWeight を追加しました。
    • ToggleControls - ToggleChipSplitToggleChip で使用するアニメーション切り替えコントロールとして CheckboxSwitchRadioButton を追加しました。これらは、ToggleChipDefaults によって提供される静的アイコン(switchIconcheckboxIconradioIcon)の代わりに使用できます。
    • プレースホルダ - 試験運用版のプレースホルダのサポートを追加しました。このサポートには、一緒に動作するように設計された 3 種類の視覚効果があります。
    • 1 つ目は、チップやカードなどのコンテナで使用するプレースホルダの背景ブラシ エフェクトで、コンテンツの読み込みを待つときに、通常の背景の上に描画されるものです。
    • 2 つ目は、読み込まれているコンテンツの上にスタジアムの形のプレースホルダ ウィジェットを描画する修飾子(Modifier.placeholder())です。
    • 3 つ目は、データの読み込みを待っていることをユーザーに伝えるために、他のエフェクトの上に重ねて表示される修飾子のグラデーション / シマー エフェクト(Modifier.placeholderShimmer())です。
      • これらすべてのエフェクトは協調して動作し、きらめいた後に消えるように設計されています。
  • Core Compose の依存関係を 1.2 から 1.3 に更新しました。

API の変更

  • フォント パラメータ(fontFamilyfontWeightfontStylefontSynthesis)を curvedText のパラメータとして直接指定できるようになりました。(Idc422

バグの修正

  • curveTextbasicCurvedText が TalkBack で適切に動作するようになりました(適切なサイズで配置される(ただし空の)compose-ui ノードが関連付けられ、テキストをコンテンツの説明として使用します)。(I7af7cb/210721259
  • PickerState.repeatedItems = false の場合の Picker のバグを修正し、Picker の内部 ScalingLazyColumn に autoCentering パラメータの明示的な設定を追加しました。これにより、ゼロ番目のオプションをビューの中央にスクロールできるようになります。(I8a4d7

バージョン 1.1.0-alpha07

2022 年 10 月 5 日

androidx.wear.compose:compose-foundation:1.1.0-alpha07androidx.wear.compose:compose-material:1.1.0-alpha07androidx.wear.compose:compose-navigation:1.1.0-alpha07 がリリースされました。バージョン 1.1.0-alpha07 に含まれる commit については、こちらをご覧ください

新機能

  • 試験運用版のプレースホルダのサポートを追加しました。このサポートには、一緒に動作するように設計された 3 種類の視覚効果があります。1 つ目は、チップやカードなどのコンテナで使用するプレースホルダの背景ブラシ エフェクトで、コンテンツの読み込みを待つときに、通常の背景の上に描画されるものです。2 つ目は、読み込まれているコンテンツの上にスタジアムの形のプレースホルダ ウィジェットを描画する修飾子(Modifier.placeholder())です。3 つ目は、データの読み込みを待っていることをユーザーに伝えるために、他のエフェクトの上に重ねて表示される修飾子のグラデーション / シマー エフェクト(Modifier.placeholderShimmer())です。これらすべてのエフェクトは協調して動作し、きらめいた後に消えるように設計されています。(I3c339

API の変更

  • CurvedTextStylefontWeightfontFamilyfontStylefontSynthesis のサポートを追加しました。curvedTextbasicCurvedText で使用できます。これらのパラメータを使用して、曲線テキストで使用するフォントとスタイルを指定できます。(Iaa1a8)、(I72759
  • Modifier.offset との一貫性を保つため、Modifier.scrollAway のオフセット パラメータを Dp に更新しました(以前はピクセル単位で表示)。また、効率化のために LayoutModifier としてリファクタリングしました。(I9f94b
  • 新しい切り替えコントロール API の一部として、RadioButton’s circleColor の名前を ringColor に変更しました。(I28fa9
  • ToggleChipSplitToggleChip で使用するアニメーション切り替えコントロールとして CheckboxSwitchRadioButton を追加しました。これらは、ToggleChipDefaults によって提供される静的アイコン(switchIconcheckboxIconradioIcon)の代わりに使用できます。(I8a8c4

バージョン 1.1.0-alpha06

2022 年 9 月 21 日

androidx.wear.compose:compose-foundation:1.1.0-alpha06androidx.wear.compose:compose-material:1.1.0-alpha06androidx.wear.compose:compose-navigation:1.1.0-alpha06 がリリースされました。バージョン 1.1.0-alpha06 に含まれる commit については、こちらをご覧ください。

新機能

  • スクロール状態に応じて、ビューの内 / 外に垂直方向に項目をスクロールする Modifier.scrollAway を追加しました(オーバーロードによって ColumnLazyColumnScalingLazyColumn と連動します)。一般に、ユーザーが項目リストを上方向にスクロールし始めたときは ScrollAway を使用してビューの外に TimeText をスクロールします。(I61766

バグの修正

  • 必要なスペースのみを占有するよう PositionIndicator が配置されてサイズが設定されるようになりました。これは、セマンティック情報が追加された場合などに役立ち、TalkBack が画面上の PositionIndicator の正しい境界を取得するようになりました。(Ie6106b/244409133

バージョン 1.1.0-alpha05

2022 年 9 月 7 日

androidx.wear.compose:compose-foundation:1.1.0-alpha05androidx.wear.compose:compose-material:1.1.0-alpha05androidx.wear.compose:compose-navigation:1.1.0-alpha05 がリリースされました。バージョン 1.1.0-alpha05 に含まれる commit については、こちらをご覧ください

バグの修正

  • Talkback がボタンとして認識できるように、InlineSliderStepper にボタンの役割が追加されました。(Icb46cb/244260275
  • Scaffold で位置とページ インジケーターの Z オーダーを修正しました。インジケーターは周辺減光の上に表示されるようになりました。そのため、周辺減光が存在する場合に、インジケーターが周辺減光によって隠れることはなくなります。(Ib988fb/244207528

バージョン 1.1.0-alpha04

2022 年 8 月 24 日

androidx.wear.compose:compose-foundation:1.1.0-alpha04androidx.wear.compose:compose-material:1.1.0-alpha04androidx.wear.compose:compose-navigation:1.1.0-alpha04 がリリースされました。バージョン 1.1.0-alpha04 に含まれる commit については、こちらをご覧ください

API の変更

  • ユーザー補助機能の改善のため、MaterialTheme のデフォルト色をいくつか更新しました。元の色はコントラストが十分でなく、チップや、カード、ボタンの背景と、テーマの背景色をユーザーが区別しにくかったためです。更新した色は、surface(0xFF202124 -> 0xFF303133)、onPrimary(0xFF202124 -> 0xFF303133)、onSecondary(0xFF202124 -> 0xFF303133)、primaryVariant(0xFF669DF6 -> 0xFF8AB4F8)、onError(0xFF202124 -> 0xFF000000)です。比較的わずかな変更であっても、色の変更は、既存のスクリーンショット テストに影響を与える可能性があります。(81ab09

バグの修正

  • 項目数が少ない(一般に項目が 2 個の)リストの初期化が完了せず、透明になることがあるという ScalingLazyColumn のロジックのバグを修正しました。(504347

バージョン 1.1.0-alpha03

2022 年 8 月 10 日

androidx.wear.compose:compose-foundation:1.1.0-alpha03androidx.wear.compose:compose-material:1.1.0-alpha03androidx.wear.compose:compose-navigation:1.1.0-alpha03 がリリースされました。バージョン 1.1.0-alpha03 に含まれる commit については、こちらをご覧ください

新機能

  • ChipsButtons の新しい枠線付きスタイルと、OutlinedChipOutlinedButton の新しいコンポーザブルを新たに追加しました。これにより、細い枠線付きの透明な Chip/Button を利用できます。(Id5972

API の変更

  • ボタン形状を変更するためのオーバーロードを追加しました。(Icccde

バグの修正

  • UX 仕様と一致しないため、ToggleChip の切り替えコントロール領域のサイズを修正しました。UX 仕様では、ラベルと 24x24.dp の切り替えコントロール アイコン領域との間に 4.dp のスペーサーを設ける(合計で 28.dp の幅になる)ことになっています。しかし、実装時に切り替えコントロール領域が誤って 36x24.dp になってしまい、使用可能なテキストラベルの領域が 8.dp 減っていました。注: このバグの修正によってテキストラベル用のスペースが広がるため、テキストのレイアウトに影響を及ぼす(テキストがはみ出さなくなる)可能性があります。ToggleChips を含むスクリーンショット テストがある場合は、更新の必要があるかもしれません。(I514c8b/240548670

バージョン 1.1.0-alpha02

2022 年 7 月 27 日

androidx.wear.compose:compose-foundation:1.1.0-alpha02androidx.wear.compose:compose-material:1.1.0-alpha02androidx.wear.compose:compose-navigation:1.1.0-alpha02 がリリースされました。バージョン 1.1.0-alpha02 に含まれる commit については、こちらをご覧ください

新機能

  • コア Compose ライブラリでの Wear OS 向け Compose の依存関係を 1.2.0 から 1.3.0-alpha0X に切り替えました。

API の変更

  • チップ形状を変更するためのオーバーロードを追加しました。(I02e87

バグの修正

  • 既存のスケーリング アニメーションと整合するよう、ダイアログの表示 / 非表示時に周辺減光される状態の可視性をアニメーション化しました。(Ida33e
  • スクロール時の一部のフリング動作でゼロ除算が発生することがあるバグを修正しました。(I86cb6
  • 無効な背景色が完全に透明になるよう ChipDefaults.childChipColor() のバグを修正しました。(I2b3c3b/238057342

バージョン 1.1.0-alpha01

2022 年 6 月 29 日

androidx.wear.compose:compose-foundation:1.1.0-alpha01androidx.wear.compose:compose-material:1.1.0-alpha01androidx.wear.compose:compose-navigation:1.1.0-alpha01 がリリースされました。バージョン 1.1.0-alpha01 に含まれる commit については、こちらをご覧ください

API の変更

  • Picker の contentDescription パラメータが、選択された Picker オプションでのみ使用され、null 許容型の文字列を取るようになりました(以前は、オプションからのマッピングをコンテンツの説明に渡す必要がありましたが、選択されたオプションしか使用されませんでした)。(Ife6a7
  • Picker のユーザー補助機能を改善し、マルチ選択ツール画面をスクリーン リーダーで操作したり、コンテンツの説明にアクセスしたりできるようにしました。(I64edb

バグの修正

  • Wear Compose ライブラリにパッケージ化されているベースライン プロファイル ルールを更新しました。(I9c694
  • 「右から左」モードの場合のチップのグラデーションの方向を修正しました。以前は「左上 -> 右下」でしたが、現在は「右上 -> 左下」になりました。(Ic2e77
  • 最新の UX 仕様に合わせて Chip/ToggleChip/Card のデフォルトのグラデーションを更新しました。プライマリの 32.5% ではなく 50% から開始するように ChipDefaults.gradientBackgroundChipColors を更新しました。プライマリの 30% から開始して onSurfaceVariant の 20% で終了するように CardDefaults.cardBackgroundPainter を更新しました(以前は 20% から開始して onSurfaceVariant の 10% で終了していました)。ToggleChip.toggleChipColors は、「75% サーフェスから 32.5% プライマリへの線形グラデーション」から「0% サーフェスから 50% プライマリへの線形グラデーション」に変わります。(I43bbd
  • 万一、背後で明るい色が使用された場合に適切に表示されるように、グラデーションの背景を持つ Chip/ToggleChips の背後に背景色(MaterialTheme.color.surface)を追加しました。(Ibe1a4b/235937657
  • Picker の項目が常に中央揃えになり、gradientRatio をゼロに設定すると配置が変更されるという副作用のバグを修正しました。(I712b8

バージョン 1.0

バージョン 1.0.2

2022 年 9 月 7 日

androidx.wear.compose:compose-foundation:1.0.2androidx.wear.compose:compose-material:1.0.2androidx.wear.compose:compose-navigation:1.0.2 がリリースされました。バージョン 1.0.2 に含まれる commit については、こちらをご覧ください

バグの修正

  • Scaffold で位置とページ インジケーターの Z オーダーを修正しました。インジケーターは周辺減光の上に表示されるようになりました。そのため、周辺減光が存在する場合に、インジケーターが周辺減光によって隠れることはなくなります。(Ib988fb/244207528

バージョン 1.0.1

2022 年 8 月 24 日

androidx.wear.compose:compose-foundation:1.0.1androidx.wear.compose:compose-material:1.0.1androidx.wear.compose:compose-navigation:1.0.1 がリリースされました。バージョン 1.0.1 に含まれる commit については、こちらをご覧ください

バグの修正

  • 項目数が少ない(一般に項目が 2 個の)リストの初期化が完了せず、透明になることがあるという ScalingLazyColumn のロジックのバグを修正しました。(076c61

バージョン 1.0.0

2022 年 7 月 27 日

androidx.wear.compose:compose-foundation:1.0.0androidx.wear.compose:compose-material:1.0.0androidx.wear.compose:compose-navigation:1.0.0 がリリースされました。バージョン 1.0.0 に含まれる commit については、こちらをご覧ください

1.0.0 の主な機能

  • これは、Wear OS 向け Compose の最初の安定版リリースです(詳細)。
  • Wear OS 向け Compose は、コア Compose ライブラリをベースとして、追加のウェアラブル固有コンポーネントと、必要に応じて、ウェアラブル デバイスに合わせて調整されたコア Compose コンポーネントの別の実装を提供します。
  • Wear Compose の主なコンポーネントのリストについては、リリースノート(Compose for Wear OS Beta01)をご覧ください。

バグの修正

  • 既存のスケーリング アニメーションと整合するよう、ダイアログの表示 / 非表示時に周辺減光される状態の可視性をアニメーション化しました。(Ida33e
  • スクロール時の一部のフリング動作でゼロ除算が発生することがあるバグを修正しました。(I86cb6
  • 無効な背景色が完全に透明になるよう ChipDefaults.childChipColor() のバグを修正しました。(I2b3c3b/238057342

バージョン 1.0.0-rc02

2022 年 6 月 22 日

androidx.wear.compose:compose-foundation:1.0.0-rc02androidx.wear.compose:compose-material:1.0.0-rc02androidx.wear.compose:compose-navigation:1.0.0-rc02 がリリースされました。バージョン 1.0.0-rc02 に含まれる commit については、こちらをご覧ください

バグの修正

  • 右から左(RTL)モードの場合のカードのグラデーションの方向を修正しました。以前は「左上 -> 右下」でしたが、現在は「右上 -> 左下」になりました。(Ic2e77
  • 最新の UX 仕様に合わせて Chip/ToggleChip/Card のデフォルトのグラデーションを更新しました。プライマリの 32.5% ではなく 50% から開始するように ChipDefaults.gradientBackgroundChipColors を更新しました。プライマリの 30% から開始して onSurfaceVariant の 20% で終了するように CardDefaults.cardBackgroundPainter を更新しました(以前は 20% から開始して onSurfaceVariant の 10% で終了していました)。ToggleChip.toggleChipColors は、「75% サーフェスから 32.5% プライマリへの線形グラデーション」から「0% サーフェスから 50% プライマリへの線形グラデーション」へと変わります。(I43bbd
  • 万一、背後で明るい色が使用された場合に適切に表示されるように、グラデーションの背景を持つ Chip/ToggleChips の背後に背景色(MaterialTheme.color.surface)を追加しました。(Ibe1a4b/235937657
  • Wear Compose ライブラリにパッケージ化されているベースライン プロファイル ルールを更新しました。(I9c694

バージョン 1.0.0-rc01

2022 年 6 月 15 日

androidx.wear.compose:compose-foundation:1.0.0-rc01androidx.wear.compose:compose-material:1.0.0-rc01androidx.wear.compose:compose-navigation:1.0.0-rc01 がリリースされました。バージョン 1.0.0-rc01 に含まれる commit については、こちらをご覧ください

API の変更

  • compose ライブラリのインターフェースが jdk8 デフォルト インターフェース メソッドを使ってビルドされるようになりました。(I5bcf1

バグの修正

  • リストのヘッダーでの fillMaxWidth() の明示的な呼び出しは、ScalinglazyColumnListHeader() コンポーネントと Chip() コンポーネントが混在している場合には不要であり、問題が発生する可能性があるため、削除しました。ListHeader のアイテムは、スクロールされて表示 / 非表示になるときに幅が拡大 / 縮小される傾向にあるためです。(I37144b/235074035
  • ScalingLazyColumn のバグを修正しました。このバグは、0 番目のリストアイテムが(パディングを含めて)十分に大きい場合に、スクロールされるまでリストアイテムが正しく描画されない原因となっていました。(Ic6159b/234328517
  • UX 仕様の更新に合わせて、アイテムが画面の端に達したときの ScalingLazyColumn のイージングを若干調整しました。以前の値 CubicBezierEasing(0.25f, 0.00f, 0.75f, 1.00f) -> 新しい値 CubicBezierEasing(0.3f, 0f, 0.7f, 1f)。以前の動作を維持するには、ScalingLazyColumnscalingParams をオーバーライドできます。(Ie375c
  • マテリアルのユーザー補助ガイドラインに沿ってタップ ターゲットのサイズが高さ 48 dp 以上になるように、CompactChip にパディングを追加しました。追加のスペースを取ることになるため、CompactChips を使用するレイアウトがある場合は、この変更の影響を受ける可能性があります。(I3d57c

バージョン 1.0.0-beta03

2022 年 6 月 1 日

androidx.wear.compose:compose-foundation:1.0.0-beta03androidx.wear.compose:compose-material:1.0.0-beta03androidx.wear.compose:compose-navigation:1.0.0-beta03 がリリースされました。バージョン 1.0.0-beta03 に含まれる commit については、こちらをご覧ください

新機能

  • ScalingLazyColumn が Compose @Preview モードで機能するようになりました。(I3b3b6b/232947354

API の変更

  • リストアイテムが列の幅全体に広がらない場合、できる限り見やすくなるよう配置されるように、ScalingLazyColumn.horizontalAlignment プロパティのデフォルト値を Start から CenterHorizontally に変更しました。以前の動作に戻すには、horizontalAlignment = Alignment.Start を設定します。(I9ed4b

既知の問題

  • CompactChip のタップの高さがマテリアルのユーザー補助ガイドラインよりも小さくなっています。この問題は次のリリース(6 月 15 日)で修正される予定です。CompactChip の上下にパディングが追加されるため、CompactChip を使用している場合は、この修正がレイアウトに影響を与えます。レイアウトを調整してテストするか、既存の動作を使用する場合はバグコメントで回避策を確認してください。(b/234332135

バグの修正

  • TimeText で開始テキストの追加または削除をアニメーション化する新しいデモ。(I16d75
  • HorizontalPageIndicator.PagesState のテストを追加しました。(I64ed0
  • TimeText を UX 仕様に近づけて更新しました。(Ib7ea1

バージョン 1.0.0-beta02

2022 年 5 月 18 日

androidx.wear.compose:compose-foundation:1.0.0-beta02androidx.wear.compose:compose-material:1.0.0-beta02androidx.wear.compose:compose-navigation:1.0.0-beta02 がリリースされました。バージョン 1.0.0-beta02 に含まれる commit については、こちらをご覧ください。

新機能

  • 選択ツールが、読み取り専用モードの場合でも、常にスクロール イベントに応答するようになりました。これにより、ユーザーはスクロールする前に、まずタップして選択ツールを選択する必要がなくなります。読み取り専用モードでは、現在選択されているオプション以外のオプションは、gradientColor の shim によって隠れます。(I72925
  • Chip/ToggleChip/CompactChip/SplitToggleChip の UX 動作を変更し、デフォルトで fillMaxWidth を実行できないようにしました。代わりに、コンテンツに合わせて大きくなります。以前の動作を維持するには、modifier = Modifier.fillMaxWidth() を追加します(I60a2cb/232206371

バグの修正

  • TextStyle を受け取る CurvedTextStyle コンストラクタが fontWeight も考慮するようになりました(これは、API の今後のリビジョンでコンストラクタとコピーメソッドに追加される可能性があります)(Ieebb9
  • エッジスワイプの改善。Modifier.edgeSwipeToDismiss が使用されており、左へのスワイプがエッジエリアからトリガーされた場合、スワイプの向きが右に変更されたときにスワイプによる非表示がトリガーされることがなくなりました。以前は、左にスワイプしてから右にスワイプすることで、スワイプによる非表示をトリガーできました(I916ea
  • HorizontalPageIndicator が画面に最大 6 ページ表示されるようになりました。合計で 6 ページを超える場合は、左または右に半分のサイズのインジケーターが表示され、ページ間の移動がスムーズになります。(I2ac29
  • ScalingLazyColumnPicker のデフォルトのスナップ動作を改善しました(I49539
  • エッジスワイプの改善。Modifier.edgeSwipeToDismiss が使用されている場合、スワイプによる非表示は、最初のタップが端に到達して右にスワイプしたときのみトリガーされます。以前は、スクロールが開始点に達したら画面の任意の場所からスワイプすることで、スワイプによる非表示をトリガーできました。(I8ca2a

バージョン 1.0.0-beta01

2022 年 5 月 11 日

androidx.wear.compose:compose-foundation:1.0.0-beta01androidx.wear.compose:compose-material:1.0.0-beta01androidx.wear.compose:compose-navigation:1.0.0-beta01 がリリースされました。バージョン 1.0.0-beta01 に含まれる commit については、こちらをご覧ください

Wear OS 1.0 の Compose の概要

Wear OS の Compose の 1.0.0-beta01 は、ライブラリの機能が完成し、API がロックされているため、重要なマイルストーンとしてマークしています。

1.0 リリースの Wear Compose Material コンポーネントには、次のものがあります。

  • マテリアル テーマ - モバイル デバイス用の MaterialTheme の代替として使用され、Wear マテリアル デザインの UX ガイドラインを初期設定の状態で実装するウェアラブルでコンポーネントをビルドする際の色、形状、タイポグラフィを指定します。
  • ButtonCompactButtonToggleButton - ボタンには、アイコン、画像、短いテキスト(最大 3 文字)を取得するためのスロットが 1 つ用意されています。デフォルト ボタン、大ボタン、小ボタンに推奨されるサイズの円形。CompactButton は、コンテンツ(アイコン、画像、テキスト)を取得できる単一のスロットを備えており、背景がひときわ小さなサイズの円形です。CompactButton には、クリック可能な領域を拡大する背景の周囲にオプションとして透明なパディングを備えています。ToggleButton は、コンテンツ(短いテキスト、アイコン、画像)の取得を 1 つのスロットで行うボタンです。色分けとさまざまなアイコンでオン / オフ(チェックマークあり / チェックマークなし)の状態を示し、オン / オフのいずれであるかを表示します。
  • カード - 通知などのアプリケーションに関する情報を表示するために使用します。AppCardTitleCard のさまざまなユースケースで柔軟な設計を実現し、異なるレイアウトが用意されており、カードのコンテンツまたは背景として画像をサポートします。
  • チップ - ボタンに類似したスタジアムの形のコンポーネントですが、エリアが広くなり、ラベル、セカンダリ ラベル、アイコン用の複数のスロットを備えています。さまざまなサイズで、背景としての画像をサポートしています。
  • ToggleChip と SplitToggleChip - オン / オフの状態のチップで、コンポーネントにチェックマークが入れられた状態を表示するスイッチやラジオボタンなどのアイコンを表示する ToggleControl スロットが追加されています。また、SplitToggleChip には 2 つ(クリック可能と切り替え可能)のタップ可能な領域があります。
  • CircularProgressIndicator - 2 つのパターンの Wear マテリアル進行状況インジケーター。1 つ目は、進行中のタスクの完了割合を表し、開始角度と終了角度の間の円形トラックのギャップをサポートします。2 つ目は、不特定の待機時間における不確定な進行状況を示します。
  • curvedText - curvedRowcurvedColumn とともに CurvedLayouts を記述し、円形デバイスの周囲にコンポーネントをレイアウトするための DSL の一部を構成します。CurvedLayoutCurvedModifier の詳細については、以下の Wear Component Foundation をご覧ください(これは、曲線でない世界で修飾子と同様の役割を果たし、レイアウト、パディング、グラデーションなどのさまざまな要素の構成を可能にします)。
  • ダイアログ、アラート、確認 - ダイアログは、他のコンテンツの上に重ねて全画面ダイアログを表示し、スワイプして閉じることができます。アラートや確認など、Wear マテリアルの独自のダイアログ コンテンツとみなされる単一のスロットを取ります。アラートは独自のダイアログ コンテンツであり、アイコン、タイトル、メッセージ用のスロットが含まれます。横に並んだ 2 つのネガティブ ボタンとポジティブ ボタン、または 1 つ以上の垂直に積み重ねられたチップのスロットで過負荷が発生します。確認は、一定期間のメッセージを表示する独自のダイアログ コンテンツです。このファイルには、アイコンや画像(アニメーション表示が可能)用のスロットが用意されています。
  • HorizontalPageIndicator - ウェアラブルのフォーム ファクタに適した方法で水平方向のページ位置を表示します。全画面表示を行い、円形のデバイスに曲線インジケーターを表示するように設計されています。Accompanist ページビューアで使用できます。
  • アイコン - Wear のマテリアル テーマから色とアルファを取得するアイコンの Wear 実装。クリック可能なアイコンについては、ボタンまたはチップをご覧ください。
  • 選択ツール - スクロール可能な選択候補アイテムのリストを表示します。デフォルトでは、アイテムは両方向に「無限」に繰り返されます。読み取り専用モードで表示し、未選択のオプションを非表示にできます。
  • PositionIndicator - ウェアラブルのフォーム ファクタに適した方法で、スクロール位置またはその他の位置を表示します。全画面表示を行い、円形のデバイスに曲線インジケーターを表示するように設計されています。
  • Scaffold - 基本的な Wear マテリアル デザインの視覚レイアウト構造を実装します。このコンポーネントには、画面を構成する複数の Wear マテリアル コンポーネント(TimeTextPositionIndicatorVignette など)をまとめる API が用意されており、それらのコンポーネントに適したレイアウト戦略を策定し、必要なデータを収集してコンポーネントが正しく連携するようにできます。
  • ScalingLazyColumn - Wear マテリアル デザイン言語の主要部分を形成するスクロールのスケーリング / 魚眼リスト コンポーネントです。コンテンツ アイテムにスケーリングと透過性効果をもたらします。ScalingLazyColumn は、膨大な量に達する可能性があるコンテンツ アイテムを処理できるように設計されています。コンテンツ アイテムは、必要なときにのみ実体化されて構成されます。
  • Slider - 使用することでユーザーは値の範囲から選択できます。選択範囲はバーとして表示され、必要に応じてセパレータを追加して表示できます。
  • Stepper - 画面の上部と下部に配置された増加 / 減少ボタンを使用し、テキストまたはチップの中央にあるスロットを使用して、ユーザーが特定の値の範囲から選択できるようにする全画面コンポーネント。
  • SwipeToDismissBox - スワイプして閉じる操作を処理します。1 つのスロットを取り、背景(スワイプ操作中にのみ表示される)とフォアグラウンドのコンテンツを配置します。必要に応じて、SwipeDismissableNavHost を使用して androidx ナビゲーション ライブラリと組み合わせることができます(以下の Wear Compose Navigation ライブラリをご覧ください)。
  • テキスト - Wear のマテリアル テーマから色とアルファを取得する Compose マテリアル テキスト コンポーネントの Wear 実装。
  • TimeText - 画面上部に時刻とアプリケーションのステータスを表示するためのコンポーネント。円形の画面で曲線テキストを使用して、画面の形状に合わせて調整します。
  • 周辺減光 - Scaffold で使用する画面処理であり、スクロール可能なコンテンツを使用しているときに画面の上と下をぼかします。

  • Wear Compose Foundation の次のコンポーネントも含まれています。

  • CurvedLayout - Wear Foundation CurvedLayout は、子を円弧に配置し、必要に応じて回転させるレイアウト コンポーザブルです。これは、環状のセグメントに曲線で表される行レイアウトに類似しています。CurvedLayout の内容はコンポーズ可能なラムダではなく、DSL(ドメイン固有の言語)です。CurvedLayout の DSL 内のすべての要素は、CurvedModifier から作成されたオプションの修飾子パラメータをサポートしています。

  • basicCurvedText - CurvedLayout DSL の要素である basicCurvedText を使用すると、デベロッパーは円の曲率に沿って(通常は円形の画面の端)、曲線テキストを簡単に記述できます。basicCurvedText は、配置を指定できるようにする、CurvedModifiers を使用するなど、最適な環境を確保するために、CurvedLayout 内でのみ作成できます。なお、ほとんどの場合にマテリアル テーマ設定を使用する curvedText を使用する必要があります。

  • curvedComposable - 通常のコンポーザブルのコンテンツをラップし、CurvedLayout で使用できるようにします。curvedComposable の内部に複数の要素がある場合、それらは互いに重なり合って描画されます(ボックスなど)。複数のコンポーザブルを曲線に沿って配置するには、各コンポーザブルを curvedComposable でラップします。

  • curvedRow と curvedColumn - 行と列と同様に、curvedRowcurvedColumnCurvedLayout 内にネストして、必要に応じて要素をレイアウトできます。curvedRow の場合は、角度レイアウトの方向と半径方向の配置を指定できます。curvedColumn の場合は、角度調整と半径方向を指定できます。

  • CurvedModifier - すべての曲線コンポーネントで、CurvedModifier を使用して作成可能な修飾子パラメータを使用できます。背景、サイズ、重量、パディングがサポートされています。

  • Wear Compose Navigation の以下のコンポーネントも含まれています。

  • SwipeDismissableNavHost - Compose 階層内に、自己完結型ナビゲーションが行われる場所を指定し、スワイプ操作による後方ナビゲーションを可能にします。コンテンツは SwipeToDismissBox 内に表示され、現在のナビゲーション レベルを示します。「スワイプして閉じる」の操作中、前のナビゲーション レベルがあれば、そのレベルがバックグラウンドで表示されます。

  • 配信されたアルファ版について詳しくは、以前のアルファ版のリリースノートをご覧ください。

API の変更

  • CurvedModifier.padding* 関数を追加しました。これらは、曲線コンポーネントの周囲に追加する領域を指定するために使用されます。(I4dbb4
  • CompositionLocal 内部クラスを削除しました(I42490
  • ButtonCompactButtonToggleButton の各アイコンサイズに定数値を追加しました(I57cab
  • AppCardTitleCard に有効化されているパラメータを追加しました。これで、androidx.compose.material カードに類似した API を使用できるようになりました。このパラメータを false に設定した場合、カードはクリックできません。(Idc48db/228869805

バグの修正

  • Stepper では、下限 / 上限に達したときの減少ボタンと増加ボタンが無効化されるようになりました(さらに、ContentAlpha.disabled が iconColor に適用されます)。(I4be9f
  • スワイプ時にテキストのジッターが表示されるを回避するために、グラデーションで描画するときの選択ツール コンテンツの周囲に 1 dp のパディングを追加しました。(I0b7b9
  • PositionIndicator のスクリーンショット テストを追加しました。(I5e8bc
  • AppCardTitleCard のテストを追加しました。(I85391b/228869805

バージョン 1.0.0-alpha21

2022 年 4 月 20 日

androidx.wear.compose:compose-foundation:1.0.0-alpha21androidx.wear.compose:compose-material:1.0.0-alpha21androidx.wear.compose:compose-navigation:1.0.0-alpha21 がリリースされました。バージョン 1.0.0-alpha21 に含まれる commit については、こちらをご覧ください

新機能

  • 曲線要素の背景を指定する新しい曲線修飾子 CurvedModifier.background.radialGradientBackground.angularGradientBackground を追加しました。(I8f392
  • 曲線テキストのオーバーフロー モード(clip / ellipsis / visible)を指定できるようになりました。(I8e7aa
  • Compose の修飾子と同様の CurvedModifier.weight 修飾子を追加しました。これは、carvedRow と CurvedLayout の子(幅の場合)、curvedColumn の子(高さの場合)で使用できます。(I8abbd
  • 曲線要素のサイズを指定する修飾子 CurvedModifier.size.angularSize.radialSize を追加しました。(I623c7

API の変更

  • パラメータの順序を変え、Wear Compose API 全体で一貫して背景が色の前にくるようにしました。(I43208
  • clockwise と insideOut のパラメータを削除し、新しいクラスのよりわかりやすい定数に置き換えました。曲線レイアウト方向が LayoutDirection に対応できるようになり、指定しない場合は継承されます(If0e6a
  • ScalingLazyColumn に関する API の問題を修正するために、autoCenter: BooleanautoCenter: AutoCentringParams に置き換えました。(Ia9c90
  • 色がアイコン / toggleControl スロットに適用されるため、API 全体(Chip / ToggleChip / Dialog / Slider / Stepper / ...)で iconTintColortoggleControlTintColor の名前を iconColortoggleControlColor に変更しました。(Ied238
  • PageIndicatorStyle 列挙型を値クラスに書き換えました(I2dc72
  • レイアウトの前提条件をデベロッパーに示せるように、コンポーザブルの一部のスロットに RowScope/ColumnScope/BoxScope を追加しました。これにより、デベロッパーは一部のスロット コンテンツで追加の修飾子を使用でき、追加のレイアウト要素を提供する必要がなくなります。さらに、timeColorappColor のデフォルト値が contentColor になるように、AppCard / TitleCard の色にマイナー アップデートを加えました。これらのプロパティは、必要に応じてすべて個別にオーバーライドできます。(I26b59
  • SwipeToDismissBoxState.Companion オブジェクトを非公開にしました(I39e84
  • InlineSliderStepper のパラメータの順序を修正しました。API ガイドラインを遵守するための簡単な変更です(I11fec
  • SwipeToDismissBoxState のセーバー オブジェクトは使用されていないため、削除しました。(Ifb54e
  • 最新の UX 仕様に沿うように CompactChip を更新しました。パディングは水平 = 12.dp、垂直 = 0.dp に縮小されました。ラベルのフォントがボタンから caption1 に変更されました。推奨されるアイコンサイズは、アイコンとラベルの両方がある場合は 20x20、アイコンのみのコンパクト チップの場合は 24x24 です。また、アイコンのみのユースケースでは、アイコンが中央揃えになるようにしました。(Iea2be
  • 適用された contentPaddingautoCenteringPadding の量をデベロッパーが把握できるように、ScalingLazyListLayoutInfo にいくつかの新しいフィールドを追加しました。これらは、フリング / スクロールの計算時にデベロッパーにとって便利です(I7577b
  • ダイアログの入出力遷移を実装しました。showDialog パラメータが追加され、ダイアログ自体で可視性を制御できるようになりました(これにより、ダイアログの表示 / 非表示の切り替え時に、ダイアログでイントロとエンディングのアニメーションを実行できます)。ユーザーがスワイプして閉じる操作でダイアログを終了すると、エンディング アニメーションは実行されません。また、最近追加された SwipeToDismissBox のオーバーロードに、状態のデフォルト値を追加しました。(I682a0
  • i18n と a11y のサポートを強化するため、ToggleChipSplitToggleChip を変更し、toggleControl スロットのデフォルト値がなくなるようにしました。また、SwitchIcon()->switchIcon()CheckboxIcon->checkboxIcon()RadioIcon()->radioIcon() のメソッドが Icon ではなく ImageVector を返すように ToggleChipDefaults を変更しました(@Composable を返さなくなったため、小文字で開始するように変更されています)。これにより、デベロッパーは適切な contentDescription セットで独自の Icon() コンポーザブルを作成できます。(I5bb5b
  • SwipeDismissableNavHostState パラメータを SwipeDismissableNavHost に追加しました。これにより、ナビゲーション デスティネーションとして使用される画面で、エッジスワイプを使用できます。これは、SwipeToDismissBoxState をホイスティングして、エッジスワイプを必要とする画面で SwipeDismissableNavHostStateModifier.edgeSwipeToDismiss の両方を初期化するために使用できるようになったためです。(I819f5b/228336555

バグの修正

  • 必要に応じて曲線レイアウトを更新するようにします。(Ie8bfab/229079150
  • https://issuetracker.google.com/issues/226648931 のバグの修正(Ia0a0ab/226648931
  • 不要な試験運用版アノテーションを削除しました(I88d7e

バージョン 1.0.0-alpha20

2022 年 4 月 6 日

androidx.wear.compose:compose-foundation:1.0.0-alpha20androidx.wear.compose:compose-material:1.0.0-alpha20androidx.wear.compose:compose-navigation:1.0.0-alpha20 がリリースされました。バージョン 1.0.0-alpha20 に含まれる commit については、こちらをご覧ください

新機能

  • SwipeToDismissedgeSwipeToDismiss 修飾子を追加します。これにより、ビューポートの左端でのみ swipeToDismiss を有効にできるようになります。マップの 2D スクロールや、ページ間の水平方向のスワイプなど、画面の中央で水平方向のページングを処理する必要がある場合に使用します。(I3fcecb/200699800

API の変更

  • CurvedModifiers の基本実装。これにより、曲線コンテンツをカスタマイズする方法の導入が可能になります(ただし、CurvedModifiers はまだ提供されておらず、後でカスタム修飾子を作成する機能が利用できるようになります)(I9b8df
  • EdgeSwipe 修飾子のドキュメントとデフォルト値が更新され、わかりやすくなりました。(I6d00d
  • PageIndicator スロットを Scaffold に追加します。PageIndicator を Scaffold に直接追加することで、円形のデバイスで正しく表示されるようにします。(Ia6042
  • InlineSlider および Stepper パラメータからデフォルトのアイコンを削除します。これにより、デベロッパーはローカライズとユーザー補助の要件にさらに注意を払うことができるようになります。デフォルトのアイコンの使用方法はデモとサンプルで示されています。(I7e6fd
  • TimeText の先頭と末尾のパラメータ名を Start と End に置き換えました。(Iaac32
  • onDismissed パラメータで SwipeToDismissBox オーバーロードが追加され、スワイプ操作の完了時にナビゲーション イベントをトリガーするという一般的な使用方法がサポートされるようになりました。(I50353b/226565726
  • TimeText の使用方法から ExperimentalWearMaterialApi アノテーションを削除しました(Ide520
  • ScalingLazyList/Column のスコープと情報インターフェースは、外部のデベロッパーによる実装を想定していないため、シール済みとしてマークされています。これにより、バイナリに破壊的変更を加えることなく、今後新しいメンバーを追加できるようになります。(I7d99f
  • 選択ツールに新しい flingBehaviour プロパティと PickerDefaults.flingBehaviour() メソッドが追加され、RSB サポートの追加などのフリング動作の設定が可能になりました。PickerStateScrollableState インターフェースが実装されました。(Ib89c7

バグの修正

  • Wear Compose ライブラリの Android ランタイム(ART)のベースライン プロファイル ルールを更新します。ART では、デバイス上のプロファイル ルールを活用して、アプリの特定の部分を事前にコンパイルし、アプリケーションのパフォーマンスを改善できます。なお、これはデバッグ可能なアプリには影響しません。(Iaa8ef
  • ドキュメントを改善しました(I2c051

バージョン 1.0.0-alpha19

2022 年 3 月 23 日

androidx.wear.compose:compose-foundation:1.0.0-alpha19androidx.wear.compose:compose-material:1.0.0-alpha19androidx.wear.compose:compose-navigation:1.0.0-alpha19 がリリースされました。バージョン 1.0.0-alpha19 に含まれる commit については、こちらをご覧ください。

API の変更

  • CurvedRow の名前を CurvedLayout に変更し、DSL 付きのスコープになるよう再構築しました。この DSL を使用すると、より複雑な曲線レイアウトを一連のネストされた curvedRowcurvedColumn(Row と Column と同等の曲線レイアウト)を使って指定できます。これらのレイアウト要素内では、curvedComposable(@Composable を追加)、basicCurvedText(基盤の曲線テキスト)、curvedText(Wear マテリアル対応の曲線テキスト)の 3 つの要素を使用できます。(Ib776a
  • PositionIndicator の側を構成可能に変更しました。基本の PositionIndicator の位置を End(レイアウト方向対応)、OppositeRsb(画面の回転を考慮し、自身を物理的な RSB の反対に位置付け)、または絶対値である Left と Right に設定できるようになりました。(I2f1f3
  • SwipeToDismissBox の場合に、SwipeDismissTarget.Original の名前を SwipeToDismissValue.Default に変更し、SwipeDismissTarget.Dismissal の名前を SwipeToDismissValue.Dismissed に変更しました。また、SwipeToDismissBoxDefaults.BackgroundKeySwipeToDismissBoxDefaults.ContentKey をそれぞれ SwipeToDismissKeys.BackgroundSwipeToDismissKeys.Content に移動しました。(I47a36
  • 複数の Picker があり、一度に 1 つの Picker のみが編集可能である画面の場合に、Picker に読み取り専用モードを追加しました。Picker が読み取り専用の場合は、現在選択されているオプションと、ラベル(指定されていた場合)が表示されます。(I879de
  • ExperimentalWearMaterialApi のスコープを Modifier.swipeableSwipeableState に制限するよう SwipeToDismissBoxState をリファクタリングし、内部で使用できるようにしました。SwipeToDismissBoxState に、一般的なユースケースをサポートするよう currentValuetargetValueisAnimationRunningsnapTo のメンバーを追加しました。他のプロパティを利用できるようにする必要がある場合は、お知らせください。また、スワイプ オフセットがアンカーの丸め誤差内にある場合の、SwipeableState の動作を修正しました。(I58302

バグの修正

  • ScalingLazyColumn のコンテンツをスクロールできるかどうかを検出するためのコードを簡素化し、修正しました(スクロールバーを表示するかどうかの判断に使用されます)。(I7bce0
  • 複数の状態で使用して状態を切り替える場合の位置インジケーターのバグを修正しました。(I320b5
  • 最新の UX ガイダンスと一致するよう Wear OS 向け Compose のデフォルトのテーマ タイポグラフィ / フォントを更新しました。特に display1(40.sp)と display2(34.s)が以前の値より小さくなり、行の高さと行間隔に対しさまざまなその他のマイナー アップデートを加えました。(Ie3077
  • 閉じるようスワイプしたときのみモーションが発生し、逆方向ではまったく発生しないよう、SwipeToDismissBox に抵抗を追加しました。(Ifdfb9
  • Wear マテリアル デザインの UX ガイドラインと一致するよう、CircularProgressIndicator 関数のデフォルトのパラメータ値の一部を変更しました。Spinner / Indeterminant バージョンでは、size(40 -> 24.dp)、indicatorColor(primary -> onBackground)、trackColor transparency(30% -> 10%)、stroke width(4 -> 3dp)を更新しました。Progress / Determinate バージョンでは、trackColor transparency(30% -> 10%)を更新しました。(I659cc
  • 最新の Wear マテリアル デザインの UX 仕様と一致するよう ScalingLazyColumn のデフォルトのスケーリング パラメータを更新しました。表示上は、この更新により、リストの中心に近いリスト項目からスケーリングが開始されますが、リストの端では以前よりもスケーリングが少なくなります。(Ica8f3
  • アニメーションの終了を改善するために ScalingLazyColumnDefaults.snapFlingBehavior を調整しました。(If3260

バージョン 1.0.0-alpha18

2022 年 3 月 9 日

androidx.wear.compose:compose-foundation:1.0.0-alpha18androidx.wear.compose:compose-material:1.0.0-alpha18androidx.wear.compose:compose-navigation:1.0.0-alpha18 がリリースされました。バージョン 1.0.0-alpha18 に含まれる commit については、こちらをご覧ください

API の変更

  • PositionIndicator にいくつかの改善を加えました。ShowResult を PositionIndicatorVisibility に名称変更しました。不要な再計算を避けるため、パフォーマンスを改善しました(Iaed9d
  • SplitToggleChip の推奨色を変更しました。SplitToggleChip のチェックをオンまたはオフにしたときの背景色を無地一色とし、コンポーネントがチェックされているかどうかを ToggleControl の色で簡単に判別できるようにしました。新しいカラーパターンをサポートするため、新たに ToggleDefaults.splitToggleChipColors() を追加しました。また、splitBackgroundOverlayColor を削除し、toggleChipColors() メソッドを簡素化しました(I7e66e
  • ScalingLazyListItemInfo に unadjustedSize を追加しました。これは、浮動小数点数の精度の点で、スケーリングしたサイズとスケーリング ファクタで元のアイテムサイズを計算するのが安全ではないためです。(I54657b/221079441
  • HorizontalPageIndicator を追加しました。これは、ページの総数と選択されているページを表します。デバイスの形状に応じて直線または曲線にできます。また、インジケーターの形状をカスタマイズして、各インジケーターの視覚的な表示方法を定義できます。(Iac898
  • PickerState を更新し、numberOfOptions を更新できるようにしました。これにより、選択した月によって月の日数が変わる DatePicker などのユースケースに対応できます。これに伴い、PickerState のコンストラクタ パラメータが initialNumberOfOptions に変更されました。(Iad066
  • PositionIndicator がスクロールバーである場合に、スクロールできないときは非表示になるようにしました。(Id0a7f
  • Scaffold との整合性を保つため、全画面の Dialog コンポーネントに PositionIndicatorVignette が表示されるようにしました。また、Column に代わって ScalingLazyColumn を使用することになったため、Dialog コンテンツは ScalingLazyListScope に含めることとなりました(通常、アイテム { /* content */ } で囲む必要があります)。これに伴い、Dialog で verticalArrangement パラメータがサポートされました。(Idea13
  • マテリアル デザインに合わせて ToggleChipSplitToggleChip の toggleIcon プロパティの名前を toggleControl に変更し、API をナビゲーションしやすくしました。(If5921b/220129803
  • Wear のマテリアル テーマ Typology.Caption3 に、新しいエントリ caption3 を追加しました。caption3 は、法的文書のような非常に長い文章に使用する小さなフォントです。(I74b13b/220128356

バグの修正

  • 表示したときに、スナップのアニメーションが停止します。(Idb69d
  • PositionIndicator の変更をアニメーション化しました。(I94cb9
  • UI / UX のフィードバックに基づいて ScalingLazyColumn の autoCentering を変更し、インデックスが ScalingLazyListState.initialCenterItemIndex 以上の複数のアイテムを、ビューポートの中央に完全にスクロールするために必要なスペースのみが提供されるようにしました。これにより、最初に中央に配置したアイテムの周囲に 1 つまたは 2 つのアイテムを配置しても、中央にスクロールされなくなりました。これに伴い、ScalingLazyColumn を autoCentering しても、initialCenterItemIndex/initialCenterItemScrollOffset より上にはスクロールできなくなりました。(I22ee2
  • 日付選択ツールのデモを追加し、選択ツールが表示されるまで initialInitialOptionOption が適用されていなかった PickerState のバグを修正しました。(Id0d7e
  • 円形の画面に幅の広い ScalingLazyColumn アイテムを表示する際のクリッピングを減らすため、水平方向のデフォルトのコンテンツ パディングを 8 dp から 10 dp に増やしました。(I0d609
  • スクロール時に PositionIndicator が表示されることを確認しました。(Ied9a2

バージョン 1.0.0-alpha17

2022 年 2 月 23 日

androidx.wear.compose:compose-foundation:1.0.0-alpha17androidx.wear.compose:compose-material:1.0.0-alpha17androidx.wear.compose:compose-navigation:1.0.0-alpha17 がリリースされました。バージョン 1.0.0-alpha17 に含まれる commit については、こちらをご覧ください

新機能

  • ScalingLazyColumn で使用できるスナップのサポートを追加しました。flingBehavior = ScalingLazyColumnDefaults.flingWithSnapBehavior(state) を設定すると、スナップのサポートが有効になります。(I068d3b/217377069
  • 時刻の形式(24 時間形式または 12 時間形式)を選択する際に使用される選択ツールのデモを追加しました。(Ie5552

API の変更

  • 正方形のデバイスでの TimeText のカスタム フォントとスタイルに関する問題を修正しました(Iea76e
  • ScalingLazyListLayoutInfo に、LazyListLayoutInfo の各プロパティと一致する reverseLayoutviewportSize、orientation プロパティが追加されました(I4f258b/217917020
  • ScalingLazyColumnに、LazyList のプロパティと一致する userScrollEnabled プロパティが追加されました(I164d0b/217912513
  • 選択ツールはデフォルトで上下にグラデーションが表示されるようになりました(Iab92a

バグの修正

  • 親のスペースをすべて埋め尽くすことのないように ScalingLazyColumn を変更しました。代わりに、コンテンツのサイズからサイズを取得します。これは LazyColumn の動作と同じです。以前の動作に戻す場合は、Modifier.fillMaxWidth()/width()/widthIn()ScalingLazyColumn に渡してください(I51bf8
  • ナビゲーションのバックスタックが空の場合にトリガーされる SwipeDismissableNavHost.kt の例外メッセージを改善しました(I1b1dc

バージョン 1.0.0-alpha16

2022 年 2 月 9 日

androidx.wear.compose:compose-foundation:1.0.0-alpha16androidx.wear.compose:compose-material:1.0.0-alpha16androidx.wear.compose:compose-navigation:1.0.0-alpha16 がリリースされました。バージョン 1.0.0-alpha16 に含まれる commit については、こちらをご覧ください

新機能

  • CircularProgressIndicator を追加しました。進行状況インジケーターに、プロセスの長さや不特定の待ち時間が表示されます。全画面で使用する場合、TimeText または他のコンポーネントのギャップ(カットアウト)をサポートします。(Iab8da

API の変更

  • 選択ツールに flingBehavior パラメータが追加されました。デフォルト値では、スクロールまたはフリングを行ったとき、最も近いオプションにスナップします。(I09000
  • InlineSlider と Stepper 用の整数 API を追加しました。(I1b5d6

バグの修正

  • ScalingLazyListState のデフォルトの initialCenterItemIndex を 0 から 1 に変更しました。つまり、状態の構築で ScalingLazyListState.rememberScalingLazyListState(initialCenterItemIndex =) にオーバーライドされない限り、初期化時に 2 番目のリスト項目(index == 1)がビューポートの中央に配置され、1 番目のリスト項目(index == 0)がその前に配置されます。これにより、ほとんどのビューポートがリスト項目で埋まるため、すぐに使えるデフォルトの視覚効果が向上します。(I0c623b/217344252
  • 一部のサイズを縮小している場合でも多くのリスト項目が表示されるように提供されている ScalingLazyColumn のデフォルトの extraPadding を、10% から 5% に減らしました。これにより、ビューポートに表示されない可能性のある余分なリスト項目が作成されなくなります。標準以外の scaleParams が使用されている場合(より極端なスケーリングなど)、デベロッパーは viewportVerticalOffsetResolver を使用して余分なパディングを調整できます。(I76be4
  • 正方形のデバイスで TimeText が複数行にわたる問題を修正しました。(Ibd3fb
  • 親のスペースをすべて埋め尽くすことのないように ScalingLazyColumn を変更しました。代わりに、コンテンツのサイズからサイズを取得します。これは LazyColumn の動作と同じです。以前の動作に戻す場合は、Modifier.fillMaxSize()ScalingLazyColumn に渡してください(注: この変更は不完全であり、次のアルファ版リリースにおける後続の変更で対処される予定です)。(I3cbfa

バージョン 1.0.0-alpha15

2022 年 1 月 26 日

androidx.wear.compose:compose-foundation:1.0.0-alpha15androidx.wear.compose:compose-material:1.0.0-alpha15androidx.wear.compose:compose-navigation:1.0.0-alpha15 がリリースされました。バージョン 1.0.0-alpha15 に含まれる commit については、こちらをご覧ください

API の変更

  • ScalingLazyColumn に新しいプロパティ autoCentering を追加しました。このプロパティが true(デフォルト)の場合、すべての項目(最初と最後の項目を含む)をスクロールして、リストのビューポートの中央に表示できます。なお、自動中央揃えを使用する場合は、垂直方向のコンテンツ パディングを 0.dp に設定することをおすすめします。autoCentering と垂直方向のコンテンツ パディングの両方が指定された場合、両方によって最初のリスト項目の前と最後のリスト項目の後で追加のスペースが利用可能になり、スクロール可能なスペースが増えます。(I2a282b/214922490
  • 他のコンテンツを覆う全画面ダイアログを任意のコンポーザブルがトリガーできるようにする Dialog コンポーネントを追加しました。このダイアログは、表示されると「スワイプして閉じる」機能をサポートし、スワイプ操作中にその親のコンテンツをバックグラウンドで表示します。ダイアログのコンテンツは Alert または Confirmation(以前のコンポーネント AlertDialog および ConfirmationDialog から名前が変更されました)であると想定されます。AlertConfirmationDialog はすべて androidx.wear.compose.material.dialog パッケージ内にあります。Alert と Confirmation はナビゲーション デスティネーションとして使用できます。また、必要に応じて Alert および Confirmation パラメータに ColumnScope を追加しました。(Ia9014
  • Compose for Wear OS のマテリアル テーマ カラーから onSurfaceVariant2 を削除し、ライブラリでの使用を onSurfaceVariant に置き換えました。(Icd592
  • PickerState でオプションをプログラムで選択するメソッドを追加し、最初に選択したオプションを PickerState の作成時にも指定できるようにしました。(I92bdf
  • ScalingLazyColumn のフリング動作をカスタマイズするためのサポートを追加しました。(I1ad2eb/208842968
  • Wear.Compose.Navigation ライブラリに NavController.currentBackStackEntryAsState() を追加しました。(If9028b/212739653
  • 回転するサイドボタンを備えた Wear デバイス用に Modifier.onRotaryScrollEvent()Modifier.onPreRotaryScrollEvent() を追加しました。(I18bf5b/210748686

バージョン 1.0.0-alpha14

2022 年 1 月 12 日

androidx.wear.compose:compose-foundation:1.0.0-alpha14androidx.wear.compose:compose-material:1.0.0-alpha14androidx.wear.compose:compose-navigation:1.0.0-alpha14 がリリースされました。バージョン 1.0.0-alpha14 に含まれる commit については、こちらをご覧ください

新機能

  • デベロッパーが特定のリスト項目へのスクロールを制御し、またリスト項目やオフセットの初期設定を行える、複数のメソッドを ScalingLazyListState に追加しました。

    この変更の一環として、ScalingLazyList が、ビューポートの開始点ではなく中心方向を向くように変更されています。

    中心(ScalingLazyListAnchorType.ItemCenter)または EdgeScalingLazyListAnchorType.ItemStart)をビューポートの中心線に揃えるかどうかを制御する、新しいプロパティ anchorType: ScalingLazyListAnchorType = ScalingLazyListAnchorType.ItemCenterScalingLazyList に追加されました。

    その結果 ScalingLazyListItemInfo.offsetScalingLazyListItemInfo.adjustedOffset が変更され、リスト項目の位置とリストの anchorType の両方に関する項目のオフセットが反映されるようになりました。たとえば、ScalingLazyColumnanchorTypeItemCenter で、リスト項目の中心がビューポートの中心線にある場合、オフセットは 0 になります。

    新しいメソッドは scrollToanimatedScrollTocenterItemIndexcenterItemOffset です。 (I61b61

  • [戻る] ボタンを押すとナビゲーション階層の前のレベルに移動できるように、[戻る] ボタンハンドラを SwipeDismissableNavHost に追加しました。(I5b086b/210205624

バージョン 1.0.0-alpha13

2021 年 12 月 15 日

androidx.wear.compose:compose-foundation:1.0.0-alpha13androidx.wear.compose:compose-material:1.0.0-alpha13androidx.wear.compose:compose-navigation:1.0.0-alpha13 がリリースされました。バージョン 1.0.0-alpha13 に含まれる commit については、こちらをご覧ください

API の変更

  • RangeIcons を内部化しました(InlineSliderStepper によって内部で参照されます)。(I927ec

バグの修正

  • SwipeDismissableNavHostCREATED ライフサイクル状態になる前に Compose 階層にデスティネーションを追加すると IllegalStateException が発生する問題を修正しました。この修正は、navigation-compose の依存関係を 2.4.0-beta02 以降にアップデートするための前提条件でした。(I40a2bb/207328687

  • Wear Compose ライブラリ内のドローアブル リソースを取得するための Drawables 列挙型クラスを追加し、リフレクションが不要になりました。これにより、minifyEnabled=true または shrinkResources=true のときにライブラリ ドローアブルが削除されるバグを修正しました。(Ib2a98

  • Wear Compose の Stepper のテストを追加しました。(I2d03a

  • Wear Compose Navigation の SwipeDismissableNavHost のサンプルを追加しました。(I85f06

バージョン 1.0.0-alpha12

2021 年 12 月 1 日

androidx.wear.compose:compose-foundation:1.0.0-alpha12androidx.wear.compose:compose-material:1.0.0-alpha12androidx.wear.compose:compose-navigation:1.0.0-alpha12 がリリースされました。バージョン 1.0.0-alpha12 に含まれる commit については、こちらをご覧ください。

新機能

  • Stepper コンポーネントが追加され、ユーザーが値の範囲から選択できるようになりました。Stepper はフルスクリーン コントロールです。上に増加ボタン、下に減少ボタンがあり、中央にスロット(チップまたはテキストのいずれかが入ることを想定)があります。ボタンアイコンは、必要に応じてカスタマイズできます。(I625fe

  • ダイアログを表示するための 2 つの新しいコンポーザブルが追加されました。 AlertDialog はユーザーからの応答を待機し、タイトル、アイコン、メッセージとともに a)シンプルな Positive と Negative の選択用の 2 つのボタン、または b)より柔軟な選択に対応するための縦に積み重ねられたチップまたは切り替えチップを表示します。 ConfirmationDialog はタイムアウトとともに確認応答を表示します。このシンプルなダイアログには、タイトル用と(アニメーション)アイコン用のスロットがあります。(Ic2cf8

API の変更

  • ダイアログの候補時間の値に単位(ミリ秒)を追加しました。(I09b48

バージョン 1.0.0-alpha11

2021 年 11 月 17 日

androidx.wear.compose:compose-foundation:1.0.0-alpha11androidx.wear.compose:compose-material:1.0.0-alpha11androidx.wear.compose:compose-navigation:1.0.0-alpha11 がリリースされました。バージョン 1.0.0-alpha11 に含まれる commit については、こちらをご覧ください

新機能

  • スクロール リストからユーザーがアイテムを選択できる選択ツール コンポーネントを追加しました。デフォルトで、選択可能なアイテムのリストは両方向に「無限」に繰り返され、横から見ると回転する円柱のような印象を与えます。今後のリリースで、スワイプやフリングの後の値にスナップする機能と、現在の値に設定 / スクロールする関数を PickerState に追加する機能という 2 つが追加される予定です。(I6461b

API の変更

  • 親コンテナのサイズに基づいてリストアイテムのサイズを設定できるように、ScalingLazyItemScope と新しい修飾子 fillParentMaxSize / fillParentMaxWidth / fillParentMaxHeight を追加しました。アイテムは、親のサイズの全部または一部を埋めるように設定できます。これにより、LazyRow/Column ですでに利用可能な機能が公開されます。(I4612f
  • アイテムがキーを持つことができるように、ScalingLazyColumn のサポートを追加しました。また、配列やリストからアイテムを追加するための便利なメソッドを追加しました。(Ic1f89

バグの修正

  • TimeText のその他の例(I8cb64

バージョン 1.0.0-alpha10

2021 年 11 月 3 日

androidx.wear.compose:compose-foundation:1.0.0-alpha10androidx.wear.compose:compose-material:1.0.0-alpha10androidx.wear.compose:compose-navigation:1.0.0-alpha10 がリリースされました。バージョン 1.0.0-alpha10 に含まれる commit については、こちらをご覧ください。

新機能

  • wear compose の InlineSlider を追加しました。InlineSlider を使用すると、ユーザーは値の範囲から選択できます。選択範囲は、範囲の最小値と最大値の間にバーとして表示され、ユーザーはそこから値を 1 つ選択できます。(If0148

  • WearOS Codelab の新しい Compose をご確認ください。

API の変更

  • Macrobenchmark の minSdkVersion23 になりました。(If2655

バグの修正

  • SideEffect の SwipeDismissableNavHost での遷移処理を更新しました。(I04994b/202863359
  • SwipeDismissableNavHost での遷移処理を更新しました。(I1cbe0b/202863359

バージョン 1.0.0-alpha09

2021 年 10 月 27 日

androidx.wear.compose:compose-foundation:1.0.0-alpha09androidx.wear.compose:compose-material:1.0.0-alpha09androidx.wear.compose:compose-navigation:1.0.0-alpha09 がリリースされました。バージョン 1.0.0-alpha09 に含まれる commit については、こちらをご覧ください

新機能

  • Wear OS で Compose のデベロッパー プレビューをリリースしました。詳しくは、メイン コンポーザブルと、それらの使用を開始するための参考資料へのリンクを確認できるブログ投稿をご覧ください。

API の変更

  • Wear のマテリアル デザイン カラーテーマですべての色をカスタマイズできるデベロッパー向けのサポートを追加しました。(I4759bb/199754668

バグの修正

  • 状態を永続化する SwipeToDismissBox サンプルを追加しました。(Ibaffe
  • CurvedText、TimeText、SwipeToDismissBox の KDocs から、developer.android.com ガイドへのリンクを追加しました。(I399d4
  • 現在のデスティネーションがない(NavGraph が wear.compose.navigation.composable ユーティリティ関数でビルドされていないことを示す)場合、SwipeDismissableNavHost がスローされるようになりました。(I91403
  • TimeText でのタイムソースの使用方法に関するドキュメントと例を追加しました。(I4f6f0

バージョン 1.0.0-alpha08

2021 年 10 月 13 日

androidx.wear.compose:compose-foundation:1.0.0-alpha08androidx.wear.compose:compose-material:1.0.0-alpha08androidx.wear.compose:compose-navigation:1.0.0-alpha08 がリリースされました。バージョン 1.0.0-alpha08 に含まれる commit については、こちらをご覧ください

API の変更

  • AppCard と TitleCard の body プロパティの名前を content に変更し、プロパティ リストの末尾に移動したことで、後置ラムダとして提供できるようなりました。また、新しいスロット名との整合性を保つため、bodyColor の名前を contentColor に変更しました。(I57e78

バグの修正

  • ボタン、カード、チップ、テーマ、位置インジケーター、遅延列コンポーネントのスケーリングについて、KDocs の developer.android.com ガイドへのリンクを追加しました。(I22428
  • WearOS SwipeToDismissBox がスワイプを処理しないことがある問題を修正しました。(I9387e
  • Button、CompactButton、Chip、CompactChip、AppCard、TitleCard、ToggleButton、ToggleChip、SplitToggleChip のサンプルを追加しました(Iddc15
  • Card、Chip、ToggleChip、TimeText、ScalingLazyColumn の Microbenchmark パフォーマンス テストを追加しました。(If2fe9

バージョン 1.0.0-alpha07

2021 年 9 月 29 日

androidx.wear.compose:compose-foundation:1.0.0-alpha07androidx.wear.compose:compose-material:1.0.0-alpha07androidx.wear.compose:compose-navigation:1.0.0-alpha07 がリリースされました。バージョン 1.0.0-alpha07 に含まれる commit については、こちらをご覧ください。

新機能

  • マテリアルに CurvedText コンポーネントを追加しました。これにより、デベロッパーは円の曲率に沿って(通常は円形の画面の端)、曲線テキストを簡単に記述できます。(I19593

API の変更

  • TimeText のテストを追加しました(Idfead
  • ArcPaddingValues をインターフェースに変換します。(Iecd4c
  • SwipeToDismissBox にアニメーションを追加しました(I9ad1b
  • SwipeToDismissBox API に hasBackground パラメータを追加し、表示するバックグラウンド コンテンツがない場合にスワイプ操作を無効にできるようにしました。(I313d8
  • rememberNavController() がオプションの Navigator インスタンスのセットを受け取るようになりました。これらのインスタンスは、返される NavController に追加され、Accompanist Navigation Material の Navigator など、オプションの Navigator のサポートを強化します。(I4619e
  • navigation-common の NamedNavArgument を参照し、wear.compose.navigation からコピーを削除しました。(I43af6

バグの修正

  • 小型デバイスでの CurvedRow のテストの不安定性を修正しました。(If7941
  • コンテンツ更新時の CurvedRow の予想されるちらつきを修正し、曲線行が再測定されるようにしました。(Ie4e06
  • ChipDefaults.gradientBackgroundChipColors() を UX 仕様の変更に合わせて更新しました。グラデーションは、MaterialTheme.colors.surface(アルファ 75%)の背景に、MaterialTheme.colors.primary(アルファ 32.5%)で始まり、MaterialTheme.colors.surface(アルファ 0%)で終了するようになりました。(Id1548
  • 最新の Wear マテリアル デザインの UX 仕様ガイダンスに合わせて、選択された状態の ToggleChip の色を更新しました。選択されると、ToggleChip のグラデーションの背景は、MaterialTheme.color.surface(アルファ 75%)の背景に、左上の MaterialTheme.color.surface(アルファ 0%)で始まり、右下の MaterialTheme.color.primary(アルファ 32%)で終了するようになりました。これにより ToggleChip のオンとオフの違いは、よりわずかになっています。(Idd40b

バージョン 1.0.0-alpha06

2021 年 9 月 15 日

androidx.wear.compose:compose-foundation:1.0.0-alpha06androidx.wear.compose:compose-material:1.0.0-alpha06androidx.wear.compose:compose-navigation:1.0.0-alpha06 がリリースされました。バージョン 1.0.0-alpha06 に含まれる commit については、こちらをご覧ください。

新機能

  • PositionIndicator(スクロールやボリュームなど)の位置、を処理するための構造を提供するトップレベルのアプリ コンポーザブル Scaffold、時刻とアプリケーションのステータスを表示する画面上部の領域を追加し、また画面の上下端をぼかすための周辺減光をサポートしました。Scaffold の主なエリアは、アプリケーション コンテンツを配置する場所です。(I5e0bf
  • Wear Compose 用の TimeText 実装を追加しました(I5654c

Wear Compose Navigation ライブラリ

  • Wear Compose と Androidx Navigation ライブラリを統合した Wear Compose Navigation ライブラリの最初のリリースを追加しました。これにより、アプリ内の宛先として @Composable 関数間を簡単に移動できます。

  • この初回リリースで提供されるものは以下のとおりです。

    • ナビゲーション グラフをホストし、スワイプ操作で戻る方向の移動を行う SwipeDismissableNavHost コンポーザブル
    • ナビゲーション グラフの作成を支援する NavGraphBuilder.composable 拡張機能
    • 状態をホイスティングできるようにする rememberSwipeDismissableNavController()
  • 画面を 2 つ作成し、その画面間を移動する場合の使用例:

    val navController = rememberSwipeDismissableNavController()
    SwipeDismissableNavHost(
        navController = navController,
        startDestination = "start"
    ) {
        composable("start") {
            Column(
                horizontalAlignment = Alignment.CenterHorizontally,
                verticalArrangement = Arrangement.Center,
                modifier = Modifier.fillMaxSize(),
            ) {
                Button(onClick = { navController.navigate("next") }) {
                    Text("Go")
                }
            }
        }
        composable("next") {
            Column(
                horizontalAlignment = Alignment.CenterHorizontally,
                verticalArrangement = Arrangement.Center,
                modifier = Modifier.fillMaxSize(),
            ) {
                Text("Swipe to go back")
            }
        }
    }
    
  • Wear Compose Navigation は個別のライブラリとしてパッケージ化されているため、独自の手巻きナビゲーションを実装するシンプルな WearCompose アプリは、Androidx Navigation ライブラリに依存する必要がありません。

API の変更

  • 背景とコンテンツのキー ID を設定することで rememberSaveable をサポートするように SwipeDismissableNavHost を更新しました。(I746fd
  • LazyListState を処理できる PositionIndicator アダプタを追加しました。(I21b88
  • rememberSaveable をサポートするように SwipeToDismissBox を更新しました。(Ie728b
  • ScalingLazyColumn に reverseLayout のサポートを追加しました。これにより、スクロールとレイアウトの方向を逆にすることができます。(I9e2fc
  • performGestureGestureScope が非推奨になりました。それぞれ performTouchInputTouchInjectionScope に置き換えられました。(Ia5f3fb/190493367
  • VignetteValue の名前を VignettePosition に変更し、VignetteValue.Both の名前を VignettePosition.TopAndBottom に変更しました。(I57ad7
  • 今後 ScalingLazyRow implementation を追加することになった場合に備えて、ScalingLazyColumnState の名前を ScalingLazyListState に、ScalingLazyColumnItemInfo を ScalingLazyListItemInfo に、ScalingLazyColumnLayoutInfo を ScalingLazyListLayoutInfo に、ScalingLazyColumnScope を ScalingLazyListScope に変更しました。(I22734

バグの修正

  • アイコンもラベルも指定されていない場合の影響について説明するように、CompactChip のドキュメントを更新しました。(I4ba88
  • Wear カード コンポーネントに以下の調整を行いました。(I6b3d0
    1. タイトルと本文の間の TitleCard の間隔を 8.dp から 2.dp に減らしました。
    2. TitleCard ヘッダーのフォントを body から title3 に変更しました。
    3. カードの背景のグラデーションを、背景が暗くなるように変更しました。

バージョン 1.0.0-alpha05

2021 年 9 月 1 日

androidx.wear.compose:compose-foundation:1.0.0-alpha05androidx.wear.compose:compose-material:1.0.0-alpha05 がリリースされました。バージョン 1.0.0-alpha05 に含まれる commit については、こちらをご覧ください

API の変更

  • ArcPaddingValues が @Stable としてマークされました(I57deb
  • ScalingLazyColumnState が ScrollableState インターフェースを実装したことで、デベロッパーはプログラムからアクセスしてコンポーネントをスクロールできるようになりました。(I47dbc

バグの修正

  • UX 仕様の更新に合わせて、Icon と Text in Chip と ToggleChip の間隔を縮小しました。(I83802

バージョン 1.0.0-alpha04

2021 年 8 月 18 日

androidx.wear.compose:compose-foundation:1.0.0-alpha04androidx.wear.compose:compose-material:1.0.0-alpha04 がリリースされました。バージョン 1.0.0-alpha04 に含まれる commit については、こちらをご覧ください

新機能

  • SwipeToDismissBox とスワイプ可能修飾子(左から右へスワイプして閉じる操作のサポートに使用可能)を追加しました。これは、Navigation コンポーネントから独立していますが、ある画面を終了して別の画面に移動するために使用することが想定されています。「スワイプして閉じる」のデモを行う統合テストを追加しました。(I7bbaa
  • スケーリングが適用された後に ScalingLazyColumn でのアイテムの実際の位置とサイズをデベロッパーが把握できるように、ScalingLazyColumnItemInfo インターフェースと ScalingLazyColumnLayoutInfo インターフェースを ScalingLazyColumnState クラスに追加しました。また、「上位」コンテンツのパディングが ScalingLazyColumn に適用された場合のスケーリングの計算方法に関するバグも修正しました。(I27c07

API の変更

  • 曲線テキストのスタイル設定の Option を指定するための CurvedTextStyle クラスを追加しました。TextStyle とよく似ていますが、色、fontSize、背景のみをサポートするようになりました。今後、さらに多くのスタイル設定オプションが追加される予定です。(I96ac3
  • スケーリングが適用された後に ScalingLazyColumn でのアイテムの実際の位置とサイズをデベロッパーが把握できるように、ScalingLazyColumnItemInfo インターフェースと ScalingLazyColumnLayoutInfo インターフェースを ScalingLazyColumnState クラスに追加しました。また、「上位」コンテンツのパディングが ScalingLazyColumn に適用された場合のスケーリングの計算方法に関するバグも修正しました。(I27c07
  • SwipeToDismissBox API の一部である SwipeDismissTarget 列挙型に @ExperimentalWearMaterialApi を追加しました。(I48b5e

バグの修正

  • SwipeToDismissBox のテスト資料を追加しました(I9febc

バージョン 1.0.0-alpha03

2021 年 8 月 4 日

androidx.wear.compose:compose-foundation:1.0.0-alpha03androidx.wear.compose:compose-material:1.0.0-alpha03 がリリースされました。バージョン 1.0.0-alpha03 に含まれる commit については、こちらをご覧ください

API の変更

  • CurvedText コンポーネントを追加しました。これにより、デベロッパーは円の湾曲(通常は円形画面の端にある)に沿ってテキストを簡単に入力できます(Id1267
  • 背景画像にスクリムが描画されていることがはっきりとわかるよう、CardDefaults.imageBackgroundPainter() の名前を CardDefaults.imageWithScrimBackgroundPainter() に変更しました。(I53206
  • Wear マテリアルのリスト コンポーネントを提供する ScalingLazyColumn コンポーネントを追加しました。これにより、コンポーネントの端に向かってスケーリングするとリスト コンテンツがサイズ縮小され透明になる魚眼ビューが提供されます。(I7070c

バグの修正

  • UX 仕様の更新に応じて、AppCard の appName コンテンツのデフォルト色が変更されました。appName のデフォルト色は MaterialTheme.colors.onSurfaceVariant になりました。また、タイトル スロットに欠落しているパラメータのドキュメントの説明を追加しました。(Ic4ad1

バージョン 1.0.0-alpha02

2021 年 7 月 21 日

androidx.wear.compose:compose-foundation:1.0.0-alpha02androidx.wear.compose:compose-material:1.0.0-alpha02 がリリースされました。バージョン 1.0.0-alpha02 に含まれる commit については、こちらをご覧ください

新機能

  • 円弧の中にコンポーザブルをレイアウトする新しいクラス CurvedRow を追加しました。(I29941
  • アプリ内で使用する新しいタイプのカード(TitleCard)を追加し、コンテンツを強調するために背景としてカードに追加できる画像の設定のサポートも追加しました。(I53b0f

API の変更

  • CurvedRow に放射状整列(行の垂直方向の整列と似た機能)のサポートを追加しました。(Id9de5
  • 円弧の中にコンポーザブルをレイアウトする新しいクラス CurvedRow を追加しました。(I29941
  • アプリ内で使用する新しいタイプのカード(TitleCard)を追加し、コンテンツを強調するために背景としてカードに追加できる画像の設定のサポートも追加しました。(I53b0f
  • デベロッパーが ToggleChip と SplitToggleChip を簡単に構成できるようにするため、ToggleChipDefaults に切り替えアイコン(チェックボックス、スイッチ、ラジオボタン)を追加しました。(I7b639
  • チップの開始および終了コンテンツ パディングが更新され、チップにアイコンが存在するかどうかにかかわらず、常に 14.dp になりました(以前はアイコンが存在する場合は 12.dp、アイコンが存在しない場合は 14.dp でした)。(I34c86

バグの修正

  • CurvedRow のテストを追加しました。(I93cdb
  • Wear Compose の依存関係を Compose 1.0.0-rc01 に関連付けました。(Ie6bc9
  • カードとチップにおける背景画像のペイントの処理を変更し、画像の比率を維持するために画像が引き伸ばされるのではなく切り抜かれるようにしました。(I29b41
  • Button と ToggleButton のデモと統合テストを追加しました。(5e27ed2
  • imageBackgroundChip のコンテンツの色をカバーするため、チップのテストを追加しました。(Ia9183

バージョン 1.0.0-alpha01

2021 年 7 月 1 日

androidx.wear.compose:compose-foundation:1.0.0-alpha01androidx.wear.compose:compose-material:1.0.0-alpha01 がリリースされました。バージョン 1.0.0-alpha01 に含まれる commit については、こちらをご覧ください

新機能

Wear Compose は、Wear OS ウェアラブル用にマテリアル デザインを拡張した Wear マテリアル デザインをサポートする、Compose ベースの Kotlin ライブラリです。この最初のアルファ版リリースには、次のものを備えた初期段階の機能実装が含まれています。

  • マテリアル テーマ - このライブラリから使用されるコンポーネント全体の色、タイポグラフィ、図形を構成します。
  • Chip、CompactChip - チップは楕円形をしており、アイコン、ラベル、セカンダリ ラベルのコンテンツを取得するためのバリエーションがあります。
  • ToggleChip、SplitToggleChip - ラジオボタンやチェックボックスなど、2 つの状態を切り替えるアイコンのスロットを含む特別なタイプのチップです。また、SplitToggleChip には 2 つ(クリック可能と切り替え可能)のタップ可能な領域があります。
  • Button、CompactButton - ボタンは円形をしており、アイコン用の単一のコンテンツ スロットか、最小限のテキスト(最大 3 文字)を備えています。
  • ToggleButton - アクションのオン / オフを切り替えるボタンで、アイコン用の単一のスロットか、最小限のテキスト(最大 3 文字)を備えています。
  • Card、AppCard - 角が丸い四角形をしており、アプリアイコン、時間、タイトル、本文などのコンテンツのスロットを提供します。

将来のリリースでは、ウィジェット セットが拡張され、Wear マテリアル デザイン選択ツール、スライダー、リスト、ページ インジケーター、ダイアログ、スクロール RSB インジケーター、トーストなどのサポートが追加される予定です。

さらに、その他のウェアラブル固有の機能(曲線レイアウトやテキストなど)のサポートと、デベロッパーがウェアラブル アプリ / オーバーレイを簡単に構築するための土台が提供されます。

Wear Compose マテリアルは、ウェアラブルをターゲットにしているとはいえ、Compose マテリアルと同じ原則に沿ってデザインされています。ウェアラブル デバイス用の開発では、Compose マテリアル ライブラリの代わりに、Wear Compose マテリアル ライブラリを使用してください。

この 2 つの「マテリアル」ライブラリは相互排他的であると見なす必要があり、同じアプリ内に混在させてはなりません。Compose マテリアル ライブラリを依存関係に含めてしまうのは、a)Wear Compose マテリアル ライブラリにコンポーネントが不足している場合、または b)Google がウェアラブル デバイスでの使用を推奨していないコンポーネントをアプリで使用している場合のどちらかです。a)に該当する場合は、必要なコンポーネントを Google にお知らせください。