- OpenLayers Cookbook
- Antonio Santiago Perez
- 383字
- 2021-08-13 18:03:35
Restricting the map extent
Often, there are situations where you are interested to show data to the user but only for a specific area, which your available data corresponds to (a country, a region, a city, and so on).
In this case, there is no point in allowing the user to explore the whole world, so you need to limit the extent the user can navigate.
In this recipe, we present some ways to limit the area a user can explore.

How to do it...
- Create a map instance. Take a look at the couple of properties used in the constructor:
var map = new OpenLayers.Map("ch1_restricting_view", { maxExtent: OpenLayers.Bounds.fromString ("-180,-90,180,90"), restrictedExtent: OpenLayers.Bounds.fromString ("-180,-90,180,90") });
- As always, add some layer to see content and center the view:
var wms = new OpenLayers.Layer.WMS("OpenLayers WMS Basic", "http://vmap0.tiles.osgeo.org/wms/vmap0", { layers: 'basic' }); map.addLayer(wms); map.setCenter(new OpenLayers.LonLat(0, 0), 2);
- Add the functions that will be executed when buttons are clicked:
function updateMaxExtent() { var left = dijit.byId('left_me').get('value'); var bottom = dijit.byId('bottom_me').get('value'); var right = dijit.byId('rigth_me').get('value'); var top = dijit.byId('top_me').get('value'); map.setOptions({ maxExtent: new OpenLayers.Bounds(left, bottom, right, top) }); } function updateRestrictedExtent() { var left = dijit.byId('left_re').get('value'); var bottom = dijit.byId('bottom_re').get('value'); var right = dijit.byId('rigth_re').get('value'); var top = dijit.byId('top_re').get('value'); map.setOptions({ restrictedExtent: new OpenLayers.Bounds(left, bottom, right, top) }); }
As you have seen, the map has been instantiated using the two properties maxExtent
and restrictedExtent
, which are responsible for limiting the area of the map we can explore.
Although similar, these two properties have different meanings. Setting the maxExtent
property limits the viewport so its center cannot go outside the specified bounds. By setting the restrictedExtent
property the map itself cannot be panned beyond the given bounds.
The functions that react when buttons are clicked get the values from the input fields and apply the new values through the map.setOptions()
method:
map.setOptions({ maxExtent: new OpenLayers.Bounds(left, bottom, right, top) });
We can pass the same properties we use when creating a new OpenLayers.Map
instance to the map.setOptions()
method and it will take care to update them.
Limiting the map extent is not the only way to limit the information we show to the user. The layers have also similar properties to filter or limit the information they must render.
- Django 2 by Example
- Hands-On Chatbots and Conversational UI Development
- Oracle SOA Suite 11g Performance Tuning Cookbook
- Spring Cloud微服務架構進階
- PLC、現場總線及工業網絡實用技術速成
- 2018網信發展報告
- WordPress Web Application Development
- 2小時讀懂物聯網
- 物聯網與智能家居
- 網管第一課:網絡操作系統與配置管理
- 網絡空間全球治理觀察
- 一本書讀懂TCP/IP
- 基于IPv6的家居物聯網開發與應用技術
- 精通SEO:100%網站流量提升密碼
- 物聯網與智慧廣電