谷歌地图v3 - 如何设置“气球”的样式并为国家着色?

时间:2011-12-12 08:35:46

标签: google-maps google-maps-api-3 google-maps-styled

有人知道当你点击一个地方时,如何设置出现在谷歌地图v3中的气球吗?我希望改变默认的“漫画风格”。

第二个问题:是否可以自动(或以其他方式)为一个国家着色(即我希望美国有红色覆盖,加拿大有黄色覆盖等等)?

谢谢你, 哒

2 个答案:

答案 0 :(得分:3)

我可以看到infowindow baloons有内联样式,因此,将样式应用于它们是一个问题。因此,其中一个选择是为泡泡创建自己的类(或找到一个,例如在这里查看:Google Maps: How to create a custom InfoWindow?)。

您的第二个问题:没有简单而通用的方式来显示您想要的叠加层。我的意思是,没有这样的API调用。但是使用多边形可以相对容易地完成。 (查看How do i Add and Remove polygons on a Google Map (version 3)?),您只需要国家边界,您可以通过网络找到。

答案 1 :(得分:3)

通过在单击标记时切换自定义元素,我解决了样式问题。我需要创建更小的信息窗口,所以我通过点击的标记显示了一个自定义元素,没有漫画风格指针。

google.maps.event.addListener(marker, 'click', function() {
  loadInfoWindow(map, marker);
});

function loadInfoWindow(map, marker){
        clearInfoWindow();
        pixelOffset = getPixelPosInMap(map, marker);
        var iwc = ''; // infowindow markup goes here
        $('#iwContainer').css({'margin-top':(pixelOffset.y - 100), 'margin-left':(pixelOffset.x - 40)}).html(iwc).fadeIn('fast');
    }

function getPixelPosInMap(map, marker){
        var scale = Math.pow(2, map.getZoom());
        var nw = new google.maps.LatLng(
            map.getBounds().getNorthEast().lat(),
            map.getBounds().getSouthWest().lng()
        );
        var worldCoordinateNW = map.getProjection().fromLatLngToPoint(nw);
        var worldCoordinate = map.getProjection().fromLatLngToPoint(marker.getPosition());
        return new google.maps.Point(
            Math.floor((worldCoordinate.x - worldCoordinateNW.x) * scale),
            Math.floor((worldCoordinate.y - worldCoordinateNW.y) * scale)
        );
    }

此代码使用jQuery获取信息窗口容器#iwContainer。我有信息窗口容器的以下样式。

#iwContainer {
  position: absolute;
  display: none;
  background-color: white;
  color: #900;
  font-size: 10px;
  padding: 5px;
  width: 90px;
  border: 1px solid #900;
  border-radius: 5px;
  z-index: 100;
  opacity: 0.85;
}