繁体   English   中英

如何在Openlayer的地图上添加标记?

[英]How to add a marker on a map on openlayer?

我正在使用openlayer,但无法在地图上添加带有经/纬度的标记。 您能否在我的代码示例下方向我指出正确的方向:

let map = new ol.Map({
  target: 'map',
  layers: [
    new ol.layer.Tile({
      source: new ol.source.OSM()
    })
  ],
  view: new ol.View({
    center: ol.proj.transform([37.41, 8.82], 'EPSG:4326', 'EPSG:3857'),
    zoom: 4
  })
})
let layerCloud = new ol.layer.Tile({
  source: new ol.source.XYZ({
    url: api.mapTemperature()
  })
})
map.addLayer(layerCloud)

您可以通过添加新的Vector图层(其样式设置为显示图钉的图像)来添加标记。 以下代码将在地图中心添加一个图钉。

const center = map.getView().getCenter();
const pinnedLocation = ol.proj.transform(center, 'EPSG:3857', 'EPSG:4326');
const feature = new ol.Feature(new ol.geom.Point(center));
const pinLayer = new ol.layer.Vector ({
  source: new ol.source.Vector ({
    features: [feature]
  }),
  style: new ol.style.Style ({
    image: new ol.style.Icon({
      src: 'http://openlayers.org/en/v3.8.2/examples/data/icon.png'
    })
  })
});
map.addLayer (pinLayer);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM