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
LOADING, LOADED, ERROR どこに何を表示するか
Search
konifar
May 28, 2018
Programming
710
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
LOADING, LOADED, ERROR どこに何を表示するか
https://nohana.connpass.com/event/80530/
で話した資料です。
konifar
May 28, 2018
More Decks by konifar
See All by konifar
自分が詳しくない領域でAIを使う #プロヒス2026
konifar
20
7.4k
マネージャー版 "提案のレベル" を上げる
konifar
26
20k
AIで 浮いた時間で 何をする? 2026春 #devsumi
konifar
21
6k
登壇資料を作る時に意識していること #登壇資料_findy
konifar
7
3.2k
事業部のプロジェクト進行と開発チームの改善の “時間軸" のすり合わせ
konifar
12
4.5k
チーム開発の “地ならし"
konifar
8
18k
AIで 浮いた時間で 何をする? #プロヒス2025
konifar
27
17k
物語を動かす行動"量" #エンジニアニメ
konifar
19
7.3k
提案のレベルを上げる #QiitaConference
konifar
98
42k
Other Decks in Programming
See All in Programming
AI 輔助遺留系統現代化的經驗分享
jame2408
1
970
Lemonade + Foundry Toolkit でお手軽アプリ開発
seosoft
1
370
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
150
dRuby over BLE
makicamel
2
390
鹿野さんに聞く!『TypeScriptコードレシピ集』で磨く実践力
tonkotsuboy_com
2
720
PHPで使える日時の表現と、その知り方 #frontend_phpcon_do
o0h
PRO
0
260
なぜ型を書くのか? TSKaigi2026で改めて考える #tskaigi_smarthr
kajitack
0
140
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
4.5k
Strategic Design in the Frontend: Moduliths & Micro Frontends @DDDEurope
manfredsteyer
PRO
0
130
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
1
300
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
390
JavaDoc 再入門
nagise
1
410
Featured
See All Featured
Building Flexible Design Systems
yeseniaperezcruz
330
40k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Embracing the Ebb and Flow
colly
88
5.1k
The World Runs on Bad Software
bkeepers
PRO
72
12k
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
Test your architecture with Archunit
thirion
1
2.3k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
The agentic SEO stack - context over prompts
schlessera
0
820
The Pragmatic Product Professional
lauravandoore
37
7.3k
Why Mistakes Are the Best Teachers: Turning Failure into a Pathway for Growth
auna
0
170
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
240
Transcript
LOADING, LOADED, ERROR どこに何を表示するか Kyash Inc. Yusuke Konishi (@konifar) 1
マテリアルデザインのおかげで それなりの見た目のアプリを 楽に作れるようになった 2
にもかかわらず 3
統一感のないアプリが できてしまう 4
解決策 5
マテリアルデザインに沿った 細かいガイドラインを作る 6
わかる、 けど難しい 7
ガイドラインの中でも 整理しにくい部分がある 8
整理しにくい = パター ンが複雑 = デザイナー さんも想定しにくい 9
その代表格 通信とユー ザー への通知 10
今日話すこと LOADING, LOADED, ERROR のとき、 どこに何を表示するか 11
分類 1. デー タの取得 => 比較的整理しやすい 2. デー タの更新 =>
なやんでる 12
デー タの取得 13
大まかな分類 1. 画面全体のロー ド 2. 画面の一部のロー ド 3. 追加のロー ド
Pull to Refresh リストの追加読み込み 14
1. 画面全体のロー ド 15
1. 画面全体のロー ド どこに 画面の真ん中 何を デフォルトのProgressBar <ProgressBar android:id="@+id/loading" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_gravity="center" /> 16
LoadingAndErrorView CustomView とDataBinding で共通化 loadState にenum を渡すといい感じに表示 <co.kyash.ui.view.LoadingAndErrorView android:layout_width="match_parent" android:layout_height="match_parent"
android:layout_below="@id/toolbar" app:loadState="@{viewModel.state}" app:onRetryClick="@{viewModel::onReloadClick}" /> 17
画面全体のロー ディング表示 がベストなのか? 画面全体のロー ドってわりとストレスたまる 部分的にロー ドできないのか? 18
2. 画面の一部のロー ド ロー ドする部分ごとにplaceholder 置いて部分的にロ ー ディングを表示する 19
考えること多い デー タがなかった時の表示の切り替え 一部エラー だった時の表示 ロー ドの待ち合わせとView の切り替え ロー ドの結果、View
がガクつかないためのwidth、 height、 アニメー ションの調整 20
開発効率とのトレー ドオフ 個人的にはデザインガイドラインには入れない方 がいいと思う どうしてもこだわりたい大事な画面は特別扱いで 対応する LOADING 中のView の表示について は、https://github.com/ethanhua/Skeleton
のよ うなライブラリである程度楽になるかもしれない 21
3-1. Pull to Refresh 22
3-1. Pull to Refresh どこに 画面の上部 何を デフォルトのSwipeRefreshLayout 23
DataBinding を使った実装 <android.support.v4.widget.SwipeRefreshLayout android:layout_width="match_parent" android:layout_height="match_parent" android:layout_below="@id/toolbar" app:onRefreshListener="@{viewModel::onRefresh}" app:refreshing="@{viewModel.swipeRefreshing}"> fun onRefresh()
{ swipeRefreshing.set(true) refreshAll(true) } 24
3-2. リストの追加読み込み 25
3-2. リストの追加読み込み どこに リストの下部 何を デフォルトのProgressBar 26
DataBinding を使った実装 @BindingAdapter(value = ["onScrolled", "onScrollTop", "onScrollE fun RecyclerView.setOnScrollEnd( ...
onScrollEnd: RecyclerViewExt.OnScrollEnd? ) { addOnScrollListener(object : RecyclerView.OnScrollListener() ... override fun onScrolled(recyclerView: RecyclerView?, dx: onScrolled?.onScrolled(recyclerView, dx, dy) val llm = layoutManager as? LinearLayoutManager ... // BOTTOM llm?.let { val visibleItemCount = it.childCount val totalItemCount = it.itemCount val pastVisibleItems = it.findFirstVisibleItemPo if (pastVisibleItems + visibleItemCount >= total onScrollEnd?.onScrollEnd() 27
DataBinding を使った実装 <android.support.v7.widget.RecyclerView android:id="@+id/recycler_view" android:layout_width="match_parent" android:layout_height="match_parent" app:onScrollEnd="@{viewModel::onScrollEnd}" /> ViewModel で処理を書くだけ
fun onScrollEnd() { if (hasMore.get() && !loadingMore) { loadingMore = true refreshData() } } 28
デー タの更新 29
整理のポイント 更新が終わる前にユー ザー に 操作をさせてよいかどうか 30
Kyash の場合 『 送金、 請求、 チャー ジ』 => 決済などお金にかかわる部分なので、LOADING 中
は操作できないように画面をロックしたい 『 プロフィー ル、 設定の変更、 メッセー ジの送信』 => 更新できなかったとしても大きな問題ではないの で、LOADING 中でも操作できるようにしたい 31
送金時( 画面全体) 32
送金時( 画面全体) ProgressDialog を使っていたが今日やめた 透明 or 半透明なFragment にProgressBar を載せて 表示するのがよいかも
送金、 請求は重要なアクションの一つなので、 ガ イドライン外でこだわってもいいかもしれない ガイドラインはあくまで基本的な思想に留めたい 33
プロフィー ル画像の変更 画像の更新は時間がかかることがある UPLOADING の状態を表示しつつ、Noti cation で 進捗を表示するのがよさそう 34
設定の変更 何も表示しないのがよさそう ダメだった時にやり直すためのSnackbar を表示す る 35
メッセー ジの送信 送信したメッセー ジを送信中としてすぐに表示す る 送信し終わったらView を更新する 表示用のモデルに isTemporary みたいなフラグを持
たせて表示を切り替えるのがよさそう 36
まとめ 37
デー タの取得は 画面全体のロー ディングを どうするか以外は簡単そう 38
デー タの更新は とにかく悩ましい 39
モデルの実際の更新と View の表示が一致しないこと が起こりそうなので 表示用のモデルを作っておく のがよさそう 40
どうしようか考え中なので 懇親会で教えてください konifar kobakei 41
Thanks! https://material.io/guidelines/components/progre ss-activity.html https://goodpatch.com/blog/progress-indicator/ https://github.com/ethanhua/Skeleton 42