#やりたいこと
- ReactNative(Expo)アプリケーションに地図を導入する
- 無償の地図を利用したい。GoogleMapは有償となったため、Open Street Mapを利用したい
#環境
- Expo 4.13.0
- react@17.0.2
- reactNative 4.9.0
#コード
-
Expo環境で以下の実装を行い、iOSシミュレータでの表示を確認しました
-
Androidは実機でExpo経由で実行しました
-
参考にした手順
【React Native】「react-native-maps」ライブラリを使ってOpenStreetMapを表示する
https://cpoint-lab.co.jp/article/202011/17919/
javascript
1import * as React from 'react'; 2import MapView, {UrlTile} from 'react-native-maps'; 3import { StyleSheet, Text, View, Dimensions } from 'react-native'; 4 5export default function App() { 6 return ( 7 <View style={styles.container}> 8 <MapView 9 style={styles.map} 10 region={緯度軽度情報を設置} 11 > 12 <UrlTile 13 urlTemplate={"http://c.tile.openstreetmap.org/{z}/{x}/{y}.jpg"} 14 maximumZ={19} 15 mapType={'none'} 16 /> 17 </View> 18 ); 19} 20 21const styles = StyleSheet.create({ 22 container: { 23 flex: 1, 24 backgroundColor: '#fff', 25 alignItems: 'center', 26 justifyContent: 'center', 27 }, 28 map: { 29 width: Dimensions.get('window').width, 30 height: Dimensions.get('window').height, 31 }, 32});
発生している事象
- Androidでは、標準のGoogleMapであれば表示されるが、
mapType={'none'}
に変更し、Open Street Viewの地図へ変更しようとすると、タイルが全く表示されない状態となります
調べてわかっていること
- OSMのポリシー変更により、OSMのTileサーバからTileがAndroidからはできなくなり、現在はTileサーバを自前で用意することが推奨されているということがわかりました
https://github.com/react-native-maps/react-native-maps/issues/3941
OSMのポリシー変更
https://operations.osmfoundation.org/policies/tiles/
https://switch2osm.org/serving-tiles/
質問したいこと
- Open Street Viewで同じような問題に対処された方がいらっしゃいましたら、どのような対処、代替策を行われたのか教えてください
- switch2osmのようにタイルサーバの設置を行なったか、WebView経由などで対処をしたか、別の地図APIへ乗り換えたか、どのように対処をされたか、参考までに教えてください。
あなたの回答
tips
プレビュー