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
ViewModel使ってますか?
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
katsuki-nakatani
April 26, 2018
Technology
0
320
ViewModel使ってますか?
メルカリさん、ヤフーさん主催のMixLeapでLTしたときの資料です。
AndroidのViewModelのさわりの説明というかんじです
katsuki-nakatani
April 26, 2018
Tweet
Share
More Decks by katsuki-nakatani
See All by katsuki-nakatani
Android 10 対応 Tips
katsukinakatani
0
110
InAppUpdate実装&InAppBillingClientVer2.0実装例
katsukinakatani
0
590
AndroidJetpack概要 &旧AACの紹介
katsukinakatani
0
680
デフォルトアプリとパーミッション
katsukinakatani
0
220
Target SDK Version 26に上げる時につまづいたこと
katsukinakatani
3
2.8k
Whats new android wear (umeda.apk #3 LT)
katsukinakatani
1
500
Android 7.1.1 AppShortcuts setup(DevfestKansai Lightning Talk)
katsukinakatani
1
700
Firebase Authentication & Firebase Realtime Database setup
katsukinakatani
2
900
Firebase Setup for Android Studio2.2
katsukinakatani
1
630
Other Decks in Technology
See All in Technology
~Everything as Codeを諦めない~ 後からCDK
mu7889yoon
3
460
【Oracle Cloud ウェビナー】[Oracle AI Database + AWS] Oracle Database@AWSで広がるクラウドの新たな選択肢とAI時代のデータ戦略
oracle4engineer
PRO
2
180
OWASP Top 10:2025 リリースと 少しの日本語化にまつわる裏話
okdt
PRO
3
830
顧客との商談議事録をみんなで読んで顧客解像度を上げよう
shibayu36
0
280
AWS Network Firewall Proxyを触ってみた
nagisa53
1
240
Oracle AI Database移行・アップグレード勉強会 - RAT活用編
oracle4engineer
PRO
0
110
Amazon Bedrock Knowledge Basesチャンキング解説!
aoinoguchi
0
160
マーケットプレイス版Oracle WebCenter Content For OCI
oracle4engineer
PRO
5
1.6k
セキュリティについて学ぶ会 / 2026 01 25 Takamatsu WordPress Meetup
rocketmartue
1
310
今こそ学びたいKubernetesネットワーク ~CNIが繋ぐNWとプラットフォームの「フラッと」な対話
logica0419
2
190
Codex 5.3 と Opus 4.6 にコーポレートサイトを作らせてみた / Codex 5.3 vs Opus 4.6
ama_ch
0
190
私たち準委任PdEは2つのプロダクトに挑戦する ~ソフトウェア、開発支援という”二重”のプロダクトエンジニアリングの実践~ / 20260212 Naoki Takahashi
shift_evolve
PRO
1
110
Featured
See All Featured
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.2k
Color Theory Basics | Prateek | Gurzu
gurzu
0
200
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1.1k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
220
Build The Right Thing And Hit Your Dates
maggiecrowley
39
3k
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
61
52k
Thoughts on Productivity
jonyablonski
74
5k
Information Architects: The Missing Link in Design Systems
soysaucechin
0
780
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
86
Optimizing for Happiness
mojombo
379
71k
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
200
Transcript
ViewModel使ってますか? 2018/4/20 Osaka Mix Leap Study #11 - スマホアプリ勉強会
Speaker 中谷 克紀 仕事 Enterprise Server Engineer GDG 神戸スタッフ Twitter @KatsukiNakatani
What's ViewModel? MVVMとか設計の話ではないです
これの話
ViewPagerでこんなデータを表示したい 仮想通貨のデータ 最近、仮想通貨流行ってますよね?
データの持ち方 data class CurrencyOrder( var exchanger: String? = null, //購入Exchanger
var folio_group:Long = FolioGroup.DEFAULT_ID, //この通貨のグループ var currency_pair: String? = null, //通貨ペア var proc_date: String = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyy/MM/dd")), //処理日付 var amount: Double = 0.toDouble(), //処理数量 var price: Double = 0.toDouble() //ベースとなる通貨の価格 exchanger folio_group currency_pair proc_date amount price zaif 1 jpy_btc 2018/1/1 1 850000 zaif 2 jpy_xem 2018/2/2 1 35
データの概要 folio_groupがここ
安易に考える Activity ViewPager Pager1 Fragment Pager2 Fragment ActivityViewModel FragmentViewModel FragmentViewModel
安易に考える Activity ViewPager Pager1 Fragment Pager2 Fragment ActivityViewModel 1.ActivityViewModelがデータを全件取得 2.ActivityがそのデータをDataCallbackInterfaceを
実装しているであろう Fragmentに送る 3.FragmentがCallbackを受け取り、データを表示 FragmentViewModel FragmentViewModel DataCallback DataCallback
めんどくさい Activity ViewPager Pager1 Fragment Pager2 Fragment ActivityViewModel ・ActivityがDataCallbackInterfaceを実装していることを知る必要あり ・ActivityはただViewPagerだけ管理していたい
FragmentViewModel FragmentViewModel DataCallback DataCallback
ViewModelの登場 ViewModelのインスタンス生成時に渡すparameterに 紐付いて生存期間のスコープが作成されます ViewModelProviders.of(parameter).get(MyViewModel.class); 画面回転時にデータ保存を意識しなくても良い!! ※ただし低メモリ時に破棄されると困るデータはきちんと SaveInstanceStateで保存しましょう
ViewModelの共有 ViewModelのインスタンス生成時に渡すparameterが同じものは別インスタンスじゃなくて 同じインスタンスにアクセスできる ViewPager Fragment Code viewModel = ViewModelProviders.of(activity).get(AssetsViewModel::class.java) Activity
ViewPager Pager1 Fragment Pager2 Fragment getActivity()した結果は同じActivity
諸問題が解決 Activity ViewPager Pager1 Fragment Pager2 Fragment ActivityViewModel AssetViewModel DataCallback
DataCallback ・DataCallbackを用意しなくても良くなり、 ActivityがFragmentの実装を意識しなくて良くなった ・Activityの回転時に再度データを検索、表示するような実装を意識しなくても良くなった
ViewModelの作り方 class AssetsViewModel @Inject constructor(private val database: AppDatabase, private val
messageRepository: MessageRepository, private val assetRepository: AssetsRepository, private val preferenceRepository: PreferenceRepository) : ViewModel() Architecture ComponentのViewModelを継承する
注意すること 生存期間が渡したパラメータのライフサイクルより長い = ViewModel側でViewにアクセスする、またはライフサイクル内の コンテキストを使用するような実装は避けましょう contextがほしいViewModelの場合はAndroidViewModelを 継承してください
ViewModelはLiveDataと組み合わせると便利 LiveDataの特徴 SubscribeするとActivityやFragmentのライフサイクル状態を 見てコールバックを呼び出してくれる LiveDataの定義 var assetsList: MutableLiveData<AssetsResponse> = MutableLiveData()
LiveDataへデータのプッシュ assetsList.postValue(response) viewModel.assetsList.observe(this,Observer<AssetsResponse> { it -> //表示処理}) LiveDataのオブザーブ ViewModel Fragment
よくある通信例 1.画面を開くと外部通信を行う 2.外部通信を行っている場合はProgressが表示される 3.通信を行っている間に画面が回転する可能性もある 4.通信結果を画面に表示する、ただし画面を落としている可能性もあるよね 落としている時はデータ表示処理してほしくないし復帰したら処理してほしい
よくある通信例 1.画面を開くと外部通信を行う 2.外部通信を行っている場合はProgressが表示される 3.通信を行っている間に画面が回転する可能性もある 4.通信結果を画面に表示する、ただし画面を落としている可能性もある 落としている時はデータ表示処理してほしくないし復帰したら処理してほしい ー>ViewModelにbooleanを持ってDatabindingで表示・非表示を切り替え ー>ViewModelを使えば渡すContextより長いスコープで 生存してくれるので気にしなくて良い ー>LiveDataをViewModel内に持たせておけば、回転してもデータを維持しUI復帰時に
データをPostしてコールバックしてくれる
使ってみた https://goo.gl/NB9R7y 結果・Room+ViewModel+LiveDataを使って実装してみたのでよければ使ってください。 Architecture Componentのモジュールを使うと 今まで苦労していたAndroidのライフサイクル関係は 大分楽に実装できます
おしまい 御清聴ありがとうございました