API Карт Google: getFeatureById для коллекции функций не работает
Я пытаюсь изменить стиль конкретной функции наложения данных коллекции объектов. Это фрагмент моего JSON:
{
"type": "FeatureCollection",
"features": [
{
"type": "Feature",
"id": 1,
"properties": {
"name": "1 CBD - Bankenviertel",
"color": "transparent",
"isHovered": false,
"isActive": false
},
"geometry": {
"type": "Polygon",
"coordinates": [
[
[
8.67279430349,
50.1143807311
],
[
8.67280054398,
50.1143975981
]
]
]
}
}
и это соответствующий фрагмент из моего map.js
map.data.loadGeoJson('some.json');
console.log(map.data.getFeatureById(1));
И я всегда получаю "неопределенный" в консоли.
Что я здесь не так делаю?
Спасибо,
Роберт
1 ответ
Решение
Вам нужно позвонить map.data.getFeatureById(1)
внутри функции обратного вызова (поэтому она не выполняется до загрузки GeoJson).
из документации:
loadGeoJson (url: string, options?: Data.GeoJsonOptions, callback?: function (Array))
Возвращаемое значение: Нет
Грузы GeoJS
доказательство концепции скрипки
фрагмент кода:
var geocoder;
var map;
function initialize() {
var map = new google.maps.Map(
document.getElementById("map_canvas"), {
zoom: 4,
center: {
lat: -28,
lng: 137
},
mapTypeId: google.maps.MapTypeId.ROADMAP
});
// map.data.addGeoJson(geoJson);
map.data.loadGeoJson(
'https://api.myjson.com/bins/1teyu', {},
function(features) {
console.log(map.data.getFeatureById(1));
console.log(map.data.getFeatureById(1).getProperty("letter"));
});
}
google.maps.event.addDomListener(window, "load", initialize);
html,
body,
#map_canvas {
height: 100%;
width: 100%;
margin: 0px;
padding: 0px
}
<script src="https://maps.googleapis.com/maps/api/js"></script>
<div id="map_canvas"></div>