Yanıtlar:
Bu extent
, View nesnesinde tanımlanarak yapılabilir . Örneğin
var view = new ol.View({
...
extent: [minx,miny,maxx,maxy]
...
});
var map = new ol.Map({
...
view: view,
...
});
extent
uygun şekilde belgelenmiş bir özellik haline geldi: openlayers.org/en/latest/apidoc/module-ol_View-View.html (yazı itibariyle, "en son" = v5.3.0)
Başka bir seçenek:
...
var map = new ol.Map({
layers: [...],
overlays: [...],
target: document.getElementById('map'),
view: new ol.View({
center: ol.proj.transform([minx,miny,maxx,maxy],
'EPSG:4326', 'EPSG:3857'),
zoom: ...,
maxZoom: ...,
minZoom: ...,
extent: ol.proj.transform([minx-n,miny-n,maxx+n,maxy+n],
'EPSG:4326', 'EPSG:3857')
})
});
...
Ragnagord'un zaten işaret ettiği gibi, içinizde ayarlamanız extent
gerekir ol.view
.
En kolay yoldan bahsetmek istediğiniz şeye bağlı olarak , fonksiyonu kullanarak doğrudan istediğiniz projeksiyon ( ol.proj.Projection
) veya katmandan (herhangi bir sınıf) kapsamı elde etmektir . EPSG: 3857 durumunda bu işe yarar:ol.layer
getExtent()
var map = new ol.Map({
...
view: new ol.View({
...
extent: ol.proj.get("EPSG:3857").getExtent()
})
});
Harita projeksiyonunu düşünürsek, WGS84 ve Küresel Mercator arasında benim durumumda bir alternatif var ol.proj.transformExtent
. Burada bir cevap bulundu . Kapsam aşağıdaki gibi atanır:
var map = new ol.Map({
.
.
.
view: new ol.View({
extent: ol.proj.transformExtent([minx, miny, maxx, maxy], 'EPSG:4326', 'EPSG:3857');
.
.
.
)}
)}