Триггер google maps click
У меня есть карта Google, настроенная для поиска текущего местоположения пользователя, и центрирование карты в том ближайшем маркере к его местоположению. При нажатии на маркеры открывается информационный блок (обратите внимание, что это немного отличается от окна информации - http://google-maps-utility-library-v3.googlecode.com/svn/trunk/infobox/docs/examples.html). Однако я хочу автоматически открыть ближайший маркер, не нажимая пользователя. Вот код для запуска открытия маркера:
//loop through all locations to add a marker:
addMarker = function(loc) {
var markerLoc = new google.maps.LatLng(loc.Lat, loc.Long);
var marker = new google.maps.Marker({
map: map,
position: markerLoc
});
google.maps.event.addListener(marker, "mousedown", function() {
var infoOpts = {
content: loc.markerText,
boxStyle: { background: "none transparent", width: "180px"},
pixelOffset: new google.maps.Size(-90, 0),
closeBoxMargin: "5px"
};
var ib = new InfoBox(infoOpts);
ib.open(map, marker);
});
markers.push(marker);
};
Так или иначе, я должен вызвать функцию mouseDown соответствующего маркера, но это должно быть сделано в функции вне этой. У меня будет ссылка на соответствующий маркер в массиве (markers[closestmarker]).
2 ответа
Я вижу, что этот вопрос уже давно стоит, но на всякий случай этот ответ может быть полезен: триггер google maps click
Удачи!
Код будет выглядеть так:
var marker = new google.maps.Marker({});
new google.maps.event.trigger( marker, 'click' );
Я обнаружил, что мне нужно прикрепить событие клика к маркеру, вот так
var marker = new google.maps.Marker({});
marker.addListener('click', function() {
infowindow.open(map, marker);
});
new google.maps.event.trigger( marker, 'click' );