【问题标题】:Google maps GeoJSON- toggle marker layers?谷歌地图 GeoJSON- 切换标记层?
【发布时间】:2014-05-25 07:53:42
【问题描述】:

我从对 PostGIS 数据库的调用中返回了一些 GeoJSON。我希望能够为每个功能添加一个标记,并能够切换不同类型的标记/功能。目前我正在使用 JavaScript 为每个功能生成一个标记,根据类型将它们添加到数组中,然后根据需要通过数组设置显示/隐藏来切换“层”。

这工作正常,但我想知道新的 GeoJSON 功能是否提供了更好的方法来做到这一点。但据我所见,所有功能都添加到同一个数据层中,并且切换它们的集合将涉及设置样式或仅替换为新的、预先过滤的 GeoJSON。

所以问题是是否有可能拥有多个数据层,并且可以轻松地从地图中添加/删除它们,还是我最好看看 OpenLayers 之类的东西?

编辑:更多研究表明这很简单。

对于我们想要打开的特征集合中的每种特征,创建一个新的数据对象。将所有相关功能添加到该数据对象。

var datalayer = new google.maps.Data();
datalayer.addGeoJson(feature);
datalayer.setMap(mainmap);

然后将每个数据对象/特征类型存储为键值对。在切换时,根据需要拉出相关数据对象和 setMap:

var datalayer= featuretypesobj["feature type to toggle"];
datalayer.setMap(mymap); //or
datalayer.setMap(null);

【问题讨论】:

    标签: maps toggle layer geojson markers


    【解决方案1】:

    您也可以创建单独的图层

    var layer_1 = new google.maps.Data();
    var layer_2 = new google.maps.Data();
    

    然后填充它,例如带json数据

    layer_1.loadGeoJson('/path/to/data.json');
    layer_2.loadGeoJson('/path/to/data2.json');
    

    然后在地图上添加/删除它们

    layer_1.setMap(map);
    layer_2.setMap(map);
    layer_1.setMap(null);
    

    【讨论】:

      【解决方案2】:

      添加: var layer_1 = new google.maps.Data();应该在地图初始化函数中完成,如:

      var map;
      
        var data_layer_for_ramps;
      
      
      
        function initialize() {
      
                  map = new google.maps.Map(document.getElementById('map'), {
                    zoom: 12,
                    center: new google.maps.LatLng(-33.897907, 151.179138),//-33.8151,151.0032 
                    mapTypeId: 'roadmap'
                  });
      
                  data_layer_for_ramps = new google.maps.Data();
              }   
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2015-10-22
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2014-12-10
        • 1970-01-01
        • 2017-10-30
        • 2014-08-13
        相关资源
        最近更新 更多