Version: 2.2.1

Map

地图。相关api Taro.createMapContext。

参考文档

类型

ComponentType<MapProps>

示例代码

class App extends Component {
onTap () {}
render () {
return (
<Map onClick={this.onTap} />
)
}
}

MapProps

参数类型默认值必填说明
longitude
number
中心经度
latitude
number
中心纬度
scale
number
16
缩放级别,取值范围为3-20
markers
marker[]
标记点
covers
any[]
标记点
不推荐: 即将移除,请使用 markers
polyline
polyline[]
路线
circles
circle[]
controls
control[]
控件(即将废弃,建议使用 cover-view 代替)
不推荐使用
includePoints
point[]
缩放视野以包含所有给定的坐标点
showLocation
boolean
false
显示带有方向的当前定位点
polygons
polygon[]
多边形
subkey
string
个性化地图使用的 key
layerStyle
number
1
个性化地图配置的 style,不支持动态修改
rotate
number
0
旋转角度,范围 0 ~ 360, 地图正北和设备 y 轴角度的夹角
skew
number
0
倾斜角度,范围 0 ~ 40 , 关于 z 轴的倾角
enable3D
boolean
false
展示 3D 楼块
showCompass
boolean
false
显示指南针
showScale
boolean
false
显示比例尺
enableOverlooking
boolean
false
开启俯视
enableZoom
boolean
true
是否支持缩放
enableScroll
boolean
true
是否支持拖动
enableRotate
boolean
false
是否支持旋转
enableSatellite
boolean
false
是否开启卫星图
enableTraffic
boolean
false
是否开启实时路况
setting
MapProps | Object
配置项

提供 setting 对象统一设置地图配置。同时对于一些动画属性如 rotate 和 skew,通过 setData 分开设置时无法同时生效,需通过 settting 统一修改。
onTap
BaseEventOrigFunction<any>
点击地图时触发
onMarkerTap
BaseEventOrigFunction<onMarkerTapEventDetail>
点击标记点时触发,e.detail = {markerId}
onLabelTap
BaseEventOrigFunction<onLabelTapEventDetail>
点击label时触发,e.detail = {markerId}
onControlTap
BaseEventOrigFunction<onControlTapEventDetail>
点击控件时触发,e.detail = {controlId}
onCalloutTap
BaseEventOrigFunction<onCalloutTapEventDetail>
点击标记点对应的气泡时触发,e.detail = {markerId}
onUpdated
BaseEventOrigFunction<any>
在地图渲染更新完成时触发
onRegionChange
BaseEventOrigFunction<onRegionChangeEventDetail>
视野发生变化时触发
onPoiTap
BaseEventOrigFunction<onPoiTapEventDetail>
点击地图poi点时触发,e.detail = {name, longitude, latitude}
includePadding
{ left: string | number; right: string | number; top: string | number; bottom: string | number; }
视野在地图 padding 范围内展示
groundOverlays
any[]
覆盖物,自定义贴图
tileOverlay
any[]
覆盖物,网格贴图
optimize
boolean
开启 optimize 模式后,无需再监听 onRegionChange 来获取并设置新的 scale 值以保证地图不会再回到原来的缩放比例。

API 支持度

API微信小程序百度小程序支付宝小程序H5React Native
MapProps.longitude✔️✔️✔️
MapProps.latitude✔️✔️✔️
MapProps.scale✔️✔️(取值范围为4-21)✔️(取值范围为5-18)
MapProps.markers✔️✔️✔️
MapProps.covers✔️
MapProps.polyline✔️✔️✔️
MapProps.circles✔️✔️✔️
MapProps.controls✔️✔️✔️
MapProps.includePoints✔️✔️✔️
MapProps.showLocation✔️✔️✔️
MapProps.polygons✔️✔️✔️
MapProps.subkey✔️
MapProps.layerStyle✔️
MapProps.rotate✔️
MapProps.skew✔️
MapProps.enable3D✔️✔️
MapProps.showCompass✔️✔️
MapProps.showScale✔️
MapProps.enableOverlooking✔️✔️
MapProps.enableZoom✔️✔️
MapProps.enableScroll✔️✔️
MapProps.enableRotate✔️✔️
MapProps.enableSatellite✔️
MapProps.enableTraffic✔️
MapProps.setting✔️✔️
MapProps.onTap✔️✔️✔️
MapProps.onMarkerTap✔️✔️✔️
MapProps.onLabelTap✔️
MapProps.onControlTap✔️✔️✔️
MapProps.onCalloutTap✔️✔️✔️
MapProps.onUpdated✔️✔️
MapProps.onRegionChange✔️✔️✔️
MapProps.onPoiTap✔️✔️
MapProps.includePadding✔️
MapProps.groundOverlays✔️
MapProps.tileOverlay✔️
MapProps.optimize✔️

marker

标记点用于在地图上显示标记的位置

参数类型必填说明备注
id
number
标记点id
marker 点击事件回调会返回此id。建议为每个 marker 设置上 Number 类型 id,保证更新 marker 时有更好的性能。
latitude
number
纬度
浮点数,范围 -90 ~ 90
longitude
number
经度
浮点数,范围 -180 ~ 180
title
string
标注点名
点击时显示,callout 存在时将被忽略
zIndex
number
显示层级
iconPath
string
显示的图标
项目目录下的图片路径,支持相对路径写法,以'/'开头则表示相对小程序根目录;也支持临时路径和网络图片
rotate
number
旋转角度
顺时针旋转的角度,范围 0 ~ 360,默认为 0
alpha
number
标注的透明度
默认1,无透明,范围 0 ~ 1
width
string | number
标注图标宽度
默认为图片实际宽度
height
string | number
标注图标高度
默认为图片实际高度
callout
callout
自定义标记点上方的气泡窗口
支持的属性见下表,可识别换行符。
label
label
为标记点旁边增加标签
支持的属性见下表,可识别换行符。
anchor
{ x: number; y: number; }
经纬度在标注图标的锚点,默认底边中点{x, y},x表示横向(0-1),y表示竖向(0-1)。{x: .5, y: 1} 表示底边中点
ariaLabel
string
无障碍访问,(属性)元素的额外描述

callout

marker 上的气泡 callout

参数类型说明
content
string
文本
color
string
文本颜色
fontSize
number
文字大小
borderRadius
number
边框圆角
borderWidth
number
边框宽度
borderColor
string
边框颜色
bgColor
string
背景色
padding
number
文本边缘留白
display
"BYCLICK" | "ALWAYS"
'BYCLICK':点击显示; 'ALWAYS':常显
textAlign
"left" | "right" | "center"
文本对齐方式。有效值: left, right, center

label

marker 上的气泡 label

参数类型说明
content
string
文本
color
string
文本颜色
fontSize
number
文字大小
x
number
label的坐标(废弃)
不推荐使用
y
number
label的坐标(废弃)
不推荐使用
anchorX
number
label的坐标,原点是 marker 对应的经纬度
anchorY
number
label的坐标,原点是 marker 对应的经纬度
borderWidth
number
边框宽度
borderColor
string
边框颜色
borderRadius
number
边框圆角
bgColor
string
背景色
padding
number
文本边缘留白
textAlign
"left" | "right" | "center"
文本对齐方式。有效值: left, right, center

polyline

指定一系列坐标点,从数组第一项连线至最后一项

参数类型必填说明备注
points
point[]
经纬度数组[{latitude: 0, longitude: 0}]
color
string
线的颜色
十六进制
width
number
线的宽度
dottedLine
boolean
是否虚线
默认 false
arrowLine
boolean
带箭头的线
默认 false,开发者工具暂不支持该属性
arrowIconPath
string
更换箭头图标
在 arrowLine 为 true 时生效
borderColor
string
线的边框颜色
borderWidth
number
线的厚度

polygon

指定一系列坐标点,根据 points 坐标数据生成闭合多边形

参数类型必填说明备注
points
point[]
经纬度数组[{latitude: 0, longitude: 0}]
strokeWidth
number
描边的宽度
strokeColor
string
描边的颜色
十六进制
fillColor
string
填充颜色
十六进制
zIndex
number
设置多边形Z轴数值

circle

在地图上显示圆

参数类型必填说明备注
latitude
number
纬度
浮点数,范围 -90 ~ 90
longitude
number
经度
浮点数,范围 -180 ~ 180
color
string
描边的颜色
十六进制
fillColor
string
填充颜色
十六进制
radius
number
半径
strokeWidth
number
描边的宽度

control

在地图上显示控件,控件不随着地图移动。即将废弃,请使用 cover-view

参数类型必填说明备注
id
number
控件id
在控件点击事件回调会返回此id
position
point
控件在地图的位置
控件相对地图位置
iconPath
string
显示的图标
项目目录下的图片路径,支持本地路径、代码包路径
clickable
boolean
是否可点击
默认不可点击

point

参数类型说明
longitude
number
经度
latitude
number
纬度

position

参数类型默认值说明
left
number
0
距离地图的左边界多远
top
number
0
距离地图的上边界多远
width
number
图片宽度
控件宽度
height
number
图片宽度
控件高度

onMarkerTapEventDetail

参数类型
markerId
string | number

onLabelTapEventDetail

参数类型
markerId
string | number

onControlTapEventDetail

参数类型
controlId
string | number

onCalloutTapEventDetail

参数类型
markerId
string | number

onRegionChangeEventDetail

参数类型说明备注
type
string
视野变化开始、结束时触发
视野变化开始为begin,结束为end
causedBy
string
导致视野变化的原因
拖动地图导致(drag)、缩放导致(scale)、调用接口导致(update)
detail
regionChangeDetail
视野改变详情

regionChangeDetail

参数类型说明
rotate
number
旋转角度
skew
number
倾斜角度

onPoiTapEventDetail

参数类型
name
string
longitude
number
latitude
number

API 支持度

API微信小程序百度小程序支付宝小程序H5React Native
Map✔️✔️✔️