触发谷歌地图标记点击

时间:2011-07-22 18:22:29

标签: javascript google-maps

我设置了谷歌地图以查找用户的当前位置,并将地图置于最靠近其位置的标记处。点击时,标记打开一个信息框(注意这与infoWindow有点不同 - 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函数,但必须在这个函数之外的函数中完成。我将引用数组中的相应标记(标记[nearestmarker])。

2 个答案:

答案 0 :(得分:113)

我发现这个问题已经存在了很长一段时间,但是,以防万一,这个答案可能会有所帮助: trigger google maps marker click

代码如下所示:

var marker = new google.maps.Marker({});
new google.maps.event.trigger( marker, 'click' );
祝你好运!

答案 1 :(得分:4)

我发现我需要将点击事件附加到标记,如此

var marker = new google.maps.Marker({});
marker.addListener('click', function() {
    infowindow.open(map, marker);
});
new google.maps.event.trigger( marker, 'click' );