我疯了。我试图从OpenLayers 2.10初学者指南中重现一个例子,我试图显示保存在json文件中的功能并在地图上添加功能,并将它们保存到文件中。
var map;
function init(){
map = new OpenLayers.Map('map');
var options = {numZoomLevels: 3}
var floorplan = new OpenLayers.Layer.Image(
'Floorplan Map',
'temp_photos/sample-floor-plan.jpg',
new OpenLayers.Bounds(-180, -88.759, 180, 88.759),
new OpenLayers.Size(580, 288),
options
);
var roomPolygonLayer = new OpenLayers.Layer.Vector('Rooms', {
protocol: new OpenLayers.Protocol.HTTP({
url: "myFloorPlanData.json",
format: new OpenLayers.Format.GeoJSON({})}),
strategies: [new OpenLayers.Strategy.Fixed(), new OpenLayers.Strategy.Save()]
});
map.addLayers([floorplan, roomPolygonLayer]);
map.zoomToMaxExtent();
map.addControl(new OpenLayers.Control.EditingToolbar(roomPolygonLayer));
map.layers[1].onFeatureInsert = function(feature){
alert("feature id: "+feature.id);
alert("feature geometry: "+ feature.geometry);
};
}
到目前为止,我的地图已经显示,我可以在地图上绘制矢量,但是它拒绝显示我在json文件中的两个点,并且还保存了我绘制的新点:
{
"type": "FeatureCollection",
"features": [
{"type":"Feature","properties":{}, "geometry":{"type":"Point", "coordinates":[5, 63]}},
{"type":"Feature","properties":{}, "geometry":{"type":"Point", "coordinates":[-48, 27]}}
]
}
json文件与我的jsp文件位于同一个文件夹中,我在服务器上运行我的项目
答案 0 :(得分:0)
OpenLayers.Strategy.Save无法直接修改json文件。它只能通过实现WFS-T协议的Web服务工作。
您可以安装支持WFS-T的软件,例如Geoserver。然后,您可以在OpenLayers应用程序中使用OpenLayers.Strategy.Save。
另一个选择是创建将修改json文件的自定义Web服务。然后,您将创建某种“保存”按钮,该按钮将在单击时调用您的自定义Web服务。