Триггер 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' );
Другие вопросы по тегам