Tengo un mapa OpenLayers con una capa base ráster, una capa vectorial y una capa marcadores en ese orden. Se muestran bien, en el orden correcto con los marcadores en la parte superior de los vectores, genial.Obligar a una capa OpenLayers Markers a dibujar en la parte superior y tener capas seleccionables debajo de
Pero cuando agrego un control SelectFeature y lo señalo a la capa vectorial, de repente se dibuja sobre la capa de marcadores, a pesar de todos los esfuerzos para elevar la capa de marcador o establecer el índice Z. Parece que el control SelectFeature anula todas las configuraciones de orden de dibujo. ¿Es esto por diseño, o puedo superar esto de alguna manera?
Las definiciones de capa:
var baselayer = new OpenLayers.Layer.WMS('Norden',
'http://{myarcgisserver}/ArcGIS/services/mylayer/MapServer/WMSServer', {
layers :'1,2',
transparent :false,
width :'auto',
height :'auto',
filter :null
}, {
isBaseLayer: true,
singleTile :true,
ratio :1,
alpha :false,
transitionEffect :'resize'
});
var vectorLayer = new OpenLayers.Layer.Vector("Work orders", {
projection: new OpenLayers.Projection("EPSG:2400"),
strategies: [new OpenLayers.Strategy.Fixed(), refresh],
protocol: new OpenLayers.Protocol.HTTP({
url: "/WorkOrder/WorkOrders.ashx?output=geojson",
format: new OpenLayers.Format.GeoJSON()
})
});
var markerlayer = new OpenLayers.Layer.Markers("Markers", {
projection: new OpenLayers.Projection("EPSG:2400"),
displayInLayerSwitcher: false
}
);
La definición de control:
var selectctrl = new OpenLayers.Control.SelectFeature(
vectorLayer,
{
clickout: true,
toggle: false,
multiple: false,
hover: false,
toggleKey: "ctrlKey", // ctrl key removes from selection
multipleKey: "shiftKey", // shift key adds to selection
box: false
}
);
de activación: (Sin esto, las capas se basan en el orden correcto)
map.addControl(selectctrl);
selectctrl.activate();
Editar: Encontrado esto en OpenLayers.Handler.Feature, donde el "moveLayerToTop" se siente como el culpable ... Trataré de superarlo, pero si alguien sabe que es imposible, ¡por favor hágamelo saber!
/**
* Method: activate
* Turn on the handler. Returns false if the handler was already active.
*
* Returns:
* {Boolean}
*/
activate: function() {
var activated = false;
if(OpenLayers.Handler.prototype.activate.apply(this, arguments)) {
this.moveLayerToTop();
this.map.events.on({
"removelayer": this.handleMapEvents,
"changelayer": this.handleMapEvents,
scope: this
});
activated = true;
}
return activated;
},
¡Usted señor es una especie de genio! – Johnny
@Johnny: jaja, gracias! ¡Me has alegrado el día! :-) –
@Nikalas: Gracias Niklas por publicar la solución. Funciona muy bien y como se esperaba :) – Nachiket