在 google maps api v3 中独立与 geojson 图层交互

Posted

技术标签:

【中文标题】在 google maps api v3 中独立与 geojson 图层交互【英文标题】:interact with geojson layers independently in google maps api v3 【发布时间】:2014-08-08 03:24:19 【问题描述】:

我想将两个 geojson 图层加载到我的地图中,并能够使用不同的规则独立设置它们的样式。我可以使用以下代码显示我的两个 geojson 文件,但由于它们都是同一个 map.data 对象的一部分,我只能对两者应用通用样式。有没有办法解决?最终(长期目标)我还希望能够使用复选框打开和关闭不同的图层(我首先关注独立样式,以免问题过于复杂)

function initialize() 
  map = new google.maps.Map(document.getElementById('map-canvas'), 
  zoom: 12,
  center: lat: 39.218509,  lng: -94.563703
);

map.data.loadGeoJson('https://url1');
map.data.loadGeoJson('https://url2');

map.data.setStyle(function(feature)  //styling rules here

google.maps.event.addDomListener(window, 'load', initialize);

任何帮助将不胜感激。我看到了一些看起来适用的线程(例如Google maps GeoJSON- toggle marker layers?),但我不确定如何专门针对我的目的应用它。

【问题讨论】:

【参考方案1】:

所以我只需要做一些类似的事情,需要添加 2 个 geojson 文件并设置不同的样式。您要做的是初始化地图,然后添加 2 个不同的图层。基本上为两者设置样式。下面是我的带注释的代码。我实际上在服务中使用了这个函数 Angular 并返回了一个承诺。

设置您的地图选项

var mapOptions = 
            zoom: 4,
            scrollwheel: false,
            center: new google.maps.LatLng(40.00, -98),
            mapTypeId: google.maps.MapTypeId.ROADMAP
        ;

将地图设置为变量。

var map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);

初始化 2 个需要层的变量。我做过州和县。

var countyLayer = new google.maps.Data();
var stateLayer = new google.maps.Data();

然后为每一层加载 GeoJson 文件。

countyLayer.loadGeoJson('counties.json');
stateLayer.loadGeoJson('states.json');

然后设置每一层的样式。

stateLayer.setStyle(
  strokeColor: 'red',
  strokeWeight: 5
 );

countyLayer.setStyle(
  strokeColor: 'black',
  strokeWeight: 1
);

最后一步是将图层设置为地图。

countyLayer.setMap(map);
stateLayer.setMap(map);

在此之后我返回了一个承诺,但你可以返回地图对象。这是否有意义/有助于回答您的问题?

此外,在每一层的 setStyle() 函数中,您可以通过函数添加动态样式。就像向 fillColor 添加一个函数,它会根据 GeoJson 文件中的数据更改颜色。

【讨论】:

为什么还没有选择这个作为答案?哦,幻用户3750486

以上是关于在 google maps api v3 中独立与 geojson 图层交互的主要内容,如果未能解决你的问题,请参考以下文章

在 maps.google.com 上的缩放比在 Google Maps API v3 上更流畅

在 Google Maps API v3 中删除标记

Google Maps API V3 - 边界内最近的路线

在 Google Maps API v3.0 中多次调用 map.fitBounds()

Google Maps API v3:如何动态更改标记图标?

Google Maps API V3 中的 API 密钥是啥?