Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
5分で完全理解するNav3との向き合い方
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Tomoki Yamashita
June 25, 2025
Technology
260
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
5分で完全理解するNav3との向き合い方
Tomoki Yamashita
June 25, 2025
More Decks by Tomoki Yamashita
See All by Tomoki Yamashita
ハードウェア連携が必要なプロダクトにおける自動テストの書き方
tomorrowkey
0
120
STORES_決済端末2ってAndroidなんでしょ__ほんとうかな__.pdf
tomorrowkey
0
59
モバイルとRubyとわたし
tomorrowkey
0
65
BiDiってなんだ?
tomorrowkey
2
740
文字列操作の達人になる ~ Kotlinの文字列の便利な世界 ~ - Kotlin fest 2025
tomorrowkey
2
1.6k
Ebisu mobile #11 - Predictive Backに対応する
tomorrowkey
1
150
AI協同時代にモバイルエンジニアが備えるべき開発環境の話
tomorrowkey
2
440
テストを楽に書きたい
tomorrowkey
2
430
Gradle Build Scanを使ってビルドのことを知ろう potatotips #87
tomorrowkey
2
1.4k
Other Decks in Technology
See All in Technology
感情と身体を置き去りにしない、エンジニアの生きのこり方 ──いまから、ここから「自分の状態」を扱うという選択
saorimurooka
0
290
Chainlitで作るお手軽チャットUI
ynt0485
0
290
【2026年版】 ベクトル検索とEmbedding最前線
mocobeta
23
7.2k
AIのReact習熟度を測る
uhyo
2
670
【Snowflake Summit 2026 Recap!!】Snowflake Summit Deep Dive: Security & Governance
civitaspo
1
300
Oracle Cloud Infrastructure:2026年6月度サービス・アップデート
oracle4engineer
PRO
0
260
【セミナー資料】Claude Code をセキュアに使うための考え方と設定の勘どころ / Claude Code Webinar 20260616
masahirokawahara
2
450
現場のトークンマネジメント
dak2
1
170
人材育成分科会.pdf
_awache
4
310
iOS アプリの「これって不具合ですか?」を AI に調べてもらう
miichan
0
140
新しいUbuntu/GNOMEが使いたいからXからWaylandへ移行頑張ってるの巻 2026-06-20
nobutomurata
0
160
Claude Codeをどのように キャッチアップしているか
oikon48
13
8.7k
Featured
See All Featured
Ruling the World: When Life Gets Gamed
codingconduct
0
260
Winning Ecommerce Organic Search in an AI Era - #searchnstuff2025
aleyda
1
2.1k
WENDY [Excerpt]
tessaabrams
11
38k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
From π to Pie charts
rasagy
0
220
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.5k
The Mindset for Success: Future Career Progression
greggifford
PRO
0
360
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
200
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
210
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.2k
Imperfection Machines: The Place of Print at Facebook
scottboms
270
14k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
46
2.9k
Transcript
STORES 株式会社 5分で完全理解するNav3との向き合い方 Ebisu mobile #10 〜WWDC & Google I/O
スペシャル!〜 2025.06.26 @tomorrowkey
自己紹介
自己紹介 • 山下智樹 / @tomorrowkey • STORES株式会社 - STORES ブランドアプリ
• Android エンジニア 3
Nav3の話をしたい
Jetpack Navigationってなに • 画面遷移を実現するためのAndroidのライブラリ • NavigationはFragmentベースの時代に作られたライブラリであり、XMLに 画面の遷移先や引数を定義して、画面遷移を宣言的に書けるライブラリだっ た。 • Navigation
Composeの登場によりCompose時代でも画面遷移を定義できる ようになった。 5
Nav2のデメリット • Fragment時代に作られたライブラリなので、Jetpack Composeとの親和性 が完全ではなかった。 • バックスタックの管理がライブラリ任せであり、テクニカルな画面遷移を実装 しようとすると、高度な知識とワークアラウンドが必要となった。 • Nav2では画面をNavHostいっぱいに表示するため、TabletやFoldableなど画
面の大きさを活かしたレイアウトを表示をさせることが難しかった。 6
Nav3の誕生
たった2つのNav3のポイント You own the back stack バックスタックはただのListです。 その管理はライブラリではなく自分自身で所有し、コントロールします。 Get out
of your way どのようにナビゲーションしたいかは、開発者である自分自身が一番分かっている。 Nav3ではオープンで拡張可能なように設計されているため、そのアプリのユースケースに併せてカスタマイズが可能になりました。 8
サンプルコード val backStack = remember { mutableStateListOf<Any>(RouteA) } NavDisplay( backStack
= backStack, onBack = { backStack.removeLastOrNull() }, entryProvider = entryProvider { entry<RouteA> { ContentGreen("Welcome to Nav3") { Button(onClick = { backStack.add(RouteB("123")) }) { Text("Click to navigate") } } } entry<RouteB> { key -> ContentBlue("Route id: ${key.id} ") } } ) 9
Nav3はすべてを解決するのか • Nav3ではすべてのアプリのユースケースをカバーするアプローチではなく、 多くのユースケースをカバーするためのコンポーネントが提供されるように なった。 • 一見柔軟性が増えたように聞こえるが、これまでライブラリで管理されていた DeepLinkや状態の管理は開発者が行わないといけなくなった。 10
Nav3にどう立ち向かうか https://github.com/android/nav3-recipes によくあるユースケースのためのサ ンプルコードがあります。 - NavigationRail or NavigationBar - ログインを題材にした条件付き画面遷移
- Scenes を複雑なカスタムレイアウト - DeepLinks (まだコードはない) - Android XR Support (まだコードはない) - 画面間の戻り値 (まだコードはない) 11
これからのNav3に期待 - まだAlpha版なのでプロダクションユースは推奨されていません - 触ってみてフィードバックをIssue Trackerになげましょう 12
おわり
参考文献 - Android Developers Blog: Announcing Jetpack Navigation 3 https://android-developers.googleblog.com/2025/05/announcing-jetpack-navigation-3-for-compose.html
- android/nav3-recipes: Implement common use cases with Jetpack Navigation 3 https://github.com/android/nav3-recipes - Navigating the future with Jetpack Navigation 3 - Core Concepts - YouTube https://www.youtube.com/watch?v=opLYavQHBB8 14