我有两个谷歌地图使用几乎相同的代码,但行为不同。两者都查询 Fusion Table 以创建图层(标记组),并且都使用 jQuery 滑块来触发将图层设置到地图或从地图取消设置的功能。两者之间的唯一区别是他们查询的融合表。查询小数据集的方法按预期工作(所有 Fusion Table 图层及其相应的数据点按预期设置和取消设置)。查询约 3500 个数据点在设置/取消设置前几层(不是具有最多数据点的层)时按预期工作;然后在设置 2003-2006 层时显示错误的数据点集(我验证了一些 2005 年的数据点不在 2003-2006 层中);然后似乎继续按预期工作以设置/取消设置剩余层。
我知道这似乎表明某处的数据存在故障,但我们已经非常彻底地查看了它,并且在那里找不到任何问题。我没有违反 5 层限制(一次只设置一个层)并且找不到可以添加到地图的标记数量的任何限制。
任何人都知道可能导致这种情况的原因是什么?完整代码如下。除了 Fusion Table ID 之外,这两个版本都是相同的。
var map;
var infowindow;
function Initialize() {
var mapCenter = new google.maps.LatLng(42,-71.5314);
var mapOptions = {
zoom: 8,
center: mapCenter,
mapTypeId: google.maps.MapTypeId.ROADMAP,
zoomControl: true,
zoomControlOptions: {
style: google.maps.ZoomControlStyle.SMALL
}
};
map = new google.maps.Map(document.getElementById('map_canvas'), mapOptions);
infowindow = new google.maps.InfoWindow();
layer2003 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2003'
}
});
layer2004 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2004'
}
});
layer2005 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2005'
}
});
layer2006 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2006'
}
});
layer2007 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2007'
}
});
layer2008 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2008'
}
});
layer2009 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2009'
}
});
layer2010 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2010'
}
});
layer2011 = new google.maps.FusionTablesLayer({
query: {
select: 'Geocode_Source',
from: '2203337',
where: 'Year <= 2011'
}
});
layer2003.setMap(map);
google.maps.event.addListener(map, 'zoom_changed', function() {
if (map.getZoom() > 12) {
map.setZoom(12);
}
});
google.maps.event.addListener(map, 'zoom_changed', function() {
if (map.getZoom() < 8) {
map.setZoom(8);
}
});
} //end function Initialize
//Set Fusion Table layers onto the map or to null, as appropriate
function set2003() {
layer2003.setMap(map);
layer2004.setMap(null);
layer2005.setMap(null);
layer2006.setMap(null);
layer2007.setMap(null);
layer2008.setMap(null);
layer2009.setMap(null);
layer2010.setMap(null);
layer2011.setMap(null);
}
function set2004() {
layer2003.setMap(null);
layer2004.setMap(map);
layer2005.setMap(null);
layer2006.setMap(null);
layer2007.setMap(null);
layer2008.setMap(null);
layer2009.setMap(null);
layer2010.setMap(null);
layer2011.setMap(null);
}
function set2005() {
layer2003.setMap(null);
layer2004.setMap(null);
layer2005.setMap(map);
layer2006.setMap(null);
layer2007.setMap(null);
layer2008.setMap(null);
layer2009.setMap(null);
layer2010.setMap(null);
layer2011.setMap(null);
}
function set2006() {
layer2003.setMap(null);
layer2004.setMap(null);
layer2005.setMap(null);
layer2006.setMap(map);
layer2007.setMap(null);
layer2008.setMap(null);
layer2009.setMap(null);
layer2010.setMap(null);
layer2011.setMap(null);
}
function set2007() {
layer2003.setMap(null);
layer2004.setMap(null);
layer2005.setMap(null);
layer2006.setMap(null);
layer2007.setMap(map);
layer2008.setMap(null);
layer2009.setMap(null);
layer2010.setMap(null);
layer2011.setMap(null);
}
function set2008() {
layer2003.setMap(null);
layer2004.setMap(null);
layer2005.setMap(null);
layer2006.setMap(null);
layer2007.setMap(null);
layer2008.setMap(map);
layer2009.setMap(null);
layer2010.setMap(null);
layer2011.setMap(null);
}
function set2009() {
layer2003.setMap(null);
layer2004.setMap(null);
layer2005.setMap(null);
layer2006.setMap(null);
layer2007.setMap(null);
layer2008.setMap(null);
layer2009.setMap(map);
layer2010.setMap(null);
layer2011.setMap(null);
}
function set2010() {
layer2003.setMap(null);
layer2004.setMap(null);
layer2005.setMap(null);
layer2006.setMap(null);
layer2007.setMap(null);
layer2008.setMap(null);
layer2009.setMap(null);
layer2010.setMap(map);
layer2011.setMap(null);
}
function set2011() {
layer2003.setMap(null);
layer2004.setMap(null);
layer2005.setMap(null);
layer2006.setMap(null);
layer2007.setMap(null);
layer2008.setMap(null);
layer2009.setMap(null);
layer2010.setMap(null);
layer2011.setMap(map);
}
function UpdateMap(){
var value = $('#slider').slider('option', 'value');
if (value==2003){set2003();}
if (value==2004){set2004();}
if (value==2005){set2005();}
if (value==2006){set2006();}
if (value==2007){set2007();}
if (value==2008){set2008();}
if (value==2009){set2009();}
if (value==2010){set2010();}
if (value==2011){set2011();}
}
$(function(){
$('#slider').slider({
orientation: 'horizontal',
animate: true,
step: 1,
min: 2003,
max: 2011,
change: function(event, ui){
UpdateMap();
}
});
});
-->
</script>