【问题标题】:how to show a pop-up/overlay window如何显示弹出/覆盖窗口
【发布时间】:2021-12-20 08:23:26
【问题描述】:

我正在尝试显示包含鼠标单击位置的叠加层。我参考了openlayers官方网页here中的示例 但是当我运行代码时,会显示 console.log 消息,显示鼠标单击位置的坐标,但覆盖或弹出窗口永远不会出现。 请让我知道下面发布的代码中缺少什么

代码

private visualisePolygonsAsMVTTiles(siteID,threshold,visualizationOperationID) {
    /**
     * Elements that make up the popup.
     */
    const container = document.getElementById('popup');
    const content = document.getElementById('popup-content');
    const closer = document.getElementById('popup-closer');
    /**
     * Create an overlay to anchor the popup to the map.
     */
    const overlay = new Overlay({
        element: container,
        autoPan: true,
        autoPanAnimation: {
        duration: 250,
        },
    });
    closer.onclick = function () {
        overlay.setPosition(undefined);
        closer.blur();
        return false;
    };
    this.map.on('singleclick', function (evt) {
        console.log(evt.coordinate)
        const coordinate = evt.coordinate;
        const hdms = toStringHDMS(toLonLat(coordinate));
        
        content.innerHTML = '<p>You clicked here:</p><code>' + hdms + '</code>';
        overlay.setPosition(coordinate);
    });

.css

.ol-popup {
  position: absolute;
  background-color: white;
  box-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: 280px;
}
.ol-popup:after, .ol-popup:before {
  top: 100%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
}
.ol-popup:after {
  border-top-color: white;
  border-width: 10px;
  left: 48px;
  margin-left: -10px;
}
.ol-popup:before {
  border-top-color: #cccccc;
  border-width: 11px;
  left: 48px;
  margin-left: -11px;
}
.ol-popup-closer {
  text-decoration: none;
  position: absolute;
  top: 2px;
  right: 8px;
}
.ol-popup-closer:after {
  content: "✖";
}

【问题讨论】:

    标签: openlayers openlayers-3 openlayers-6 openlayers-5 angular-openlayers


    【解决方案1】:

    我发现了。我只是没有将叠加层添加到地图中,如下所示:

            this.map.addOverlay(overlay)
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-08-30
      相关资源
      最近更新 更多