Jetpack Compose for XR
| 最新の更新 | 安定版リリース | リリース候補版 | ベータ版リリース | アルファ版リリース |
|---|---|---|---|---|
| 2025 年 10 月 22 日 | - | - | - | 1.0.0-alpha08 |
依存関係の宣言
XR Compose への依存関係を追加するには、Google の Maven リポジトリをプロジェクトに追加する必要があります。詳しくは、Google の Maven リポジトリをご覧ください。
アプリまたはモジュールの build.gradle ファイルに、必要なアーティファクトの依存関係を追加します。
Groovy
dependencies { implementation "androidx.xr.compose:compose:1.0.0-alpha08" // Use to write unit tests testImplementation "androidx.xr.compose:compose-testing:1.0.0-alpha08" }
Kotlin
dependencies { implementation("androidx.xr.compose:compose:1.0.0-alpha08") // Use to write unit tests testImplementation("androidx.xr.compose:compose-testing:1.0.0-alpha08") }
依存関係について詳しくは、ビルド依存関係の追加をご覧ください。
フィードバック
お寄せいただいたフィードバックは Jetpack 改善の参考にさせていただきます。新しい問題が見つかった場合や、このライブラリを改善するアイデアをお持ちの場合は、お知らせください。新しい問題を報告していただく前に、このライブラリの既存の問題をご確認ください。スターボタンをクリックすると、既存の問題に投票できます。
詳細については、Issue Tracker のドキュメントをご覧ください。
バージョン 1.0
バージョン 1.0.0-alpha08
2025 年 10 月 22 日
androidx.xr.compose:compose:1.0.0-alpha08 と androidx.xr.compose:compose-testing:1.0.0-alpha08 がリリースされました。バージョン 1.0.0-alpha08 にはこれらの commit が含まれています。
API の変更
ResizePolicyを変更して、onResizeStart、onResizeUpdate、onResizeEndを受け入れるようにしました。(I7e21f)
バグの修正
- Subspace を含む Activity を破棄する際のクラッシュを防止(I595a1)
バージョン 1.0.0-alpha07
2025 年 9 月 24 日
androidx.xr.compose:compose:1.0.0-alpha07 と androidx.xr.compose:compose-testing:1.0.0-alpha07 がリリースされました。バージョン 1.0.0-alpha07 にはこれらの commit が含まれています。
API の変更
SpatialMainPanelの KDocs を改善しました。(I27b70、b/444467891)SpatialRowやSpatialColumnなどの 3D レイアウトで、主軸に沿って子を配置するためのSpatialArrangementを導入しました。この新しい API は、Start、End、Center、SpaceBetween、SpaceAround、SpaceEvenlyなど、2D Compose の使い慣れた配置オプションを提供し、LTR と RTL の両方のレイアウト方向を完全にサポートします。(I7db38、b/436289959)SubspaceModifier.Nodeの基本インターフェースを追加し、拡張インターフェースの型安全性とユーザビリティを改善しました。たとえば、CompositionLocalConsumerSubspaceModifierNodeLayoutCoordinatesAwareModifierNodeSubspaceLayoutModifierNodeCoreEntityNode(内部)(Iede00、b/440599394、b/440599394)
SpatialExternalSurfaceの制限を解除(I33315、b/439646773)- Subspace コンポーザブルに
SubspaceModifierを導入し、制約パラメータをSubspaceModifierからサイズ関連のSubspaceModifiersに置き換えました。allowUnboundedSubspaceが true の場合でも、サブスペースに無制限の制約を設定できます。(Ib06e6、b/433331675) DragPolicy()とResizePolicy()がSpatialPanelとSpatialExternalSurfaceAPI の一部になったため、移動可能でサイズ変更可能なSubspaceModifiersを非推奨にしました(I397bf、b/437924639)- 空間レイアウトで
LayoutDirectionのサポートを追加しました。SpatialAlignmentを使用するコンポーザブルで、LTR コンテキストと RTL コンテキストの両方で要素が正しく配置されるようになりました。(I964bb、b/436300273) - これらの動作がサポートされているコンテナにのみ適用されるように、
PanelAPI に Resizable パラメータと Movable パラメータを追加します。(Id491c) - 幅、高さ、奥行きの正確な最小値と最大値の制約を設定できる
sizeIn、widthIn、heightIn、depthIn、SubspaceModifiersを追加しました。(I1af09、b/433330761)
バージョン 1.0.0-alpha06
2025 年 8 月 13 日
androidx.xr.compose:compose:1.0.0-alpha06 と androidx.xr.compose:compose-testing:1.0.0-alpha06 がリリースされました。バージョン 1.0.0-alpha06 にはこれらの commit が含まれています。
バグの修正
- ライフサイクル オーナーが破棄されたときに
ComposeXrOwnerLocalsを再作成します。(9123ce1)
バージョン 1.0.0-alpha05
2025 年 7 月 30 日
androidx.xr.compose:compose:1.0.0-alpha05 と androidx.xr.compose:compose-testing:1.0.0-alpha05 がリリースされました。バージョン 1.0.0-alpha05 には、これらの commit が含まれています。
新機能
SubspaceComposableアノテーション クラスを公開にしました。(Ic2a34、b/399432430)- 180 度と 360 度の球体を表す 2 つの新しい
SpatialExternalSurfaceコンポーザブル。(I40ef2、b/391705799) SubspaceModifier.aspectRatioを追加しました(Ide5ab、b/399729509、b/414762147)SceneCoreと XR 用 Compose の相互運用性を改善するためにSceneCoreEntityAPI を追加しました。(I50bb3、b/423020989)- スケーリングされていない
GravityAligned機能をサポートするGravityAlignedsubspaceAPI を提供しました(I07359)
API の変更
SpatialDialog()はSpatialDialogProperties.dismissOnBackの押下設定に従います。(Ib453b、b/416797132)- メートル単位で表されるため、
minimumPanelDimensionを新しいデフォルトのディメンション サイズDimensions(0.1f, 0.1f, 0.1f)に更新します。(Ib852a) - サブスペースとオービターは、ホームスペースとアプリがバックグラウンドにあるときに内部状態を保持するようになります。ホームスペース モードでは、Subspace はフルスペース モードへの切り替えに備えてシーンをセットアップします。(I40317、b/416037751)
- アプリがバックグラウンドで動作しているとき、
SpatialDialogsは状態を保持するようになりました。(I6aa56) ApplicationSubspaceは、推奨されるスケールと位置をシステムから継承するようになりました。(I4565f、b/418834194)SubspaceComposable以外のコンテキストでSubspaceComposableが使用された場合のエラー メッセージを改善し、エラーを早期にトリガーするようにしました。(Iee2ae、b/416484684)- 構成可能な API を誤って使用した場合、警告が見落とされることが多いため、
ExperimentalSubspaceVolumeApiを Warning から Error に更新しました。(I427aa、b/424864286) - サブスペースと
ApplicationSubspaceはrecommendedContentBoxInFullSpaceによって制約されるようになりました。以前はSpatialUserの視野によって制約されていました。(I41015、b/423074142) SpatialElevationを更新し、最小サイズを使用することで、ハードコードされたサイズを使用しないようにしました(I2dbe6、b/427785338)- キー変数が変更されたときに更新されるように、
SpatialAcitivityPanelをスクリムする方法を更新します。(I0f64d、b/427999029) - デフォルトの制約値を同等の値に設定するために、
VolumeConstraints.Unboundedを削除します。(Ie24ec、b/407938414) SpatialFeatheringSizeが公開されなくなりました(I1c15b、b/399432430)- Compose の
Placeableと区別するために、XR のPlaceableの名前をSubspacePlaceableに変更しました。(I74874) - Orbiter の設定を削除し、新しいパラメータとして
shouldRenderInNonSpatialを追加します。また、クラスEdgeOffsetを削除し、Orbiter()関数を統合するための新しいパラメータとしてorbiterOffsetTypeを追加します。また、OrbiterEdgeの名前をContentEdgeに変更します。(Iebf3d) - Compose の
Measurable型と区別するため、Measurableの名前をSubspaceMeasurableに変更しました。(I9726c) MeasureResultの名前をSubspaceMeasureResultに変更しました。(I9f34d)- Compose の
SubspaceコンポーザブルでsetContentを使用するように変更し、setSubspaceContentAPI を削除しました。(Ifff4c、b/421427391、b/421427391) MeasurePolicyの名前がSubspaceMeasurePolicyに変更されました。(I37a9b、b/422553904)- デフォルトなしではメンバーを追加できないため、
SubspaceSemanticsInfoをシール済みインターフェースにします。(I372f9、b/423704068) SpatialExternalSurfaceのドキュメントを更新し、ContentSecurityLevelの名前をSurfaceProtectionに変更しました(I3c460、b/420982808)- アンカー設定を可能にする、移動可能な修飾子のオーバーロードされたコンストラクタを提供しました。(Ic0c70)
- ツールチップの位置プロバイダを追加しました。これにより、デベロッパーはツールチップをアンカーの上、下、左、右のいずれに配置するかを制御できるようになりました。カレットの Shape を受け取る API を追加し、より多くのカスタムシェイプを提供できるようにしました。(Ie513c、b/374766087、b/418854637)
PublishedApiとしてのCoreEntityを削除しました(Ifee05)
バグの修正
- レンダリング時に
SpatialDialogが点滅する問題を修正しました。(Ife73c、b/401619909) SpatialDialogがアクティビティ パネルをスクリムできない問題を修正しました。(I8ca6c、 b/367442109)- XR ダイアログで一部のコンテンツが表示されない問題を修正しました(I17cd5、b/418062437)
- コンテンツの内部をクリックすると
SpatialPopupが閉じられる問題を修正しました。(If262c、b/417245722) resizable().movable()をチェーンすると SpatialPanel が新しいサイズに正しくリサイズされない問題を修正しました。(I02ee3、b/422264230)SpatialComposeVideoPlayerでtopBarがメニューと重なる問題を修正しました(Id33bc、b/427168167)- 角の丸みがレンダリングされない問題を修正しました(I975fe、b/428261830)
バージョン 1.0.0-alpha04
2025 年 5 月 7 日
androidx.xr.compose:compose:1.0.0-alpha04 と androidx.xr.compose:compose-testing:1.0.0-alpha04 がリリースされました。バージョン 1.0.0-alpha04 にはこれらの commit が含まれています。
新機能
- カスタム
SubspaceModifierタイプがコンポジション ローカル値にアクセスできるようにするCompositionLocalConsumerSubspaceModifierNodeインターフェースを追加しました。 - Compose の
AndroidView実装スタイルに準拠した新しいSpatialPanelAPI を追加し、以前のViewBased SpatialPanelを非推奨にしました。 - 制約なしを表す
VolumeConstraints.Unboundedコンパニオン オブジェクトを追加しました。 - 空間化された音源を許可する
SubspaceModifier.onPointSourceParamsを追加しました。 - 公開
ApplicationSubspaceが追加されました。これにより、アプリが空間コンテンツをレンダリングできる 3D 領域を定義するオプションのVolumeConstraintsが提供されます。デフォルトでは、制約が指定されていない場合、サブスペースはSpatialUserの現在の視野の幅と高さで制限されます。視野を特定できない場合に使用する制約を指定できます。それ以外の場合は、デフォルトの視野の幅と高さの値が使用されます。 - 立体視コンテンツのレンダリングに使用できる
SpatialExternalSurfaceを追加しました。SpatialExternalSurfaceは、修飾子(アルファを除く)とエッジのフェザリング効果でカスタマイズできます。 - ユーザーが空間ポインタのアイコンを設定できる新しい
pointerHoverIconサブスペース修飾子を追加しました。
API の変更
- すべての Jetpack XR パッケージの
RequiresApi(34)制限を削除しました。Jetpack XR は現在 API レベル 34 以上のデバイスでのみ利用できるため、この制限は冗長でした。(Iae0f8) - Kotlin 2.0 でリリースされたプロジェクトを使用するには、KGP 2.0.0 以降が必要です。(Idb6b5)
- 埋め込みアクティビティのない空間パネルで、戻るボタンの処理が機能するようになりました。戻る操作を機能させるには、Android マニフェストで
android:enableOnBackInvokedCallback="true"を指定する必要があります。 - バックハンドルが空間ダイアログで動作するようになりました。バック ハンドリングを機能させるには、Android マニフェストで
android:enableOnBackInvokedCallback="true"を指定する必要があります。 - Compose ベースと View ベースの
SpatialPanelは、コンテンツに基づいてサイズを調整できるようになりました。 - デベロッパーは、独自のカスタム
SpatialElevationLevel値を設定できるようになり、事前定義されたレベルに制限されなくなりました。 elevationパラメータを使用して、オービターの高度レベルをカスタマイズできるようになりました。- サブスペースは、デフォルトで
SpatialUserの視野の幅と高さで制限できるようになりました。視野を特定できない場合は、デフォルトの視野の幅と高さの値が使用されます。 Movable修飾子に新しいコールバックonMoveStartとonMoveEndを追加しました。onMoveStartコールバックとonMoveEndコールバックは、ユーザーが移動可能な修飾子を使用してサブスペース コンポーザブルの移動を開始および終了したときに呼び出されます。SpatialRowやSpatialPanelなどの空間 API からnameパラメータが削除されました。空間コンポーズ ツリーのデバッグには、代わりにSubspaceModifier.testTagを使用します。spatialElevationLevelとcontentのみを持つSpatialPopupのサポートされていないオーバーロードを削除しました。onDimissRequestをサポートするインターフェースを使用してください。- Movable 修飾子の
onPoseChangeコールバックが削除されました。代わりにonMoveを使用してください SubspaceModifiersは、デタッチされている場合やデタッチ中の場合は効果が適用されなくなります。- 既存の
SpatialRowAPI がSpatialRowとSpatialCurvedRowに分割されました。以前にSpatialRowのcurveRadiusパラメータを使用していた場合は、同じ動作を提供するSpatialCurvedRowを使用してください。 - 同様に新しいシステム イメージで実行した場合、
MainPanelとActivityPanelにタイトルバーが表示されなくなりました。 - アルファとスケールの修飾子がスタック可能になり、最終的に適用されるアルファ値またはスケール値の値を乗算するようになります。
- Movable 修飾子の
onPoseChangeコールバックが、ポーズの動きをよりスムーズに行えるように最適化されました。 - 移動可能およびサイズ変更可能な修飾子は、状態の変更が再コンポジションをトリガーするように、メインスレッドでコールバックを実行するようになりました。
- レイアウト フェーズと測定フェーズに状態の監視を追加し、
SubspaceLayoutの状態の変化が再レイアウトをトリガーするようにしました。 - 既存の修飾子をより適切に再利用できるように、最適化された修飾子チェーンの更新。
バグの修正
SpatialDialogが表示されたときにスクリムを停止しました。(Ic4594)- 修飾子ノードが切り離されている間に行われたレイアウトの再リクエストが無視されるようになりました。
- Movable 修飾子と Resizable 修飾子によってトリガーされるレイアウト再計算フェーズを削除しました。
MainPanel()コンポーザブルで、直接またはレイアウト計算(SpatialRow/SpatialColumn計算など)中にいずれかのディメンションがゼロに設定された場合に発生するクラッシュを修正しました。代わりに、パネルが非表示になります。この修正はレイアウト フェーズでのクラッシュに特に対処するものであり、ユーザー操作によるパネルのサイズ変更は別途処理されます。非表示のパネルに UI アフォーダンスがありません。- サイズ変更可能な修飾子からの
maintainAspectRatioに関する問題を修正しました。アスペクト比が維持されるようになりました。 - ネストされたサブスペースが 1 つのフレームで誤った位置に配置される問題を修正しました。
- 角丸が適用されるべきときに適用されないことがある問題を修正しました。
NestedSubspacesが 1 フレームだけ間違った場所に表示されることがなくなります。
バージョン 1.0.0-alpha03
2025 年 2 月 26 日
androidx.xr.compose:compose:1.0.0-alpha03 と androidx.xr.compose:compose-testing:1.0.0-alpha03 がリリースされました。前回のアルファ版からの重要な変更はありません。バージョン 1.0.0-alpha03 にはこれらの commit が含まれています
バージョン 1.0.0-alpha02
2025 年 2 月 12 日
androidx.xr.compose:compose:1.0.0-alpha02 と androidx.xr.compose:compose-testing:1.0.0-alpha02 がリリースされました。バージョン 1.0.0-alpha02 にはこれらの commit が含まれています。
新機能
- 空間ダイアログがアクティブなときに、アクティビティ パネルのコンテンツをスクリムできるようになりました。
OrbiterAPI がSubspaceComposableコンテキストで使用できるようになり、オービターが最も近いSubspaceLayoutベースのコンポーザブルな親にアタッチされるようになります。- カスタムの配置ベースの修飾子を許可する
LayoutCoordinatesAwareModifierNodeを導入しました。 - アタッチ/デタッチ ライフサイクル メソッドを
SubspaceModifier.Nodeに追加しました。 - 移動可能な修飾子に
scaleWithDistanceを追加しました。scaleWithDistanceが有効になっている場合、移動されたサブスペース要素は拡大または縮小します。また、移動前に設定されていた明示的なスケールも維持されます。
API の変更
SessionCallbackProviderを削除し、SpatialCapabilitiesに置き換えました。
その他の変更
minSDKを 24 に削減しました。すべての Jetpack XR API は、実行時に引き続き API 34 を必要とします。OrbiterEdgeOffset.inner、EdgeOffset.outer、EdgeOffset.overlapのコンストラクタが@Composableメソッドではなくなり、コンポーザブルでないコンテキストで使用できるようになりました。- 最新の UX 仕様に沿うように空間の高度レベルを更新しました。
SubspaceSemanticsInfoインターフェースをMeasurableLayoutに実装します。SubspaceModifierElementの名前をSubspaceModifierNodeElementに変更しました。
バグの修正
SubspaceModifierの順序を安定させるための修正。SubspaceModifierの動作がより信頼性の高いものになります。オフセット、回転、拡大縮小、移動可能、サイズ変更可能の修飾子は、任意の順序で使用できるようになりました。
バージョン 1.0.0-alpha01
2024 年 12 月 12 日
androidx.xr.compose:compose-*1.0.0-alpha01 がリリースされました。
初回リリースの機能
Jetpack Compose for XR のデベロッパー向け初回リリース。既存の 2D アプリを XR に移植する場合でも、XR アプリをゼロから作成する場合でも、行や列などの使い慣れた Compose のコンセプトを使用して、XR で空間 UI レイアウトを作成できます。このライブラリは、サブスペースと空間コンポーザブル(空間パネルやオービターなど)を提供します。これにより、既存の 2D Compose または Views ベースの UI を空間レイアウトに配置できます。Volume サブスペース コンポーザブルが導入され、UI を基準にして 3D モデルなどの SceneCore エンティティを配置できるようになりました。詳しくは、デベロッパー ガイドをご覧ください。
Subspace: このコンポーザブルはアプリの UI 階層内の任意の場所に配置できるため、ファイル間のコンテキストを失うことなく、2D UI と空間 UI のレイアウトを維持できます。これにより、UI ツリー全体で状態をホイストしたり、アプリを再構築したりすることなく、既存のアプリ アーキテクチャなどのものを XR と他のフォーム ファクタ間で簡単に共有できます。SpatialPanel: スペース パネルは、アプリのコンテンツを表示できるサブスペース コンポーザブルです。たとえば、動画の再生、静止画、その他のコンテンツをスペース パネルに表示できます。
オービター: オービターは空間 UI コンポーネントです。対応する空間パネルに接続するように設計されており、その空間パネルに関連するナビゲーションとコンテキスト アクション アイテムが含まれています。たとえば、動画コンテンツを表示する空間パネルを作成した場合、オービター内に動画再生コントロールを追加できます。
Volume: UI を基準にして 3D モデルなどの SceneCore エンティティを配置します。
空間レイアウト:
SpatialRow、SpatialColumn、SpatialBox、SpatialLayoutSpacerを使用して、複数の空間パネルを作成し、空間レイアウト内に配置できます。SubspaceModifierを使用してレイアウトをカスタマイズします。空間 UI コンポーネント: これらの要素は 2D UI で再利用できます。空間属性は、空間機能が有効になっている場合にのみ表示されます。
SpatialDialog: パネルが z 軸方向に少し奥に移動し、ダイアログが浮き上がって表示されます。SpatialPopUp: パネルが z 軸方向に少し奥に移動し、ポップアップが浮き上がって表示されるSpatialElevation:SpatialElevationLevelを設定して標高を追加できます。
SpatialCapabilities: 空間機能は、ユーザーがアプリやシステムを操作するにつれて変化する可能性があります。また、アプリ自体によって変更されることもあります(ホーム スペースやフル スペースに移動するなど)。問題を回避するには、アプリで
LocalSpatialCapabilities.currentをチェックして、現在の環境でサポートされている API を特定する必要があります。isSpatialUiEnabled: 空間 UI 要素(SpatialPanel など)isContent3dEnabled: 3D オブジェクトisAppEnvironmentEnabled: 環境isPassthroughControlEnabled: アプリケーションがパススルー状態を制御できるかどうかisSpatialAudioEnabled: 空間オーディオ
既知の問題
- 現在、XR に Jetpack Compose を使用するには、minSDK が 30 である必要があります。回避策として、minSDK が 23 の状態でビルドして実行できるように、次のマニフェスト エントリ
<uses-sdk tools:overrideLibrary="androidx.xr.scenecore, androidx.xr.compose"/>を追加できます。 - Jetpack XR アプリでは現在、AndroidManifest で
android.permission.SCENE_UNDERSTANDING権限をリクエストする必要があります。 - マニフェストの
PROPERTY_XR_ACTIVITY_START_MODEプロパティを使用してアプリがフルスペースに直接起動される場合、アクティビティ/アプリケーションは最初にホームスペースで開かれ、その後フルスペースに移行します。 - Volume コンポーザブルの glTF が、最初は間違った場所でちらつくことがあります。
- 大きく移動したパネルで SpatialDialog を使用すると、コンテンツが誤った方向に移動します。