我有一个使用 OpenLayers 和 GeoExt 库的网站。我的目标是为我的每一层(我有 5 层)设置一个不透明度滑块。现在,它正在使用我的矢量图层,但不是我的 WMS 层。我尝试了基础层(开放街道地图),它工作正常。
这是创建层的代码:
//This part is inside an "if success" in an ajax request.
map.addLayer(new OpenLayers.Layer.WMS(openlayers_wms_layer_analyses, CMCDataServer, {
layers: analysesWMSLayer[currentStatePeriod],
styles: analysesWMSStyle[currentStatePeriod],
format: "image/png",
transparent: true,
time: currentStateDate.getUTCFullYear() + "-" + ('0' + (currentStateDate.getUTCMonth() + 1)).slice(-2) + "-" + ('0' + currentStateDate.getUTCDate()).slice(-2) + "T" + timeChopArray[currentStateIndex] + ":00:00Z"
},
{
opacity: 0.73,
visibility: true
}));
Ext.getCmp('analyses_validity_display_extjs').setValue(extjs_gui_state_panel_valid_analyses);
Ext.getCmp('extjs_gui_legend_tab_panels').setActiveTab(0);
} else {
Ext.getCmp('analyses_validity_display_extjs').setValue(extjs_gui_state_panel_invalid_analyses);
Ext.Msg.alert(extjs_gui_analyses_missing_warning_title, extjs_gui_analyses_missing_warning);
Ext.getCmp('analyses_checkbox_extjs').setValue(false);
}
}
});
//This part is a little lower in my code, it's an "else" after the ajax request on top.
}else if(map.getLayersByName(openlayers_wms_layer_analyses).length!=0){
adjustStatePanelAnalysesValidity();
map.removeLayer(map.getLayersByName(openlayers_wms_layer_analyses)[0]);
}
adjustStatePanelProducts(checkbox, checked);
}
这是我的滑块代码:
new GeoExt.LayerOpacitySlider({
width: 100,
value: 100,
layer: map.getLayersByName(openlayers_wms_layer_analyses)[0],
aggressive: true,
style: {
position: 'absolute',
left: '150px'
}
}),
我为矢量图层的滑块使用了相同的代码,它工作正常。如果我将图层的名称更改为我的基础图层,它也可以正常工作。我不认为这是因为我没有选择正确的图层,因为我使用了图层创建中使用的名称。如果你检查层被移除的方式,你会发现它使用了和我一样的行,像这样:map.removeLayer(map.getLayersByName(openlayers_wms_layer_analyses)[0]);
你有什么想法可以帮助我吗?
map.getLayersByName(openlayers_wms_layer_analyses)[0]
更新:我在 javascript 控制台中写道。如果我没有选中该框以查看图层,我会得到“未定义”,但如果选中并且我可以看到图层,我会正确看到图层。这意味着我的滑块应该可以工作..不?