首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在Google地图上显示多个多边形,并切换每个多边形的可见性

,可以通过Google Maps JavaScript API来实现。

首先,需要在HTML页面中引入Google Maps JavaScript API的库文件,并创建一个地图容器:

代码语言:txt
复制
<!DOCTYPE html>
<html>
<head>
  <title>Google Maps Polygon</title>
  <style>
    #map {
      height: 400px;
      width: 100%;
    }
  </style>
</head>
<body>
  <div id="map"></div>
  <script src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&callback=initMap" async defer></script>
  <script>
    var map;

    function initMap() {
      map = new google.maps.Map(document.getElementById('map'), {
        center: {lat: 37.7749, lng: -122.4194}, // 设置地图中心点的经纬度
        zoom: 12 // 设置地图缩放级别
      });

      // 创建多个多边形
      var polygon1 = new google.maps.Polygon({
        paths: [
          {lat: 37.7749, lng: -122.4194},
          {lat: 37.7749, lng: -122.4316},
          {lat: 37.7833, lng: -122.4316},
          {lat: 37.7833, lng: -122.4194}
        ],
        strokeColor: '#FF0000', // 设置边框颜色
        strokeOpacity: 0.8, // 设置边框透明度
        strokeWeight: 2, // 设置边框宽度
        fillColor: '#FF0000', // 设置填充颜色
        fillOpacity: 0.35 // 设置填充透明度
      });

      var polygon2 = new google.maps.Polygon({
        paths: [
          {lat: 37.7749, lng: -122.4094},
          {lat: 37.7749, lng: -122.4216},
          {lat: 37.7833, lng: -122.4216},
          {lat: 37.7833, lng: -122.4094}
        ],
        strokeColor: '#00FF00',
        strokeOpacity: 0.8,
        strokeWeight: 2,
        fillColor: '#00FF00',
        fillOpacity: 0.35
      });

      // 将多边形添加到地图上
      polygon1.setMap(map);
      polygon2.setMap(map);

      // 切换多边形的可见性
      document.getElementById('togglePolygon1').addEventListener('click', function() {
        if (polygon1.getMap()) {
          polygon1.setMap(null);
        } else {
          polygon1.setMap(map);
        }
      });

      document.getElementById('togglePolygon2').addEventListener('click', function() {
        if (polygon2.getMap()) {
          polygon2.setMap(null);
        } else {
          polygon2.setMap(map);
        }
      });
    }
  </script>
  <button id="togglePolygon1">Toggle Polygon 1</button>
  <button id="togglePolygon2">Toggle Polygon 2</button>
</body>
</html>

上述代码中,首先创建了一个地图容器,并引入了Google Maps JavaScript API的库文件。然后,在initMap函数中,创建了两个多边形,并设置了它们的属性,如边框颜色、填充颜色等。接着,将多边形添加到地图上,并通过按钮的点击事件来切换多边形的可见性。

需要注意的是,上述代码中的YOUR_API_KEY需要替换为你自己的Google Maps API密钥。

推荐的腾讯云相关产品是腾讯地图开放平台,它提供了类似Google Maps的地图服务,可以在腾讯云官网上查找相关产品和产品介绍链接地址。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 高德地图——标记「建议收藏」

    标记显示地图上的单一位置。它可以使用一个标准的图标,也可以由开发 者自定义图标。您可以通过 AMap.addMarker(MarkerOptions Options) 方 法将一个标记添加到地图上。 MarkerOptions属性有: • position(Required) 在地图上标记位置的经纬度值。 参数不能为空。 • title 当用户点击标记,在信息窗口上显示的字符串(测试发现,点击没有任何效果)。 • snippet 附加文本,显示在标题下方(测试发现,点击没有任何效果)。 • draggable 如果您允许用户可以自由移动标记,设置为“true ” ,默认情况下为“false ” 。 • visible 设置“false ” ,标记不可见。 • anchor图标摆放在地图上的基准点。 • perspective设置 true,标记有近大远小效果。 • 可以通过Marker.setRotateAngle() 方法设置标记的 旋转角度,从正北开始,逆时针计算。

    01

    Qt编写地图综合应用9-行政区划

    行政区划在地图应用中非常有用,行政区划是行政区域划分的简称,是国家为了进行分级管理而实行的区域划分,百度地图提供的内置的函数类支持传入行政区划的名称来获取对应的边界点集合,然后根据该集合来绘制点集合,最后将该点集合封闭连起来,就形成了行政区划的轮廓图了,使用下来发现地图本身提供的函数可以支持到县城,如果需要精确到乡镇那就需要其他办法获得,一种是直接加载事先准备好的乡镇的边界点集合的js文件,一种是在地图上绘制多边形,然后开启可编辑属性,人为的拖动边界,最后获取整个多边形的边界点集合即可,这种方法有个专业术语叫扒数据,在音乐界叫扒带。其实方法一的前提也是按照方法二来获取的,对于很小的应用数量不多的乡镇可以采用此法,如果需要很多省市的乡镇那就可能需要安排专人去获取了。

    00

    Python学习总结(1)—turtle海龟作图

    forward(distance) 前进 backward(distance) 后退 right(degree)右转 默认为角度 left(degree) 左转 默认为角度 goto(newX,newY) | setpos(newX,newY) | setposition(newX,newY) 前往/定位 不设置penup()时,会产生画迹 setx(newX) 设置x坐标 相当于goto(newX,formerY),不设置penup()时,会产生画迹 sety() 设置y坐标 相当于goto(newX,formerY),不设置penup()时,会产生画迹 setheading(to_angel) 设置朝向 0-东;90-北;180-西;270-南 相当于left(degree),因为海龟默认初始指向东 home() 返回原点并改海龟朝向为初始朝向 相当于goto(0,0) 和setheading(0)的合作用 ,不设置penup()时,会产生画迹 circle(radius, extent=None, steps=None) 画圆周/正多边形 radius是半径,也就是圆心位于海龟的左边,距离海龟radius【注意海龟朝向】 extent是所绘制圆周的圆心角大小,单位为°,缺省为360° steps:用来画正多边形,缺省会拟合为圆 dot(size=None, *color) 画点 在海龟所处位置画点 size是点的大小,为整型;缺省为默认值 *color是点的颜色的英文单词,为字符串类型 stamp() 印章 在海龟当前位置绘制一个海龟形状【需要提前设置海龟形状,缺省为箭头形状】,并返回该印章的id【需要print(t.stamp())或及时赋值给其他变量stamp_id=t.stamp()】 clearstamp(stamp_id) 清除印章 参数必须是stamp()函数返回 clearstamps(n) 清除多个印章 n缺省为清除全部印章 n为正数是清除前几个印章 n为负数是清除后几个印章【前后次序以印章出现顺序为准】 undo() 撤消 没有参数。撤消 (或连续撤消) 最近的一个 (或多个) 海龟动作。可撤消的次数由撤消缓冲区的大小决定。 speed(Vnum) 速度 Vnum取值为0-10。1-10速度逐渐加快;0为最快【此时没有转向的动画效果,前后移动变为跳跃】 或Vnum取为”fastest”对应0,”fast”对应10,”normal”对应6,”slow”对应3,slowest”对应1

    01

    (数据科学学习手札74)基于geopandas的空间数据分析——数据结构篇

    geopandas是建立在GEOS、GDAL、PROJ等开源地理空间计算相关框架之上的,类似pandas语法风格的空间数据分析Python库,其目标是尽可能地简化Python中的地理空间数据处理,减少对Arcgis、PostGIS等工具的依赖,使得处理地理空间数据变得更加高效简洁,打造纯Python式的空间数据处理工作流。本系列文章就将围绕geopandas及其使用过程中涉及到的其他包进行系统性的介绍说明,每一篇将尽可能全面具体地介绍geopandas对应方面的知识,计划涵盖geopandas的数据结构、投影坐标系管理、文件IO、基础地图制作、集合操作、空间连接与聚合。   作为基于geopandas的空间数据分析系列文章的第一篇,通过本文你将会学习到geopandas中的数据结构。 geopandas的安装和使用需要若干依赖包,如果不事先妥善安装好这些依赖包而直接使用pip install geopandas或conda install geopandas可能会引发依赖包相关错误导致安装失败,官方文档中的推荐安装方式为:

    02
    领券