我对打开图层比较新,但对谷歌地图api非常熟悉。
我之前使用谷歌地图完成了以下操作。我基本上试图用开放图层/打开街道地图复制相同的功能。但是我遇到了一个难题。
map = new OpenLayers.Map("map");
wms = new OpenLayers.Layer.WMS( "OpenLayers WMS", "http://vmap0.tiles.osgeo.org/wms/vmap0", {layers: 'basic'} );
osm = new OpenLayers.Layer.OSM();
map.addLayer(wms);
epsg4326 = new OpenLayers.Projection("EPSG:4326"); //WGS 1984 projection
projectTo = map.getProjectionObject(); //The map projection (Spherical Mercator)
var lonLat = new OpenLayers.LonLat(-71.3699930, 43.5412410).transform(epsg4326, projectTo);
var zoom=12;
map.setCenter (lonLat, zoom);
var vectorLayer = new OpenLayers.Layer.Vector("Overlay");
var encoded = "_p~iF~ps|U_ulLnnqC_mqNvxq`@";
var format = new OpenLayers.Format.EncodedPolyline({geometryType:"linestring"});
vectorLayer.addFeatures(format.read(encoded));
map.addLayer(vectorLayer);
目前编写代码的方式有效。它加载WMS贴图,显示折线,并使贴图正确居中。但这不是我想要的,我希望加载OSM地图。所以如果我改变这一行:
map.addLayer(wms);
到此:
map.addLayer(osm);
osm贴图加载精细,但未显示折线。我已经玩了很长时间了,似乎无法让这个工作。它与投影有关吗?谢谢!
答案 0 :(得分:0)
您需要做的是改变
vectorLayer.addFeatures(format.read(encoded));
以下
vectorLayer.addFeatures(new OpenLayers.Feature.Vector(format.read(encoded).geometry.transform('EPSG:4326', 'EPSG:3857')));
我有同样的麻烦,这就是我如何解决它。