本日、Jetpack Compose 2025 年 12 月リリースが安定版になりました。これには、コア Compose モジュールのバージョン 1.10 と Material 3 のバージョン 1.4(BOM マッピングの全一覧を参照)が含まれており、新機能と大幅なパフォーマンスの改善が追加されています。
本日のリリースを使用するには、Compose BOM のバージョンを 2025.12.00 にアップグレードしてください。
implementation(platform("androidx.compose:compose-bom:2025.12.00"))
パフォーマンスの改善
アプリのランタイム パフォーマンスがデベロッパーとユーザーにとって非常に重要であることを Google は認識しているため、Compose チームはパフォーマンスを最優先事項として取り組んできました。このリリースでは、さまざまな改善が加えられています。最新バージョンにアップグレードするだけで、これらの改善をすべて利用できます。Google の内部スクロール ベンチマークによると、Compose のパフォーマンスは Views を使用した場合と同程度になりました。
スクロール パフォーマンスのベンチマーク(Views と Jetpack Compose を Compose のさまざまなバージョンで比較)
Lazy プリフェッチでの一時停止可能なコンポジション
Lazy プリフェッチでの一時停止可能なコンポジションがデフォルトで有効になりました。これは、Compose ランタイムがワークをスケジュールする方法の根本的な変更であり、UI ワークロードの負荷が高い場合のジャンクを大幅に削減するように設計されています。
以前は、コンポジションが開始されると、完了まで実行する必要がありました。コンポジションが複雑な場合、メインスレッドが 1 フレームよりも長くブロックされ、UI がフリーズすることがありました。一時停止可能なコンポジションを使用すると、ランタイムは時間が足りなくなった場合にワークを「一時停止」し、次のフレームでワークを再開できます。これは、Lazy レイアウト プリフェッチと組み合わせてフレームを事前に準備する場合に特に効果的です。Compose 1.9 で導入された Lazy レイアウト CacheWindow API は、より多くのコンテンツをプリフェッチし、一時停止可能なコンポジションを活用して、UI パフォーマンスを大幅にスムーズにする優れた方法です。
一時停止可能なコンポジションと Lazy プリフェッチを組み合わせることで、ジャンクを削減できます
また、Modifier.onPlaced、Modifier.onVisibilityChanged、その他の修飾子の実装を改善し、他の部分のパフォーマンスも最適化しました。Google は引き続き Compose のパフォーマンスの改善に投資していきます。
新機能
保持
Compose には、さまざまなライフサイクルで状態を保持して管理するための API がいくつか用意されています。たとえば、remember はコンポジション間で状態を保持し、rememberSavable/rememberSerializable はアクティビティまたはプロセスの再作成間で状態を保持します。retain は、これらの API の間に位置する新しい API であり、シリアル化せずに構成変更間で値を保持できますが、プロセスの終了後は保持できません。retain は状態をシリアル化しないため、簡単にシリアル化できないラムダ式、フロー、ビットマップなどの大きなオブジェクトを保持できます。たとえば、retain を使用してメディア プレーヤー(ExoPlayer など)を管理し、構成変更によってメディアの再生が中断されないようにすることができます。
@Composable
fun MediaPlayer() {
val applicationContext = LocalContext.current.applicationContext
val exoPlayer = retain { ExoPlayer.Builder(applicationContext).apply { ... }.build() }
...
}
この機能の設計に影響を与え、貢献してくださった AndroidDev コミュニティ(特に Circuit チーム)に感謝いたします。
Material 1.4
material3 ライブラリのバージョン 1.4.0 では、多くの新しいコンポーネントと機能強化が追加されています。
-
TextFieldに、TextFieldStateベースの試験運用版が追加されました。これにより、テキストの状態をより堅牢に管理できます。また、新しいSecureTextFieldバリアントとOutlinedSecureTextFieldバリアントが提供されるようになりました。マテリアルのTextコンポーザブルで autoSize 動作がサポートされるようになりました。 -
カルーセル コンポーネントに、新しい
HorizontalCenteredHeroCarouselバリアントが追加されました。 -
TimePickerで、ピッカーモードと入力モードの切り替えがサポートされるようになりました。 - 縦方向のドラッグハンドルを使用すると、アダプティブ ペインのサイズや位置を変更できます。
横方向の中央に配置されたヒーロー カルーセル
Material 3 Expressive API は、material3 ライブラリのアルファ版で引き続き開発されています。詳細については、こちらの最近の講演をご覧ください。
新しいアニメーション機能
共有要素アニメーションのカスタマイズの更新など、アニメーション API の拡張を続けています。
動的な共有要素
デフォルトでは、sharedElement() アニメーションと sharedBounds() アニメーションは、
ターゲット状態に一致するキーが見つかったときにレイアウトの変更をアニメーション化しようとします。ただし、ナビゲーションの方向や現在の UI 状態など、特定の条件に基づいてこのアニメーションを動的に無効にしたい場合があります。
共有要素の遷移が発生するかどうかを制御するために、rememberSharedContentState() に渡される SharedContentConfig をカスタマイズできるようになりました。isEnabled プロパティは、共有要素がアクティブかどうかを決定します。
SharedTransitionLayout {
val transition = updateTransition(currentState)
transition.AnimatedContent { targetState ->
// Create the configuration that depends on state changing.
fun animationConfig() : SharedTransitionScope.SharedContentConfig {
return object : SharedTransitionScope.SharedContentConfig {
override val SharedTransitionScope.SharedContentState.isEnabled: Boolean
get() =
// determine whether to perform a shared element transition
}
}
}
詳細については、ドキュメントをご覧ください。
Modifier.skipToLookaheadPosition()
このリリースでは、新しい修飾子 Modifier.skipToLookaheadPosition() が追加されました。これにより、共有要素アニメーションの実行時にコンポーザブルの最終位置が保持されます。これにより、Androidify サンプルでカメラが徐々に表示されるように、「表示」タイプのアニメーションなどの遷移を実行できます。詳細については、こちらの動画のヒントをご覧ください。
共有要素遷移の初期速度
このリリースでは、新しい共有要素遷移 API prepareTransitionWithInitialVelocity が追加されました。これにより、初期速度(ジェスチャーなど)を共有要素遷移に渡すことができます。
Modifier.fillMaxSize()
.draggable2D(
rememberDraggable2DState { offset += it },
onDragStopped = { velocity ->
// Set up the initial velocity for the upcoming shared element
// transition.
sharedContentStateForDraggableCat
?.prepareTransitionWithInitialVelocity(velocity)
showDetails = false
},
)
ジェスチャーからの初期速度で始まる共有要素遷移
ベール遷移
EnterTransition と ExitTransition は、AnimatedVisibility/AnimatedContent コンポーザブルの表示方法または非表示方法を定義します。新しい試験運用版のベール オプションを使用すると、コンテンツをベールまたはスクリムで覆う色を指定できます。たとえば、コンテンツの上に半透明の黒いレイヤをフェードイン/フェードアウトします。
ベールで覆われたアニメーション コンテンツ - アニメーション中にグリッド コンテンツの上に半透明のベール(またはスクリム)が表示されます
AnimatedContent(
targetState = page,
modifier = Modifier.fillMaxSize().weight(1f),
transitionSpec = {
if (targetState > initialState) {
(slideInHorizontally { it } togetherWith
slideOutHorizontally { -it / 2 } + veilOut(targetColor = veilColor))
} else {
slideInHorizontally { -it / 2 } +
unveilIn(initialColor = veilColor) togetherWith slideOutHorizontally { it }
}
},
) { targetPage ->
...
}
今後予定されている変更
Modifier.onFirstVisible の非推奨
Compose 1.9 では、Modifier.onVisibilityChanged と Modifier.onFirstVisible が導入されました。皆様からのフィードバックを確認した結果、Modifier.onFirstVisible のコントラクトを確定的に遵守することは不可能であることがわかりました。具体的には、アイテムが最初に 表示される場合です。たとえば、Lazy レイアウトでは、ビューポートからスクロールアウトしたアイテムが破棄され、スクロールして戻ると再度コンポーズされることがあります。この場合、onFirstVisible コールバックは、新しくコンポーズされたアイテムであるため、再度トリガーされます。同様の動作は、onFirstVisible を含む以前にアクセスした画面に戻る場合にも発生します。そのため、次の Compose リリース(1.11)でこの修飾子を非推奨とし、onVisibilityChanged に移行することをおすすめします。詳細については、ドキュメントをご覧ください。
テストでのコルーチン ディスパッチ
テストの不安定さを改善し、より多くの問題を検出するために、テストでのコルーチン ディスパッチを変更する予定です。現在、テストでは UnconfinedTestDispatcher が使用されていますが、これは本番環境の動作とは異なります。たとえば、エフェクトはキューに登録されるのではなく、すぐに実行されることがあります。今後のリリースでは、本番環境の動作に合わせて、デフォルトで StandardTestDispatcher を使用する新しい API を導入する予定です。新しい動作は、1.10 で今すぐ お試しいただけます。
@get:Rule // also createAndroidComposeRule, createEmptyComposeRule val rule = createComposeRule(effectContext = StandardTestDispatcher())
StandardTestDispatcher を使用するとタスクがキューに登録されるため、composeTestRule.waitForIdle() や composeTestRule.runOnIdle() などの同期メカニズムを使用する必要があります。テストで runTest を使用する場合は、同期のために runTest と Compose ルールが同じ StandardTestDispatcher インスタンスを共有していることを確認する必要があります。
// 1. Create a SINGLE dispatcher instance
val testDispatcher = StandardTestDispatcher()
// 2. Pass it to your Compose rule
@get:Rule
val composeRule = createComposeRule(effectContext = testDispatcher)
@Test
// 3. Pass the *SAME INSTANCE* to runTest
fun myTest() = runTest(testDispatcher) {
composeRule.setContent { /* ... */ }
}
ツール
優れた API には優れたツールが不可欠です。Android Studio には、Compose デベロッパー向けの最近の追加機能がいくつかあります。
-
**UI の変換**:
@Previewを右クリックして [UI の変換] を選択し、自然言語で変更内容を記述して、デザインを反復処理します。 -
@Preview**の生成**: コンポーザブルを右クリックし、**Gemini > [コンポーザブル名] のプレビューを生成** を選択します。 - ベクター アセット ウィザードでアイコン バリエーションの新しいサポートを使用してマテリアル シンボルをカスタマイズ します。
- **スクリーンショットからコードを生成** したり、Gemini に既存の UI をターゲット画像に一致させるよう相談したりします。これは、リモート MCP サポートと組み合わせて使用できます。たとえば、Figma ファイルに接続して、デザインから Compose UI を生成できます。
- UI の品質に関する問題を修正 は、アクセシビリティの問題などの一般的な問題について UI を監査し、修正を提案します。
これらのツールの動作については、こちらの最近のデモをご覧ください。
Compose をお楽しみください
Google は、美しいリッチな UI の作成に必要な API とツールを提供するために、Jetpack Compose への投資を続けています。皆様からのご意見をお待ちしております。これらの変更や、今後追加してほしい機能について、Issue Tracker でフィードバックをお寄せください。
続きを読む
-
2026 年 4 月 22 日2026 年 4 月 22 日
プロダクト ニュース
Jetpack Compose 2026 年 4 月リリースが安定版になりました。このリリースには、コア Compose モジュールのバージョン 1.11(BOM マッピングの全一覧を参照)、共有要素デバッグツール、トラックパッド イベントなどが含まれています。
Meghan Mehta • 所要時間: 5 分
-
プロダクト ニュース
Android Studio Panda 4 が安定版となり、本番環境で使用できる準備が整いました。このリリースでは、プランニング モード、次の編集予測などが導入され、高品質の Android アプリをこれまで以上に簡単に構築できるようになりました。
Matt Dyor • 所要時間: 5 分
-
プロダクト ニュース
革新的な AI 機能をアプリに実装しようとしている Android デベロッパー向けに、強力な新しいアップデートがリリースされました。
Thomas Ezan • 所要時間: 3 分
最新情報の入手
Android 開発に関する最新の分析情報を毎週メールでお届けします。