I have this GeoJSON file (polygon.geojson)...
{
"type": "Feature",
"geometry": { "type": "Polygon", "coordinates": [ [ [73, 15], [83.0, 15], [83, 5], [73, 5], [73, 15] ] ] },
"properties": { "name": "Foo" }
}
...and use it as vector source:
var vectorSource = new ol.source.Vector({
url: 'polygon.geojson',
format: new ol.format.GeoJSON(),
projection : 'EPSG:4326',
});
Now I want to get the extent with:
var extent = vectorSource.getExtent();
The value of extent
, however, is:
Array [ Infinity, Infinity, -Infinity, -Infinity ]
I'm using OL 3.9.0 and the vector layer with this source is displayed properly. What am I doing wrong?
I figured it out. I need to wait until the source is loaded:
vectorSource.once('change',function(e){
if(vectorSource.getState() === 'ready') {
var extent = vectorSource.getExtent();
console.log(extent);
map.getView().fit(extent, map.getSize());
}
});
EDIT: It might be safer to zoom only if the layer isn't empty:
vectorSource.once('change',function(e){
if(vectorSource.getState() === 'ready') {
if(layers[0].getSource().getFeatures().length>0) {
map.getView().fit(vectorSource.getExtent(), map.getSize());
}
}
});
If you're looking to fit
to the extent try this:
var extent = *YOURLAYER*.getSource().getExtent();
map.getView().fit(extent, map.getSize());
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With