[英]OpenLayers is not adding marker to my map
我有一個OpenLayers映射,並且使用JavaScript函數創建了它。 然后,我有一個按鈕,當按下該按鈕時,它將調用另一個JavaScript函數,該函數具有向地圖添加標記的代碼。
由於某種原因,未添加標記。
OpenLayers地圖創建代碼:
function init()
{
var map, baseLayer;
var options = {numZoomLevels: 5, isBaseLayer: true,};
map = new OpenLayers.Map('map');
baseLayer = new OpenLayers.Layer.Image("My map","map.png",
new OpenLayers.Bounds(-2000, -2000, 1000, 1000),
new OpenLayers.Size(1500,1500), options);
map.addLayer(baseLayer);
var center = new OpenLayers.LonLat(-100,-100);
map.setCenter(center ,0);
map.addControl(new OpenLayers.Control.LayerSwitcher());
map.addControl(new OpenLayers.Control.MousePosition());
var size = new OpenLayers.Size(21,25);
var offset = new OpenLayers.Pixel(-(size.w/2), -size.h);
var icon = new OpenLayers.Icon('http://www.openlayers.org/dev/img/marker.png',size,offset);
var markers = new OpenLayers.Layer.Markers( "Marker" );
map.addLayer(markers);
}
添加標記的代碼:
function addMarker(x, y)
{
markers.addMarker(new OpenLayers.Marker(new OpenLayers.LonLat(x, y),icon));
}
任何幫助深表感謝 :)
這對我來說很好:
var markers,icon;
function init(){
var map, baseLayer;
var options = {numZoomLevels: 5, isBaseLayer: true,};
map = new OpenLayers.Map('map');
baseLayer = new OpenLayers.Layer.Image("My map","map.png",
new OpenLayers.Bounds(-2000, -2000, 1000, 1000),
new OpenLayers.Size(1500,1500), options);
map.addLayer(baseLayer);
var center = new OpenLayers.LonLat(-100,-100);
map.setCenter(center ,0);
map.addControl(new OpenLayers.Control.LayerSwitcher());
map.addControl(new OpenLayers.Control.MousePosition());
var size = new OpenLayers.Size(21,25);
var offset = new OpenLayers.Pixel(-(size.w/2), -size.h);
//instance the icon
icon = new OpenLayers.Icon('http://www.openlayers.org/dev/img/marker.png',size,offset);
//instance the marker layer
markers = new OpenLayers.Layer.Markers( "Marker" );
map.addLayer(markers);
}
function addMarker(x, y){
markers.addMarker(new OpenLayers.Marker(new OpenLayers.LonLat(x, y),icon));
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.