OpenLayers并没有封装图层切换的控件,所以我们需要自己来实现图层控件。
自定义图层切换控件的原理很简单:显示某个图层时,将其他图层隐藏。
完整代码:
layerSwitch.html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>图层切换控件</title> <link rel="stylesheet" href="../v5.3.0/css/ol.css" /> <script src="/UploadFiles/2021-04-02/ol.js">实现效果:
代码整体逻辑是很简单的,其中使用了事件委托这一机制来绑定事件,事件委托可以减少事件绑定导致的内存消耗,所以平时开发时推荐多使用事件委托。
另外,map.getLayers()返回一个ol.Collection类的对象,该对象中包含了地图中的三个图层对象(ol.layer.Tile),可以为item()方法传入对应索引来取出对应图层对象。
最后,ol.layer.Tile类的setVisible()方法可以设置图层的显示与隐藏。
怎么样,自己实现一个图层切换控件是不是很简单呢?
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。