我正在使用Google Maps Utility Library v3在Google地图上尝试群集标记的基本实现。
当我运行此操作时,我在Chrome开发者工具控制台上收到错误消息:
Uncaught TypeError: Object #<Object> has no method 'getPosition'
这与实用程序库脚本中的第649行有关:http://google-maps-utility-library-v3.googlecode.com/svn/trunk/markerclusterer/src/markerclusterer.js。以下是以下功能:
/**
* Determins if a marker is contained in a bounds.
*
* @param {google.maps.Marker} marker The marker to check.
* @param {google.maps.LatLngBounds} bounds The bounds to check against.
* @return {boolean} True if the marker is in the bounds.
* @private
*/
MarkerClusterer.prototype.isMarkerInBounds_ = function(marker, bounds) {
return bounds.contains(marker.getPosition());
};
我使用的代码是相当标准的Google地图内容,其主要功能是:
function initialize(items,loop,zoom) {
geocoder = new google.maps.Geocoder();
if (items.length > 0) {
var latlng = new google.maps.LatLng(items[0].Lat, items[0].Lng);
var myOptions = {
zoom: zoom,
center: latlng,
//mapTypeControl: false,
streetViewControl: false,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
map = new google.maps.Map(document.getElementById("map"), myOptions);
map.setOptions({styles: stylez});
for (var i = 0; i < items.length; i++) {
var marker = new google.maps.Marker({
position: new google.maps.LatLng(items[i].Lat, items[i].Lng),
title: items[i].Title,
icon: _iconCenter,
shadow: shadow,
infocontent: items[i].Description
});
marker.setMap(map);
markersArray.push(marker);
}
var markerCluster = new MarkerClusterer(map, items);
google.maps.event.addListener(map, "tilesloaded", function () {
if(loop == true){
SetLoop();
}
});
}
}
据我所知,我已经跟踪了错误函数,它应该接收地图边缘的坐标,以便能够确定边界,这应该只是标准行为,但显然有些不对。< / p>
我想知道是否有人可以对此有所了解?
感谢任何人们......
答案 0 :(得分:5)
事实证明,我在谷歌地图脚本之前宣布了markerclusterer脚本。调用地图脚本首先解决了它......现在很明显!
答案 1 :(得分:4)
MarkerClusterer需要一系列标记。您创建一个,但将items数组传递给它的构造函数。变化:
var markerCluster = new MarkerClusterer(map, items);
为:
var markerCluster = new MarkerClusterer(map, markersArray);