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
Android cookpadLiveの開発改善 / cookpad_tech_kitchen#23
Search
star_zero
January 30, 2020
Programming
910
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Android cookpadLiveの開発改善 / cookpad_tech_kitchen#23
star_zero
January 30, 2020
More Decks by star_zero
See All by star_zero
今からはじめるAndroidアプリ開発 2024 / DevFest 2024
star_zero
0
1.6k
Jetpack Compose の Side-effect を使いこなす / DroidKaigi 2023
star_zero
5
7.1k
Android 14 新機能 / Android 14 Meetup Nagoya
star_zero
1
680
Android 14 と Predictive back gesture / Shibuya.apk #42
star_zero
0
490
Coroutines Test 入門 / Android Test Night #8
star_zero
2
1.3k
What's new in Jetpack / I/O Extended Japan 2022
star_zero
1
710
Kotlin 2021 Recap / DevFest 2021
star_zero
3
1.4k
Kotlin Symbol Processing (KSP) を使ったコード生成 / DroidKaigi 2021
star_zero
2
5.3k
What's new Android 12
star_zero
0
620
Other Decks in Programming
See All in Programming
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
13k
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
21
6.7k
Spring Security 実践 ─ GraphQL APIで実務に役立つ 認証・認可 を学ぶ
wagyu
0
240
Honoでのサプライチェーン侵害対策 〜 3つのライブラリに学ぶ
yusukebe
6
1.3k
Dataformのリポジトリを立ち上げるときにまずやること / dataform-day0-2026
snhryt
0
170
TAKTでAI駆動開発の品質を設計する
j5ik2o
7
1.3k
JavaDoc 再入門
nagise
1
370
例外の正しい扱い方 そのエラー try-catchして大丈夫?
jinwatanabe
0
260
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
410
エンジニアと一緒にテストコードの設計と実装を改善した話
mototakatsu
0
200
Vite+ Unified Toolchain for the Web
naokihaba
0
320
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
200
Featured
See All Featured
Mozcon NYC 2025: Stop Losing SEO Traffic
samtorres
1
260
Thoughts on Productivity
jonyablonski
76
5.2k
Test your architecture with Archunit
thirion
1
2.3k
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
2k
VelocityConf: Rendering Performance Case Studies
addyosmani
333
25k
A designer walks into a library…
pauljervisheath
211
24k
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
1
350
Into the Great Unknown - MozCon
thekraken
41
2.6k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
2
1.5k
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
508
140k
Claude Code のすすめ
schroneko
67
230k
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Transcript
Android cookpadLiveの 開発改善 Cookpad Tech Kitchen #23 2020/01/30
About me •Kenji Abe •2018/07入社 •Android cookpadLive •Google Developers Expert
for Android •Twitter: @STAR_ZERO
話すこと •Android cookpadLiveで改善してきた色々なこと ‣ たくさんあるので一部抜粋して •今後やりたいこと
アーキテクチャの変更
VIPER MVVM
VIPER •View / Interactor / Presenter / Entity / Router
•iOS由来のアーキテクチャ •https://cheesecakelabs.com/blog/ios-project- architecture-using-viper/
View Presenter Interactor Entity Router
VIPERの問題点 •Jetpackとの相性 ‣ これらを活かせないため効率と品質を上げられない ‣ Lifecycleの管理が面倒でクラッシュも起きやすい •コード量が多い ‣ Interfaceによるやりとり ‣
あちこちにViewの更新コード
MVVM •Model / View / ViewModel •Google 推奨のアーキテクチャ •https://developer.android.com/jetpack/docs/guide
Activity / Fragment ViewModel Repository Room(DB) Retrofit(API) AppSync LiveData
MVVMの良いとこ •Jetpackが活用しやすい ‣ 特にViewModel, LiveData, DataBinding便利 ‣ これらを活用することでバグが減らせる ‣ 効率よく開発できる
‣ その他Jetpackライブラリも導入が簡単
Activity / Fragment ViewModel Repository Room(DB) Retrofit(API) AppSync LiveData Jetpack
Jetpack Jetpack
MVVMの良いとこ •Google推奨(デファクトスタンダード) ‣ 知見やサンプルがたくさんある ‣ 新しく来た人が理解しやすい(可能性が高い) ‣ 去っていく人も次に活かせる(可能性が高い)
Modularization
Single Module Multi Module
Single Module •スマートフォンアプリのみ ‣ AndroidTV / FireTVとコードが重複 •ビルドスピードの問題 •依存関係の絡まり
Multi Module •スマートフォンアプリ、AndroidTV、FireTV ‣ APIアクセスなどは共有 •ビルドスピードの改善 •関心事の分離
app 最初のSingleModule時代
core app 共通部分をcoreに分ける
core smarttv app androidtv firetv AndroidTV / FireTVをプロジェクト統合
core smarttv app androidtv firetv appsync AppSyncをcoreから分離
core smarttv appcore app androidtv firetv appsync app専用の共通モジュールを作成
core smarttv appcore app androidtv firetv features appsync 機能単位にモジュールを分ける
core smarttv appcore app androidtv firetv features appsync 機能単位にモジュールを分ける まだ途中
コメント表示改善
改善前 •受信したコメントをそのまま表示 ‣ 描画負荷が高い ‣ 場合によってはクラッシュを引き起こす •RecyclerViewのアニメーション ‣ デフォルトがそのまま ‣
大量のコメントで違和感
改善後 •受信したコメントを少しバッファリングして表示 ‣ ある程度まとめ描画させて、描画負荷を軽減 •RecyclerViewのアニメーションは無効に ‣ 無効にしたほうが自然な感じ
Activity Repository ViewModel AppSync LiveData
Activity Repository ViewModel AppSync LiveData RxJavaのObservableに変換
Activity Repository ViewModel AppSync LiveData ここで数msバッファリング
Activity Repository ViewModel AppSync LiveData LiveDataでコメントActivityへ
コード自動生成
コード自動生成 •現状、サーバー側がRails Garageを使ってる ‣ 欲しいレスポンスをGETパラメータで指定する ‣ 例: /api/episodes?fields=hoge,foo •面倒なので、Retrofitの戻り値から自動生成 ‣
Annotation Processing
/api/episodes?fields=hoge,foo interface APIService { @Garage @GET("/api/episodes") fun getEpisodes(): Single<List<Episode>> }
data class Episode( val hoge: String? val foo: String? ) このアノテーションから自動生成
デバッグツールの活用
デバッグツールの活用 •Hyperion ‣ アプリ実行中にデバッグメニューから色々できる ‣ 設定値をクリアしたり、APIのエンドポイントを切り替え たり ‣ https://github.com/willowtreeapps/Hyperion-Android
None
デバッグツールの活用 •Flipper ‣ デスクトップアプリを使ったデバッグツール ‣ Stethoみたいなもの ‣ ログ、Preferences、Layoutなどの確認 ‣ プラグインを作れる
‣ https://fbflipper.com/
None
デバッグツールの活用 •Flipper ‣ プラグインを作成して、ダミーのLive配信 • OkHttp Interceptorでダミーデータを差し込む ‣ 簡単な見た目の確認すぐできる ‣
ステージングの配信を作る必要がない
None
OkHttp API Server Flipper OkHttp Interceptor レスポンス 書き換え ダミーデータ
今後やりたいこと
今後やりたいこと •Coroutinesの導入 •テストを充実 •リソースの整理 •さらなる効率化
ありがとうございました