我正在使用 jQuery 3.21 开发 Openlayers 5.13。我正在尝试div
在 openlayers 中的地图视口上放置一个 html 元素。这个元素应该有两个复选框来过滤掉地图上的一些内容。为此,我正在使用一个Overlay
实例。有两个问题:1)当我放大或缩小时,叠加层的大小会增加和减小,这不是我所期望的。我希望该叠加层(html div 元素)保持其大小。
2)我不能放弃弄清楚如何将叠加层放在右上角。覆盖是用position
我不知道要设置什么的属性实例化的。
我也不知道如果覆盖是我应该寻求在地图上显示一些静态元素。(我高度怀疑覆盖是正确的方式)
这是我的代码:css-
<style>
.ol-panel {
position: absolute;
background-color: white;
filter: drop-shadow(0 1px 4px rgba(0,0,0,0.2));
padding: 15px;
border-radius: 10px;
border: 1px solid #cccccc;
bottom: 12px;
left: -50px;
min-width: 100px;
}
</style>
html -
<div id="panel" class="ol-panel">
<div id="content">
<table>
<tr>
<td>
Ports <input type="checkbox">
</td>
</tr>
<tr>
<td>
Vessels <input type="checkbox">
</td>
</tr>
</table>
</div>
</div>
<div id="map"></div>
脚本 -
map = new ol.Map({
logo: 'false',
target: 'map',
layers: [new ol.layer.Tile({
title: 'OSM',
type: 'base',
visible: true,
source: new ol.source.OSM()
})],
view: new ol.View({
center: ol.proj.transform([17.813988, 43.342019], 'EPSG:4326', 'EPSG:3857'),
zoom: 3
})
});
panelDiv = document.getElementById("panel");
var panel = new ol.Overlay({
element: panelDiv,
stopEvent: false,
//offset:[0,0],
autoPan: true,
position: ol.proj.transform([82,80 ], 'EPSG:4326', 'EPSG:3857'),
positioning: 'top-right',
autoPanAnimation: {
duration: 250
}
});
map.addOverlay(panel);
这就是我所期待的,一个固定在某个位置的元素:
参考 - [ http://openlayers.org/en/latest/apidoc/module-ol_Overlay-Overlay.html]