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
React Nativeで 位置情報アプリをつくった話
Search
Tsuyoshi Higuchi
PRO
February 21, 2019
Programming
10
5k
React Nativeで 位置情報アプリをつくった話
【第2回】ReactNativeにゆかりのあるスタートアップが集う会
https://r-n.connpass.com/event/117895/
Tsuyoshi Higuchi
PRO
February 21, 2019
Tweet
Share
More Decks by Tsuyoshi Higuchi
See All by Tsuyoshi Higuchi
2024 Profile Slide - for フロントエンドのモデル駆動設計
tyshgc
PRO
0
64
開発現場でのサービスデザインとモデリング
tyshgc
PRO
7
2.8k
Design For User #2 コンポーネント指向から考えるUIと設計・趣旨説明スライド / Design For User #2 Openning Slide
tyshgc
PRO
1
1.2k
メンタルモデルから紐解く オブジェクト指向的コンポーネント設計 / Mental-Model Component Design
tyshgc
PRO
11
5.1k
Designer meets Domain-Driven-Design
tyshgc
PRO
28
2.6k
ReactとLoopbackことはじめ / React.js meets Loopback
tyshgc
PRO
11
3.6k
UCDとDDD - ユースケースからユーザー中心について考える
tyshgc
PRO
21
4k
UIデザイナーを取り巻く様々な設計 / Intrinsic meaning of UI Design
tyshgc
PRO
46
12k
React & Go Single Page Apps
tyshgc
PRO
20
5.6k
Other Decks in Programming
See All in Programming
Cloudless Computingの論文紹介
yuukit
1
220
チームで運用する golangci-lint の向き合い方
sgash708
3
290
データサイエンスやデータエンジニアリングの求人サイトの個人開発
billyio
0
550
Google I/O - 2024 What’s new in flutter
cybozuinsideout
PRO
2
180
You may not need XXX in Node.js
masashi
5
920
Fat Controller は悪か? ~光のFat Controller・闇のガリController~
stwile
1
210
C++ MIX #11 これどう読むの...?
5mingame2
0
190
スクラムチームに入れないという選択: フルサイクルチームにおける開発者のステップアップ / Why We Don’t Add Newbies to Our Scrum Team
yuk4w4
3
1.4k
スタートアップ企業が実践する「身の丈スクラム」の現在地 / Current State of 'Right-Sized Scrum' Practices in Startups
ar_tama
11
3.5k
イベント駆動アーキテクチャ導入の手引きと共通の落とし穴 / Guide to Implementing Event-Driven Architecture and Common Pitfalls
nrslib
12
3.9k
BigQueryとDataformとTROCCO®による事業グロース
nihemak
0
240
デプロイ・QA・Four keys を自動化×見える化する freee の統合デリバリー基盤
akito0922
1
260
Featured
See All Featured
The Illustrated Children's Guide to Kubernetes
chrisshort
35
47k
Building a Modern Day E-commerce SEO Strategy
aleyda
22
6.6k
What the flash - Photography Introduction
edds
64
11k
A Tale of Four Properties
chriscoyier
154
22k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
20
1.7k
The Cost Of JavaScript in 2023
addyosmani
25
4.1k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
247
20k
Web Components: a chance to create the future
zenorocha
307
41k
GitHub's CSS Performance
jonrohan
1025
450k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
27
2.4k
The Power of CSS Pseudo Elements
geoffreycrofte
63
5.1k
Build your cross-platform service in a week with App Engine
jlugia
227
17k
Transcript
React Nativeで 位置情報アプリをつくった話 Tsuyoshi Higuchi @tyshgc 2019.02.21
今回のトピック React Native と Google Mapsを利用 位置情報の追跡・大量のマーカーの取り扱い ユーザの現在地追随アプリを作成した際に得た知見
自己紹介 樋口 剛 Tsuyoshi Higuchi 今日はエンジニアとしてやってきました。 基本はサービスとUIをデザイン(設計)する人ですが インフラとバックエンド以外は基本何でもやります。 Reactは5年くらい、React Native歴は半年程度。 @tyshgc
サービスの紹介 KiiiN - キーン - という現実世界に 金塊「キーン」をばら撒いて それを集めてモノと交換する 位置情報 ×
ロイヤリティプログラムサービス 33,503 33,503
インセンティブを提供し ユーザを特定の場所へ誘導・現実世界の活動を 流動的にすることによって ビジネスの機会をつくろうというサービス
アプリの要件 ❶ユーザの現在地に追随する ❷大量のカスタムマーカーを配置・更新する 現在地の取得の精度・デバイス依存問題 マーカーのレンダリングコスト問題 ISSUE
主に利用している位置情報関連のライブラリ https://github.com/react-native-community/react-native-maps react-native-maps https://github.com/manuelbieh/Geolib geolib https://github.com/neuberoliveira/react-native-gps-state react-native-gps-state
アーキテクチャ 今回は状態管理周りにMobXを採用 社内的にVue.jsユーザが多い & 堅牢性は(設計次第で)劣るが記述量はReduxより少ない コンポーネントはContainer Component Pattern Atomic Designの粒度定義は無駄にファットになるのでいれない
Container Component Model UseCase A User Event 1 User Event
2 UseCase B User Event 1 User Event 2 Domain Store = [ State, State, … ] Presentational Store = [ State, State, … ] Stores MobX ࣮ମԽ Model Element Component Element Component 1SPWJEFSܦ༝Ͱ ঢ়ଶมߋ࣌ʹ ࣗಈͰ͢ API / Realm / NativeAPI !BDUJPONFUIPEΛୟ͍ͯ4UBUFͷঢ়ଶΛมߋ 1SPQTͰͱ6TF$BTFΛ͢ 6TF$BTFͷ ΠϕϯτΛୟ͘ 4UPSFαʔϏευϝΠϯʹؔ͢Δͷͱ 1SFTFOUBUJPOBM (6* ʹؔ͢ΔͷͰ͚Δ
None
None
None
None
位置情報を扱う React Nativeで位置情報といえば Geolocation APIは、Geolocation Web仕様を拡張したもの navigator.geolocation
None
現在地の取得は一部のAndroidデバイスで 取得できたりできなかったり、精度微妙… RN公式でも react-native-geolocation-service を 使えとのこと
Geolocation APIは積極的に使わず react-native-mapsの MapViewコンポーネントの onUserLocationChange を活用 onUserLocationChange: (event=> { const
{ latitude, longitude } = event.nativeEvent.coordinate }) 返り値(緯度・経度)をUsecase経由でStoreへ投げて諸々処理する方向へ
None
None
None
onUserLocationChange は、 showsUserLocationとfollowsUserLocationを trueにしないと返り値を返さない… { showsUserLocation: true, followsUserLocation: true, onUserLocationChange:
(event=> {…}) } ただしこれらをアクティブにするとMap上に青い現在地が表示されてしまう
33,503
また、onUserLocationChange は、 かなり小さい移動も検知するため イベントを呼ぶ回数をgeolibで間引く必要がありました。 { showsUserLocation: true, followsUserLocation: true, onUserLocationChange:
(event=> {…}) }
大量のCustomMarkerと闘う マーカーを独自のイメージに変更したい場合は… <Marker image={画像} coordinate={現在地} />
iOSは表示も周りのインタラクションも激重!! CPUを食いまくるらしくFPSは大幅に低下する
tracksViewChangesでfalseを指定する <Marker image={画像} tracksViewChanges={false} coordinate={現在地} /> falseだと何も表示されないので componentDidMountでMountできたらfalseにする
None
None
マーカーに込み入ったことをする こんな感じにマーカーをしたい場合は… 33,503
<Marker image={画像} tracksViewChanges={false} coordinate={現在地} > <View style={…}><SvgOriginalImage /></View> </Marker> <Marker
/>にchildrenを渡せばいい アプリではSvgのアイコンイメージをマーカーにしようとした
Androidでchildrenが表示されない… iOSとAndroidで微妙に表示の扱いが違うぽい
<Marker …> <Svg width={MARKER_WIDTH} height={MARKER_HEIGHT}> <View style={…}><SvgOriginalImage /></View> </Svg> </Marker>
AndroidはSvgコンポーネントで挟んであげる ※iOSはSvgいれると表示されなくなるので注意
ReactNative所感 ReactNative自体はReact経験者にはやさしい Native Bridgeコードも言うほど障壁高くない ただ、OSSのライブラリはインストール時にコケることが 多く特にXcodeが辛すぎた… AndroidStudioはSDKバージョン周りで最初にコケた…
ご静聴ありがとうございました