您需要做的就是在GPolygon
构造函数中设置clickable: false
选项,如下例所示(GPolygonOptions:API参考):
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
<title>Google Maps Non Clickable Polygon Demo</title>
<script src="http://maps.google.com/maps?file=api&v=2&sensor=false"
type="text/javascript"></script>
</head>
<body onunload="GUnload()">
<div id="map" style="width: 450px; height: 300px"></div>
<script type="text/javascript">
var map = new GMap2(document.getElementById("map"));
map.setCenter(new GLatLng(37.4419, -122.1419), 13);
GEvent.addListener(map, "click", function(overlay, latlng) {
var lat = latlng.lat();
var lon = latlng.lng();
var latOffset = 0.01;
var lonOffset = 0.01;
var polygon = new GPolygon([
new GLatLng(lat, lon - lonOffset),
new GLatLng(lat + latOffset, lon),
new GLatLng(lat, lon + lonOffset),
new GLatLng(lat - latOffset, lon),
new GLatLng(lat, lon - lonOffset)
], "#f33f00", 5, 1, "#ff0000", 0.2, { clickable: false });
map.addOverlay(polygon);
});
</script>
</body>
</html>
附带证据的屏幕截图:
![谷歌地图不可点击的多边形示例](https://i.imgur.com/e9z1CJW.png)
请注意,click(overlay: GOverlay, latlng: GLatLng, overlaylatlng: GLatLng)
事件根据点击的上下文和是否在可点击的叠加层上发生而传递不同的参数。如果点击未发生在可点击的叠加层上,则overlay
参数为null
,而latlng
参数包含所点击点的地理坐标。如果用户单击可点击的叠加层,则overlay
参数包含叠加层对象,而overlaylatlng
参数包含所点击叠加层的坐标(来源:API参考)。