0

由于一个融合表层有5个融合表层和5个样式的限制,我必须尝试如下:使用5个融合表层,每个融合表层使用两种样式,然后我可以达到我的目的:显示10种不同的样式一张地图。

但是在我实现之后,我发现它只显示了第一个融合表层。

然后我写了一个测试用例来检查原因。发现:如果我们在两层设置样式,只能显示第一层,第二层就没了。如果我为一层设置样式,效果很好。

下面是我的代码,有人可以帮忙吗?现在只显示一层。如果我们为它们或其中一个注释样式设置,则可以显示两个图层。

提前致谢!

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<style type="text/css">
html { height: 100% }
body { height: 100%; margin: 0px; padding: 0px }
#top-box {padding: 10px; background-color:#336699;}
.para-line {font-weight:bold;}
#map_canvas { height: 100% }
</style>
<script type="text/javascript"src="http://maps.google.com/maps/api/js?sensor=false"></script>

<script type="text/javascript">

    var map;

    function initialize() {
        map = new google.maps.Map(document.getElementById("map_canvas"));
        map.setMapTypeId('roadmap');
        map.setCenter(new google.maps.LatLng(38.4985464, -98.3834298));
        map.setZoom(4);

        var tableid1 =  4436842;

        var style = [{
            where: "State in('IL','PA')",
            polygonOptions: 
            {
                fillColor: "#rrggbb",
                fillOpacity: 0.7  
            }
        },{
            where: "State in('AL')",
            polygonOptions: 
            {
                fillColor: "#006400",
                fillOpacity: 0.7
            }
        }
        ];

        var query1 = {
            select: ['geometry','name'],
            from: tableid1,
            where: "State in('IL','PA')"
        }

        var query2 = {
                select: ['geometry','name'],
                from: tableid1,
                where: "State in('AL')"   
            }

        var layer1 = new google.maps.FusionTablesLayer({
            query:query1,
            styles: style,
            suppressInfoWindows: false,
            clickable:true
        }); 

        layer1.setMap(map);

        var layer2 = new google.maps.FusionTablesLayer({
            query:query2,
            styles:style,
            suppressInfoWindows: false,
            clickable:true
        }); 
        layer2.setMap(map);

        return;

    } 
</script>
</head>
<body onload="initialize()">    
<div id="map_canvas" style="width:100%; height:100%"></div>
</body>
</html>
4

1 回答 1

1

限制是(来自文档“您可以使用 Maps API 最多向地图添加五个 Fusion Tables 图层,其中一个可以使用最多五个样式规则设置样式。”

您可以使用 FusionTable 用户界面对图层进行样式设置,但只能动态设置一个样式,并且该样式只能有 5 个样式规则。

于 2012-08-25T06:09:33.370 回答