下午好,我在地图上有一个弹出窗口,我只想向左移动10个像素,向左移动15个像素,问题是当你改变它在纬度和经度上的位置时,完全处于另一个位置当我远离标记时,我想要的只是移动到新位置,无论变焦如何,始终保持在标记之上。
var size = new OpenLayers.Size(21,25);
var offset = new OpenLayers.Pixel(-(size.w/2), -size.h);
var icon = new OpenLayers.Icon('/openlayers/img/marker.png',size,offset);
var lonlat = new OpenLayers.LonLat(long,lat);
var proj_1 = new OpenLayers.Projection("EPSG:4326");
var proj_2 = new OpenLayers.Projection("EPSG:900913");
var EPSG = lonlat.transform(proj_1,proj_2);
var marker = new OpenLayers.Marker(EPSG, icon);
markers.addMarker(marker);
marker.events.register("click", marker, function(e){ // on click popup
var popup = new OpenLayers.Popup.FramedCloud(id,
marker.lonlat,
new OpenLayers.Size(200,200),
'<div class="popup">info example</div>',
null,true);
map.addPopup(popup);
});
var labelepopup = new OpenLayers.Popup(null,
EPSG,
new OpenLayers.Size(37,13),
'<p style="font-size: 8.5px;">always info</p>'
);
map.addPopup(labelepopup);
标记上的弹出窗口显示为labelepopup,我想要的只是在标记上方容纳labelepopup。
答案 0 :(得分:1)
您可以使用getPixelFromLonLat
地图功能从纬度和经度中获取精确像素,然后使用返回的Pixel
对象添加或删除所需的像素。然后,您可以使用需要moveTo
对象的Pixel
弹出功能更改弹出位置。
这样的事情:
var pixel = map.getPixelFromLonLat(popup.lonlat); //or use another OpenLayers.LonLat object
pixel.x += DESIRED_X_AMOUNT;
pixel.y += DESIRED_Y_AMOUNT;
popup.moveTo(pixel);