Openlayers获取矢量图层特征的质心并使用它来设置地图的中心

时间:2013-05-21 18:04:13

标签: openlayers kml

下面的代码使用了地图中心的绝对位置,但我想根据从KML文件中引入的矢量图层特征来设置中心 - 这可能吗?我看过getCentroid但是不能正确使用语法吗?

map = new OpenLayers.Map("Map");
var mapnik = new OpenLayers.Layer.OSM();
//Set centre position converting from WGS to Mercator
var wgs84 = new OpenLayers.Projection("EPSG:4326");
var fromProjection = new OpenLayers.Projection("EPSG:4326");   // Transform from WGS 1984
var toProjection   = new OpenLayers.Projection("EPSG:900913"); // to Spherical Mercator Projection
var position       = new OpenLayers.LonLat(4.891280,52.373690).transform( fromProjection, toProjection);

var layer = new OpenLayers.Layer.Vector("vectorlayer", {
    projection: wgs84,
    strategies: [new OpenLayers.Strategy.Fixed()],
    protocol: new OpenLayers.Protocol.HTTP({
        url: "kmlfile.kml",   //<-- relative or absolute URL to your .osm file
        format: new OpenLayers.Format.KML()
    }),
    styleMap: new OpenLayers.StyleMap({
      "default": {
            //pointRadius: "${radius}",
            fillColor: "blue",
            fillOpacity: 0.1,
            strokeColor: "#5555ff",
            strokeWidth: 2,
            strokeOpacity: 0.8
       }
        ,
      "select": {
          fillColor: "#8aeeef",
          strokeColor: "#32a8a9"
      }
    })
});

map.addLayers([mapnik, layer]);

map.addControl(new OpenLayers.Control.LayerSwitcher());

var scaleline = new OpenLayers.Control.ScaleLine();
map.addControl(scaleline);


//Set centre of map and zoom level
map.setCenter(position, 10 );

1 个答案:

答案 0 :(得分:0)

尝试这个(其中图层是基于代码的矢量):

var bounds = layer.geometry.bounds;
map.zoomToExtent(bounds);

var bounds = layer.geometry.bounds;
map.setCenter(bounds.getCenterLonLat());