每一个地图应用都应该有一些工具方便用户控制地图的行为,比如缩放,全屏,坐标控件等等,在 OpenLayers 中怎么添加这些工具呢?下面我给大家介绍一下 OpenLayers 中包含的控件种类,并介绍其使用方法。对控件的定制化,和对 OpenLayers 增加控件和优化控件等超出了本文范围。
OpenLayers 中的控件是由 control
类定义的,这是一个虚基类,不负责实例化特定的控件,它的主要作用是让其他具体的种类的控件类实现继承。OpenLayers 中包含的控件有:
下面我们来分别介绍各种控件的使用方法。
地图全屏控件,该控件提供一个全屏按钮,当点击的时候,地图充满整个屏幕(注意是整个屏幕,而不是整个浏览器窗口);当在全屏模式时,在屏幕的右上角会出现一个退出按钮,用于退出全屏模式,同时按 Esc
按钮也可以退出全屏模式。在 map 对象中添加如下代码:
controls: ol.control.defaults().extend([
new ol.control.FullScreen()
]),
刷新浏览器运行代码,结果如下图:
点击全屏后,全屏按钮变成退出按钮,点击即可退出全屏模式,同时点击 ESC
也可以退出全屏模式:
鼠标位置控件,用于显示鼠标指针 2D 坐标,默认情况下,它显示的是地图的 view 对象中设置的投影,但是可以修改为任意投影。鼠标位置控件是加载在地图右上角的位置,如,我们在以上全屏控件的基础上加如下代码:
controls: ol.control.defaults().extend([
new ol.control.FullScreen(),
new ol.control.MousePosition()
]),
刷新浏览器,得到结果截图如下:
有两种解决方法,一种是修改 ol.control.MousePosition
的可选参数的默认值;二是覆盖其默认的 CSS 样式类,这种方法我们后面会讲到。
这里我们用第一种方法做例子,控件的可选参数如下:
/**
* @typedef {{className: (string|undefined),
* coordinateFormat: (ol.CoordinateFormatType|undefined),
* projection: ol.proj.ProjectionLike,
* render: (function(ol.MapEvent)|undefined),
* target: (Element|undefined),
* undefinedHTML: (string|undefined)}}
* @api stable
*/
重要的参数如下:
ol-mouse-position
,也就是默认动态生成的;知道用法后,我们就先定义将要显示坐标的 HTML 元素:
<div id="mouse-position" class="mouse-position-wrapper">
<div class="custom-mouse-position">div>
div>
我们要将该 div
元素悬浮在地图之上,而默认情况下,map 的 z-index
值很大,要悬浮在 map 之上,就要定义更大的 z-index
。定义如下:
.mouse-position-wrapper{
width:300px;
height:29px;
color:#FFFFFF;
position:absolute;
right:20px;
bottom:6px;
z-index:999;
}
该CSS将控件放在右下角的位置,然后修改 MousePosition
对象:
controls: ol.control.defaults().extend([
new ol.control.FullScreen(),
new ol.control.MousePosition({
coordinateFormat: ol.coordinate.createStringXY(4),
projection: 'EPSG:4326',
className: 'custom-mouse-position',
target: document.getElementById('mouse-position')
})
]),
再次运行代码,得到如下效果:
全局地图控件,显示当前视口中的地图位于全局地图的哪一部分,可选的参数如下:
/**
* @typedef {{collapsed: (boolean|undefined),
* collapseLabel: (string|Node|undefined),
* collapsible: (boolean|undefined),
* label: (string|Node|undefined),
* layers: (Array.<ol.layer.Layer>|ol.Collection|undefined),
* render: (function(ol.MapEvent)|undefined),
* target: (Element|undefined),
* tipLabel: (string|undefined)}}
* @api
*/
参数的意义为:
true
;overviewmapcontrol
收缩为图标按钮时,显示在图标按钮上的文字或者符号,默认为 »
;overviewmapcontrol
针对的图层,默认情况下为所有图层;overviewmapcontrol
重新绘制时,调用的函数;HTML
元素;以上参数都为可选,添加如下代码:
new ol.control.OverviewMap({})
默认情况下,控件为收缩状态,点击即可打开,打开后如下图所示:
地图旋转控件,主要作用是当地图角度不为 0 时,默认显示,点击,使地图恢复旋转角度为 0。可选参数如下:
/**
* @typedef {{duration: (number|undefined),
* className: (string|undefined),
* label: (string|Node|undefined),
* tipLabel: (string|undefined),
* target: (Element|undefined),
* render: (function(ol.MapEvent)|undefined),
* autoHide: (boolean|undefined)}}
* @api stable
*/
参数的意义为:
240
;ol-rotate
;⇧
; Reset rotation
;ID
;true
,也就是默认隐藏。默认情况下,该控件不会显示;当地图旋转角度不为 0 时,才会显示,原因是该控件为地图默认添加控件。当该控件显示时候,其默认的位置和全屏控件重合,所以如果想要显示该按钮,那么全屏按钮就会被覆盖。
有两种方法可以解决该问题:
mousepositioncontrol
的方式,将其默认位置放于其它地方;这里采用第二种方法,在自己的 CSS 样式表中添加如下代码(因为自己的CSS文件样式优先级比外部链接引入的样式优先级高):
/* rewrite the default css in `ol.css` */
.ol-rotate{
right:40px;
}
添加如下代码:
new ol.control.Rotate({
autoHide:false
})
比例尺控件,显示当前地图的分辨率,也就是比例尺,默认的位置和 overviewmap control
位置重合,要移动位置避免覆盖,同样覆盖默认样式:
/* rewrite the default css in `ol.css` */
.ol-scale-line {
#left:100px;
}
添加代码:
new ol.control.ScaleLine({ }),
缩放控件,包含两个按钮,一个放大,一个缩小,是默认加载的控件之一,默认的 CSS
样式类分别为 .ol-zoom-in
和.ol-zoom-out
。
缩放条控件,主要显示当前的分辨率对应的刻度,给予一个直观的显示,其默认的条没有刻度,如果需要有刻度的,需要自己定制。可选的参数有:
/**
* @typedef {{className: (string|undefined),
* duration: (number|undefined),
* maxResolution: (number|undefined),
* minResolution: (number|undefined),
* render: (function(ol.MapEvent)|undefined)}}
* @api
*/
其它的选项类似于以上的控件,添加该控件到地图中:
new ol.control.ZoomSlider({ }),
效果如下:
缩放到图层控件,将地图缩放到视口可以容纳整个地图的合适尺度,可选的参数如下:
/**
* @typedef {{className: (string|undefined),
* target: (Element|undefined),
* label: (string|Node|undefined),
* tipLabel: (string|undefined),
* extent: (ol.Extent|undefined)}}
* @api stable
*/
这个控件也没有什么特殊的选项,除了 extent
,表示缩放到范围的大小。需要注意的是该控件位置和 zoomslidercontrol
位置会有部分重叠,同样,我们需要覆盖zoomslidercontrol
的样式类: .ol-zoomslider
:
.ol-zoomslider{
top:100px;
left: 9px;
}
添加如下代码:
new ol.control.ZoomToExtent({ })
效果如下图:
我们看一下点击之前和之后的效果对比:
点击之后其实已经到了合适的尺寸,但是地图配置为连贯显示,也就是左右不间断,重复拼接在一起,所以会有这样的效果。
到此为止,我们将 OpenLayers 3 的所有能用的控件都试了一遍,代码最后是这样的:
map = new ol.Map({ //init map
controls: ol.control.defaults().extend([
new ol.control.FullScreen(),
new ol.control.MousePosition({
coordinateFormat: ol.coordinate.createStringXY(4),
projection: 'EPSG:4326',
className: 'custom-mouse-position',
target: document.getElementById('mouse-position')
}) ,
new ol.control.OverviewMap({ }),
new ol.control.Rotate({
autoHide:false
}),
new ol.control.ScaleLine({ }),
new ol.control.ZoomSlider({ }),
new ol.control.ZoomToExtent({ })
]),
target: 'map',
layers: [
new ol.layer.Tile({
source: new ol.source.MapQuest({layer: 'sat'})
}),
vectorLayer
],
view: new ol.View({
center: ol.proj.transform([37.41, 8.82], 'EPSG:4326', 'EPSG:3857'),
zoom: 2
})
});
我们的地图也变成了这样:
这幅地图包含了缩放控件、缩放到图层控件、缩放标尺、地图全景控件、比例尺、旋转控件和全屏控件 7 个控件,希望对大家有帮助!
有问题,可以留言或者给我发邮件! [email protected]