我设置了谷歌地图以查找用户的当前位置,并将地图置于最靠近其位置的标记处。点击时,标记打开一个信息框(注意这与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])。
答案 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' );