React Native 高德地图组件的使用(react-native-amap3d)
高德地图组件 react-native-amap3d
基本使用
import {MapView} from 'react-native-amap3d'
render() {
return <MapView style={StyleSheet.absoluteFill}/>
}
data:image/s3,"s3://crabby-images/c3379/c33799236fb373674d0b639e782794d1778c7288" alt="img" |
设置地图状态
所谓的地图状态包括:中心坐标(coordinate)、缩放级别(zoomLevel)、倾斜度(titl)、旋转角度(rotation)、显示区域(region)。
通过 coordinate、zoomLevel 设置显示区域
<MapView
style={StyleSheet.absoluteFill}
coordinate=
zoomLevel={18}
tilt={45}
showsIndoorMap
/>
data:image/s3,"s3://crabby-images/44183/441830b85687042087ca99ef5105a532d8d9d6ff" alt="img" |
通过 region 设置显示区域
region 由中心坐标和经纬跨度组成,相对于 zoomLevel,region 可以精确控制显示边界。
<MapView
style={StyleSheet.absoluteFill}
region=
/>
data:image/s3,"s3://crabby-images/aa69e/aa69efa0e16f6369636706c6826147dbf590ac88" alt="img" |
动画过渡
通过属性控制的地图状态切换会显得比较生硬,如果希望地图状态切换是动画过渡的,可以使用 animateTo 方法。
<MapView ref={ref => this._mapView} style={StyleSheet.absoluteFill}/>
this._mapView.animateTo({
tilt: 45,
rotation: 90,
zoomLevel: 18,
coordinate: {
latitude: 39.97837,
longitude: 116.31363,
}
})
5种地图模式
目前高德地图支持5种地图模式:
- 标准(standard)
- 卫星(satellite)
- 导航(navigation)
- 公交(bus)
- 夜间(night)
<MapView
style={StyleSheet.absoluteFill}
zoomLevel={14}
mapType='satellite'
/>
data:image/s3,"s3://crabby-images/454bd/454bd50e5442da51ae27a45cb7c0ce5e269fd868" alt="img" |
卫星地图
data:image/s3,"s3://crabby-images/34bb9/34bb9f2b70369b6d683b8190bbcdf96bc9381d0f" alt="img" |
导航地图
data:image/s3,"s3://crabby-images/a1c3a/a1c3a4626885b6eafa437e448120294838fd491e" alt="img" |
公交地图
data:image/s3,"s3://crabby-images/e7d52/e7d52bae4fc143f98f0823af3dfbbf4b76012b3e" alt="img" |
夜间地图
地图事件
目前支持的地图事件有:
onPress
点按事件onLongPress
长按事件onLocation
定位事件onStatusChange
地图状态变化事件,变化过程会一直调用onStatusChangeComplete
地图状态变化结束事件
可以通过 event.nativeEvent
获取事件传递过来的数据
定位
通过 locationEnabled
控制是否启用定位,通过 locationInterval
和 distanceFilter
可以控制定位频次。
<MapView
style={StyleSheet.absoluteFill}
locationEnabled
locationInterval={10000}
distanceFilter={10}
onLocation={({nativeEvent}) =>
console.log(`${nativeEvent.latitude}, ${nativeEvent.longitude}`)}
/>
data:image/s3,"s3://crabby-images/5f133/5f133b56e3aad53be64e065170ba54d100e91d6d" alt="img" |
添加标注点
默认标注点
<MapView style={StyleSheet.absoluteFill}>
<Marker
active
title='这是一个标注点'
color='red'
description='Hello world!'
coordinate=
/>
</MapView>
data:image/s3,"s3://crabby-images/6ffd4/6ffd46790082b649194da2d389385399289c5de8" alt="img" |
可拖拽的标注点
<Marker
draggable
onDragEnd={({nativeEvent}) =>
console.log(`${nativeEvent.latitude}, ${nativeEvent.longitude}`)}
coordinate=
/>
自定义图片
可以通过 image
属性设置标注点图片,image
的值是图片资源的名字,对于 android 是 drawable,对于 ios 是 Images.xcassets。
<Marker
title='自定义图片'
image='flag'
coordinate=
/>
data:image/s3,"s3://crabby-images/18fe3/18fe3fbbd49021b4fe1bddc77062ef57c46f56b2" alt="img" |
自定义 View
除了 image
,还可以用 View 作为标注点,更自由的控制标注点的显示。
<Marker
active
title='自定义 View'
coordinate=
icon={() =>
<View style={style.marker}>
<Text style={style.markerText}>{(new Date()).toLocaleTimeString()}</Text>
</View>
}
/>
const style = StyleSheet.create({
marker: {
backgroundColor: '#009688',
alignItems: 'center',
borderRadius: 5,
padding: 5,
},
markerText: {
color: '#fff',
},
})
data:image/s3,"s3://crabby-images/ee022/ee022695b9f5bc484b3c95055a4f6c79ed8d917e" alt="img" |
自定义弹出窗口
<Marker
active
coordinate=
>
<View style={style.infoWindow}>
<Text>自定义弹出窗口</Text>
</View>
</Marker>
const style = StyleSheet.create({
infoWindow: {
backgroundColor: '#8bc34a',
padding: 10,
borderRadius: 10,
elevation: 4,
borderWidth: 2,
borderColor: '#689F38',
},
})
data:image/s3,"s3://crabby-images/f2c1f/f2c1ff196c20f5d366dbe899665a279ffdc428c9" alt="img" |
绘制线段
<MapView zoomLevel={10} style={StyleSheet.absoluteFill}>
<Polyline
width={10}
color='rgba(255, 0, 0, 0.5)'
coordinates={[
{
latitude: 40.006901,
longitude: 116.097972,
},
{
latitude: 40.006901,
longitude: 116.597972,
},
{
latitude: 39.706901,
longitude: 116.597972,
},
]}
/>
</MapView>
data:image/s3,"s3://crabby-images/5cf58/5cf58457156eb80f711dc657761d12b77d17b02b" alt="img" |
热力图
import {MapView, HeatMap} from 'react-native-amap3d'
_coordinates = (new Array(200)).fill(0).map(i => ({
latitude: 39.5 + Math.random(),
longitude: 116 + Math.random(),
}))
<MapView zoomLevel={9} style={StyleSheet.absoluteFill}>
<HeatMap
opacity={0.8}
radius={20}
coordinates={this._coordinates}/>
</MapView>
data:image/s3,"s3://crabby-images/20906/209069aeb50ba0b23ee051f8d73f09678f79437a" alt="img" |
海量点
批量添加的 Marker 数量过多会出现性能问题,这时可以考虑用海量点(MultiPoint)。
import {MapView, MultiPoint} from 'react-native-amap3d'
_points = Array(1000).fill(0).map(i => ({
latitude: 39.5 + Math.random(),
longitude: 116 + Math.random(),
}))
_onItemPress = point => Alert.alert(this._points.indexOf(point).toString())
<MapView zoomLevel={10} style={StyleSheet.absoluteFill}>
<MultiPoint
image='point'
points={this._points}
onItemPress={this._onItemPress}
/>
</MapView>
data:image/s3,"s3://crabby-images/b8325/b8325818ed809abce03d1c797bf84da4096b5153" alt="img" |
更多示例
请参考 examples。