MapViewComponent
MapConductor は、アプリケーションで地図を表示するための基盤となる、地図SDK固有の地図ビューコンポーネントを提供します。各地図SDKには独自の実装がありますが、一貫した API インターフェースを維持しています。
MapViewContainerのアーキテクチャ
Section titled “MapViewContainerのアーキテクチャ”MapConductor は、地図SDKが提供するMapViewをラップしたMapViewContainerコンポーネントを提供します。
MapViewComponentは概念で、実際に使うときには地図SDKごとに提供される XxxMapView (例:GoogleMapView, MapBoxView など)を使用します。
MapViewComponentの中にはMapViewを制御するためのコントロールが内包されています。このコントロールはMapViewStateInterfaceを通じて操作することができます。

地図SDK固有のコンポーネント
Section titled “地図SDK固有のコンポーネント”MapConductor は複数の地図SDKをサポートしており、それぞれに専用のコンポーネントがあります。 地図上には通常、複数のオブジェクト(マーカーやポリラインなど)が配置されるため、イベントコールバックは各オーバーレイの State に設定します。
各地図SDK固有の特殊なイベントコールバックについては、v1.1.3 ではまだサポートされていません。
GoogleMapView( state: GoogleMapViewState, modifier: Modifier = Modifier, onMapLoaded: OnMapLoadedHandler? = null, onMapClick: OnMapEventHandler? = null, onCameraMoveStart: OnCameraMoveHandler? = null, onCameraMove: OnCameraMoveHandler? = null, onCameraMoveEnd: OnCameraMoveHandler? = null, content: (@Composable () -> Unit)? = null)MapboxMapView( state: MapboxViewState, modifier: Modifier = Modifier, onMapLoaded: OnMapLoadedHandler? = null, onMapClick: OnMapEventHandler? = null, onCameraMoveStart: OnCameraMoveHandler? = null, onCameraMove: OnCameraMoveHandler? = null, onCameraMoveEnd: OnCameraMoveHandler? = null, content: (@Composable () -> Unit)? = null)ArcGISMapView( state: ArcGISMapViewState, modifier: Modifier = Modifier, onMapLoaded: OnMapLoadedHandler? = null, onMapClick: OnMapEventHandler? = null, onCameraMoveStart: OnCameraMoveHandler? = null, onCameraMove: OnCameraMoveHandler? = null, onCameraMoveEnd: OnCameraMoveHandler? = null, content: (@Composable () -> Unit)? = null)HereMapView( state: HereViewState, modifier: Modifier = Modifier, onMapLoaded: OnMapLoadedHandler? = null, onMapClick: OnMapEventHandler? = null, onCameraMoveStart: OnCameraMoveHandler? = null, onCameraMove: OnCameraMoveHandler? = null, onCameraMoveEnd: OnCameraMoveHandler? = null, content: (@Composable () -> Unit)? = null)MapLibreMapView( state: MapLibreViewState, modifier: Modifier = Modifier, onMapLoaded: OnMapLoadedHandler? = null, onMapClick: OnMapEventHandler? = null, onCameraMoveStart: OnCameraMoveHandler? = null, onCameraMove: OnCameraMoveHandler? = null, onCameraMoveEnd: OnCameraMoveHandler? = null, content: (@Composable () -> Unit)? = null)共通パラメータ
Section titled “共通パラメータ”すべての地図ビューコンポーネントは以下のパラメータを共有しています:
コアパラメータ
Section titled “コアパラメータ”modifier: スタイリングとレイアウトのための Compose modifierstate: 地図SDK固有の地図ビュー状態実装content: 地図オーバーレイ(マーカー、円など)を含む Composable コンテンツ
イベントハンドラ
Section titled “イベントハンドラ”onMapLoaded: 地図の読み込みが完了したときに呼び出されますonMapClick: ユーザーが地図をタップしたときに呼び出されますonCameraMoveStart:moveCameraTo(dst, durationMs)を開始するときに呼び出されます。ユーザーが地図をインタラクティブに動かしたときには呼び出されません。onCameraMove: 地図を表示するカメラが移動したときに呼び出されます。onCameraMoveEnd: 地図を表示するカメラの移動が修了したときに呼び出されます。
高度なパラメータ
Section titled “高度なパラメータ”sdkInitialize: SDK固有の初期化プロセス
@Composablefun GoogleMapsExample() { val mapViewState = rememberGoogleMapViewState()
GoogleMapView( state = mapViewState, onMapClick = { geoPoint -> println("Map clicked at: ${geoPoint.latitude}, ${geoPoint.longitude}") } ) { Marker( position = GeoPoint.fromLatLong(37.7749, -122.4194), icon = DefaultIcon(label = "SF"), extra = "San Francisco", onClick = { markerState -> println("Marker clicked: ${markerState.extra}") } )
Circle( center = GeoPoint.fromLatLong(37.7749, -122.4194), radiusMeters = 1000, strokeColor = Color.Blue, fillColor = Color.Blue.copy(alpha = 0.3f) ) }}
@Composablefun MapboxExample() { val center = GeoPoint.fromLatLong(37.7749, -122.4194) val camera = MapCameraPosition(position = center, zoom = 13) val mapViewState = rememberMapboxMapViewState(cameraPosition = camera)
MapboxMapView( state = mapViewState, onMapClick = { geoPoint -> println("Map clicked at: ${geoPoint.latitude}, ${geoPoint.longitude}") } ) { Marker( position = GeoPoint.fromLatLong(37.7749, -122.4194), icon = DefaultIcon(label = "MB"), extra = "Mapbox marker" )
Polyline( points = listOf( GeoPoint.fromLatLong(37.7749, -122.4194), GeoPoint.fromLatLong(37.7849, -122.4094), GeoPoint.fromLatLong(37.7949, -122.3994) ), strokeColor = Color.Red, strokeWidth = 3.dp ) }}
地図SDKに依存しないパターン
Section titled “地図SDKに依存しないパターン”各地図SDKには特定のコンポーネントが必要ですが、地図SDKに依存しないコンテンツを作成できます:
@Composablefun MapContent() { Marker( position = GeoPoint.fromLatLong(37.7749, -122.4194), icon = DefaultIcon(label = "Point"), extra = "Common marker" )
Circle( center = GeoPoint.fromLatLong(37.7749, -122.4194), radiusMeters = 500, strokeColor = Color.Green, fillColor = Color.Green.copy(alpha = 0.2f) )}
@Composablefun GoogleMapsScreen() { val state = rememberGoogleMapViewState() GoogleMapView(state = state) { MapContent() // 再利用可能なコンテンツ }}
@Composablefun MapboxScreen() { val state = remember { MapboxViewState() } MapboxMapView(state = state) { MapContent() // 同じコンテンツ、異なる地図SDK }}高度なイベント処理
Section titled “高度なイベント処理”@Composablefun AdvancedMapExample() { val center = GeoPoint.fromLatLong(37.7749, -122.4194) val mapViewState = rememberGoogleMapViewState( cameraPosition = MapCameraPosition(position = center, zoom = 13) )
var clickedPoint by remember { mutableStateOf<GeoPointInterface?>(null) } val onMarkerClick: (MarkerState) -> Unit = { markerState -> println("マーカーがクリックされました: ${markerState.extra}") }
GoogleMapView( state = mapViewState, onMapLoaded = { println("地図の読み込みが完了しました") }, onMapClick = { geoPoint -> clickedPoint = geoPoint println("地図がクリックされました: ${geoPoint.latitude}, ${geoPoint.longitude}") }, onCameraMoveStart = { println("カメラの移動が開始されました") }, onCameraMove = { cameraPosition -> println("カメラ位置: ${cameraPosition.position}") }, onCameraMoveEnd = { println("カメラの移動が終了しました") } ) { // マーカーと円を表示 Marker( position = center, icon = DefaultIcon(label = "中心", fillColor = Color.Red), extra = "中心のマーカー", onClick = onMarkerClick )
Circle( center = center, radiusMeters = 1000, strokeColor = Color.Blue, fillColor = Color.Blue.copy(alpha = 0.2f) )
// クリックされた位置にマーカーを表示 clickedPoint?.let { point -> Marker( position = point, icon = DefaultIcon(label = "クリック", fillColor = Color.Green), extra = "クリックされた位置", onClick = onMarkerClick ) } }}地図SDKの違い
Section titled “地図SDKの違い”API は全地図SDKで一貫していますが、以下の点で違いがあります:
サポートされる機能
Section titled “サポートされる機能”- GroundImage: 現在 Google Maps と ArcGIS でサポートされています
- マーカーアニメーション: Google Maps と Mapbox で利用可能
- カスタムスタイリング: 各地図SDKには異なる地図スタイルオプションがあります
パフォーマンス特性
Section titled “パフォーマンス特性”- Google Maps: 一般的な使用に優れており、優れたマーカーパフォーマンス
- Mapbox: カスタムスタイリングと大規模データセットに最適
- HERE Maps: ロケーションサービス統合に最適化
- ArcGIS: GIS およびエンタープライズアプリケーションに最適
プラットフォーム統合
Section titled “プラットフォーム統合”各地図SDKには、API キー、パーミッション、プラットフォームセットアップに関して異なる要件がある場合があります。地図SDK固有のセットアップについては、初期化ドキュメントを参照してください。
ベストプラクティス
Section titled “ベストプラクティス”- 適切な地図SDKを選択: アプリの特定のニーズに基づいて選択してください(スタイリング、パフォーマンス、機能)
- 一貫した状態管理: 地図SDKに関係なく、同じ状態パターンを使用してください
- 再利用可能なコンテンツ: 可能な限り地図SDKに依存しない Composable コンテンツを作成してください
- イベント処理: より良いユーザーエクスペリエンスのために包括的なイベント処理を実装してください
- エラー処理: 常に初期化の失敗を処理し、フォールバック UI を提供してください
- パフォーマンス: 大量のマーカーに対してはカスタムレンダリング戦略の使用を検討してください
- テスト: 互換性を確保するために、複数の地図SDKでアプリケーションをテストしてください