码迷,mamicode.com
首页 > 其他好文 > 详细

Leaflet:Marker、Popup类

时间:2020-11-17 12:41:43      阅读:7      评论:0      收藏:0      [点我收藏+]

标签:prope   时间   set   bsp   图片   标记   http   大小   机制   

Marker、Popup、Tooltip类都是继承自Layer类:Event与Layer

 

Marker

技术图片

1、用例

L.marker([41,123]).addTo(map);

2、实例化

L.marker(<LatLng> latlng , <Marker options> options) 

3、参数

icon //Icon实例,作为该Marker的显示图标。不写则用默认Marker的Icon,即我们之前给出的那个Marker图像
keyboard //是否用键盘标记该Marker,如果是true,你可以通过按回车键实现点击该Marker的功能,默认true
title //一个显示在Marker上的Browser Tooltip,鼠标在Marker上悬停一段时间可以看到
zIndexOffset //标识Marker的zIndex,如果一个两个Marker相距很近,则在地图上表示时,高zIndex的Marker会覆盖在低zIndex的上边
opcity //透明度 0-1
riseOnHover //默认false,如果设置为true,那么当你鼠标移到该Marker上时它会覆盖在其他Marker上边。但是当移开鼠标后,它跟其他Marker的位置关系还是遵从于zIndex的大小
riseOffset //riseOnHover的机制是,鼠标悬停的Marker的zIndex加上riseOffset得到一个新的zIndex,鼠标悬停处的Marker会覆盖在所有小于该新的zIndex的Marker之上;默认250

//与拖动(Draggable)相关的参数
draggable //是否可拖动,默认false
autoPan //当拖动该Marker到地图边缘时,地图是否发生平移(以使可以把该Marker拖动到更远的范围),默认false
autoPanPadding //当Marker离地图边缘多近时,地图开始平移
autoPanSpeed //平移速度(单位pixel)

4、方法

除了可以用继承而来的Layer的方法外,Marker还有一些特有的方法:

getLatLng() //返回Marker的地理坐标,LatLng类型
setLatLng(<LatLng>latlng) //改变Marker位置到给定坐标
serZIndexOffset(n) //改变该Marker的zIndex offset
setOpacity(n) //改变透明度

5、Properties

Handler

dragging //类型是Handler,是Marker进行dragging时的Handler。

例子:

marker.dragging.disable();//不允许Marker进行拖动

 

Popup

Map.openPopup()一次打开一个Popup,用Map.addLayer()可以打开任意多的Popup。

如果仅仅想为一个Layer对象,比如Marker或者Polygon等添加一个Popup并且打开,那很简单:

marker.bindPopup(Content).openPopup();

下面这个例子,是通过创建Popup对象的方式显示Popup:

var popup =L.popup()
                .setLatLng(latlng)
                .setContent(Content)
                .openOn(map);

 

1、实例化

L.popup(options? )

2、参数

maxWidth //最大宽度,单位pixel
minWidth
maxHeight
autoPan //默认true,如果设置为false,那么在Map将不会把视角移动到该Popup处
keepInView //默认false,如果设置为true,那么你拖动地图时没办法把该popup移动到视图以外。
//但是关上该Popup后就可以拖动了,所以该参数只是保证Popup本身始终在视图以内
//如果之前有一个Popup已经打开,请保证它们在同一个视图内,否则会错误
closeButton //默认true,如果设置为false,那么popup右上角将不会显示关闭的× autoClose //默认true,如果设置为false,那么在打开另一个Popup时该Popup将不会关闭

3、方法

getLatLng() //返回地理坐标
setLatLng(<LatLng>latlng)
getContent()
setContent(Content)
update()     //更新该Popup的内容、布局以及位置
bringToFront() //将该Popup覆盖显示在其他Popup之前
bringToBack() //将该Popup显示在其他Popup之后
openOn(<Map> map)//在map上显示该Popup同时关闭之前的Popup,效果等同于map.openPopup(popup)

4、补充

三种打开Popup的方法:

//假设该Popup对象为popup
//1、Map.openPopup
map.openPopup(popup)

//2、popup
popup.addTo(leafletMap)
popup.openOn(leafletMap)//关闭之前所有的Popup

//3、Layer.openPopup
var marker =L.marker(latlng).bindPopup(Content).addTo(leafletMap);
marker.openPopup();

只有popup.openOn(leafletMap)会关闭之前的所有Popup,而剩下三种只有在点击时才会关闭之前的Popup

Leaflet:Marker、Popup类

标签:prope   时间   set   bsp   图片   标记   http   大小   机制   

原文地址:https://www.cnblogs.com/ShineLeBlog/p/13959247.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!