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
【DevFest & ADS JP 22】チームで導入するJetpackCompose@おい...
Search
kako351
December 16, 2022
Programming
2.6k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
【DevFest & ADS JP 22】チームで導入するJetpackCompose@おいしい健康
「DevFest & Android Dev Summit Japan 2022」でのLT登壇資料です
kako351
December 16, 2022
More Decks by kako351
See All by kako351
Play Billing Library 7.0.0 変更点まとめ@potatotips#88
kako351
0
1.6k
Paging3のSeparatorsを使って LazyColumnにヘッダーや 別のアイテムを挿入する
kako351
0
790
CircleCIでFlakyなテストを再実行する_potatotips#83
kako351
0
230
ComposeでTimeRangePickerを作る_YUMEMI.grow Mobile #2
kako351
1
900
Composeの座標を取得する ~コーチマークにおける活用事例~_DroidKaigi.collect#1
kako351
2
3.2k
チームで導入する Jetpack Compose あの素晴らしいLTをもう一度.ver
kako351
1
1.4k
Other Decks in Programming
See All in Programming
JJUG CCC 2026 Spring: JSpecify で実現する Kotlin フレンドリーな Java API 設計
ternbusty
1
160
Oxcを導入して開発体験が向上した話
yug1224
4
300
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
13
3.6k
ローカルLLMでどこまでコードが書けるか -拡張版 / How much code can be written on a local LLM Extended
kishida
2
160
Swiftのレキシカルスコープ管理
kntkymt
0
220
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.6k
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
390
コンテキストの使い捨てをやめる — ビジネスルール駆動開発と miko —
ioki
0
180
dRuby over BLE
makicamel
2
330
CSC307 Lecture 17
javiergs
PRO
0
320
Oxlintのカスタムルールの現況
syumai
6
1.1k
Composerを使ったサプライチェーン攻撃の様子を眺めてみる #phpstudy
o0h
PRO
2
240
Featured
See All Featured
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
210
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
2
330
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
2k
The Language of Interfaces
destraynor
162
27k
WCS-LA-2024
lcolladotor
0
620
<Decoding/> the Language of Devs - We Love SEO 2024
nikkihalliwell
1
240
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
180
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.3k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
22k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
830
Transcript
チームで導入する Jetpack Compose 小林 克麻 株式会社おいしい健康 Android エンジニア
小林 克麻 (@kako_351) 株式会社おいしい健康 Android エンジニア 「おいしい健康 Android アプリ」の開発をリ リース時から今まで担当してきました。今回の
導入事例は「おいしい健康 Android アプリ」 での話をします。 自己紹介
None
None
Contents 01 02 03 04 05 弊社の Jetpack Compose 導入状況
導入の進め方 メリット 課題と対応 今後の TRY
弊社の Jetpack Compose 導入状況 「おいしい健康 Android アプリ」はリリースして 3 年が経ちました。弊社の Androidチーム
では、Jetpack Compose がリリースされてから早いタイミングで導入してきたのでその事 例をご紹介します。
導入から現在までの使用につ いて おいしい健康では Jetpack Compose を 2021 年 11 月から導入を開始しまし
た。導入時点での最新バージョンは 1.0.1。 Jetpack Compose がリリースさ れてから早いタイミングで導入をしまし た。 導入から約 1 年経ちましたが、その間 Jetpack Compose を使用し続けてきま した。現在ではバージョン 1.3.0 を使用し ています。新規で画面を実装するときは 基本的に Jetpack Compose を使用して います。 導入時点 現在
おいしい健康の画面全体に対するJetpack Compose 使用率は 29.55% (約 30%)。導入箇所ですが、ホーム画面に 部分的に導入したり、リスト画面すべてを Jetpack Compose で実装したりと積極的
に使用してきました。 Jetpack Compose の割合 30% Jetpack Compose の割合
導入の理由 導入当時チームメンバー全員 が使いたい意思を持ち合わせ おり、メンバーの意向が揃って いました。 また、Jetpack Compose によ り開発スピードの向上も期待し ていました。
サポートが minSDK 21 以上で あったり、Android View や Fragment との相互運用可能 であったり、既存アプリへの導 入がしやすく既存の実装が障 壁となることはありません。 モチベーション 導入のしやすさ AndroidView のバグの中には OS のバージョンに依存するも のが存在していました。 Jetpack Compose では OS に依存しないかたちで View を 提供可能なため、OS バージョ ン依存のバグがなくなることを 期待していました。 バグの減少
導入の進め方 既存アプリにも導入しやすい Jetpack Compose ですが、プロダクトに導入する上では考 慮すべきことや懸念点があると思います。おいしい健康ではどのように導入を進めてきたの か、その事例をご紹介します。
おいしい健康には「買い物リスト」という機能 が存在しますが、初めてJetpack Compose を導入した画面になります。 既存機能の一部を Jetpack Compose に 置き換えることも検討しましたが、リプレイス よりも新機能の開発で使用する方が進めや
すいと考えました。 新機能の開発時に初導入
Jetpack Compose を使用する ことにこだわりすぎないことも大 事なことだと考えてきました。 Jetpack Compose をあえて使 用しなかった一例をご紹介しま す。
実装の悩みを ISSUE 化 Jetpack Compose を チームに浸透させていく チームで Jetpack Compose の Codelab Pathway に取り組 み知見の共有・学習してチーム 全体の Jetpack Compose の 理解を底上げしました。 メンバーが実装時に悩んだこと を記載する場所としてGithub の ISSUE を用意しました。 Codelab 会 無理に使わない
チームで Jetpack Compose Codelab Pathway に取り組みました。 Codelab 中にお互いに質問したり疑問を 一緒に解決したり、メンバー全員で知見を 共有・学習できた時間となりました。
この Codelab がとても手厚く Jetpack Compose を学習できるようになっていて、 Jetpack Compose の学習を進めていたメ ンバーとそうでないメンバーの知識の差を 埋めることができました。 Codelab 会
Jetpack Compose を早いタイミングで導 入したこともあり実装時に何がベストか悩む ことがありました。 メンバーが実装時に悩んだことを共有・管 理する場として Github の ISSUE
を活用し ました。 知見や参考資料を共有したり、議論したり など悩みつつもチームで進めていきまし た。 実装の悩みを ISSUE 化
Jetpack Compose の使用が難しい場合 には、AndroidView で実装する方針をとり ました。 例えば、初期のころは TextField の日本語 入力において入力テキストの削除が削除ボ
タン長押しで削除できない問題があったた め、AndroidView の EditText を利用しま した。 Jetpack Compose から AndroidView を 呼べる相互運用のメリットの恩恵が受けら れたケースでもあると感じています。 無理に使わない
Jetpack Compose をチームで取り組み導入を進めてきた中で感じたメリットを ご紹介します。 導入して感じたメリット
メリット 同じ実装でも AndroidView と 比較すると少ないコードで実装 できます。コードの少なさはシン プルであり、バグのリスクを軽減 できます。 Jetpack Compose
はアニメー ションの実装も簡単です。動きを つけることでよりリッチなアプリを 実現できます。 コード量の削減 アニメーション デバッグを効率的に行える開発 ツールが揃っています。便利な 機能が備わっているので一例を ご紹介します。 強力な開発ツール
リストの画面を実装した場合、従来の RecyclerView と Jetpack Compose で比 較したところ大幅にコードの削減ができま した。 コード量の削減
ShoppingListAdapter.kt class ShoppingListAdapter(private val data: List<ShoppingItem>): RecyclerView.Adapter<ShoppingListAdapter.ViewHolder>() { class ViewHolder(view:
View): RecyclerView.ViewHolder(view){} override fun getItemCount(): Int = data.size override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder { // ... return ViewHolder(view) } override fun onBindViewHolder(holder: ViewHolder, position: Int) } ShoppingListFragment.kt val adapter = ShoppingListAdapter(data) val recyclerView: RecyclerView = findViewById(R.id.recycler_view) recyclerView.adapter = adapter recyclerView.layoutManager = LinearLayoutManager(requireContext(), RecyclerView.VERTICAL, false)
ShoppingList.kt @Composable fun ShoppingList(data: List<ShoppingItem>) { LazyColumn { items(data) {
ShoppingListItem(it) } } } @Composable fun ShoppingListItem(item: ShoppingItem) { // ... }
Jetpack Compose はアニメーションの実 装も少ないコードで実現できます。 献立をブックマークする機能があり、ブック マーク時にカード全体がアニメーションしま す。このアニメーションも Jetpack Compose で実装しています。
アニメーション
RecommendedMenuCard.kt var visible by remember { mutableStateOf(true) } AnimatedVisibility( visible
= visible, exit = scaleOut( targetScale = 0.2f, ) + slideOutVertically { with(density) { +200.dp.roundToPx() } } + fadeOut( animationSpec = tween(delayMillis = 200), ), )
デバッグを効率的に行える開発ツールが 揃っています。特に Preview が優秀で複 数デバイスの Preview や、実機 Preview、 インタラクティブモードなど強力なツールが 揃っています。
インタラクティブモードでは Android Studio 上で Composable の挙動を確認 できます。アプリを立ち上げる必要がなくデ バッグを効率的に行えます。 強力な開発ツール
Jetpack Compose を導入するメリットを紹介しましたが、今度はチームで取り組んだ中で見え てきた課題とその課題にどのように対応してきたのか事例をご紹介します。 課題と対応
人によって Composable の粒度が異なっ ていました。 特別問題を引き起こすケースはありません でしたが、実装方針が人に依存していまし た。 粒度が揃わない 他社様のブログなどを参考に Atomic
デ ザインを採用してみました。 これにより粒度がある程度揃いましたが、 Atomic デザインに限らずチームとしての 方針を立てておくとよかったなと思ってい ます。 Atomic デザイン採用
Preview は非常に便利なツールではある のですが、実際のアプリのビルドの時間が 影響するため Preview が遅い問題があり ました。 Preview 表示が遅い 本体のアプリとは別に
Preview 用のアプリ ケーションモジュールを作成しました。 Preview はそのアプリケーションモジュー ル内で行い Preview の高速化を図りまし た。 Preview 用アプリ
本体アプリの Feature モジュールでは89 秒、Preview 用アプリケーションモジュール では 11 秒という結果になり約87% 時間が 短縮しました。
Preview 時間計測 87% Preview 時間短縮
Atomic デザインを採用しましたが、 チームに合わせた方針が必要だと感じ ています。 TwitterCompose ルールや公開されて いるリポジトリを参考にしつつ、チームに 合わせてカスタマイズして導入すること を検討しています。 今後の
Try 実装タスクの中で Jetpack Compose に 置き換えられそうなコンポーネントはつい でに置き換えるという方針で徐々に Jetpack Compose 化を今後もすすめて いく予定です。 チームで実装方針を作る 既存画面への導入について
「おいしい健康」では Android エンジニア を募集しています。 Jetpack Compose を使いたい、導入の詳 しい話を聞きたいと言う方は右の QR コード
からカジュアル面談お待ちしております。 [宣伝] Android エンジニア 募集しています
ご清聴ありがとう ございました
Thank you!