私は、ラスターベースレイヤー、ベクターレイヤー、マーカーレイヤーの順にOpenLayersマップを持っています。それらは、ベクトルの上にマーカーがある、正しい順序で、うまく表示されます。OpenLayersマーカーレイヤーを上に描画し、選択可能なレイヤーを下に置くようにします
しかしSelectFeatureコントロールを追加してベクトルレイヤーをポイントすると、マーカーレイヤーを上げたりZインデックスを設定したりしても、突然マーカーレイヤーの上に描画されます。 SelectFeatureコントロールは、すべての描画順序設定をオーバーライドするようです。これは設計によるのですか、それとも何とかこれを克服できますか?
層定義:
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
}
);
コントロール定義:
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
}
);
活性化(これがなければ、層は正しい順序で描画)
map.addControl(selectctrl);
selectctrl.activate();
編集: が見つかりこれはOpenLayers.Handler.Featureの "moveLayerToTop"が犯人...それを克服しようとするが、誰かがそれが不可能であることを知っているなら、私に知らせてください!
/**
* 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;
},
あなたは何か天才ですか? – Johnny
@Johnny:ハハ、ありがとう!あなたは私の一日を作った! :-) –
@ニカラ:ソリューションを投稿するためのNiklasに感謝します。実際にはうまく動作しています:) – Nachiket