将 Google Maps JS API ImageMapType 剪辑为多边形

2024-02-07

如何将 Google 地图中的 MapType 剪辑为任意多边形。例如,如果我有一个自定义图像映射类型 https://developers.google.com/maps/documentation/javascript/maptypes#ImageMapTypes覆盖很大的区域(即全世界),但我只想在给定的多边形(即一个国家)内显示它。

有没有办法将 ImageMapType 剪切到给定的多边形,或者实现自定义 MapType 来实现此行为?它应该允许正常缩放和平移。

地图的其余部分应保持不变,并且会有一个仅覆盖特定区域的 MapType。因此,不可能简单地叠加一个多边形来覆盖多边形之外的区域以仅显示所需的内容。

Like so:

服务器端剪辑不是一个选项。


我已经为覆盖地图类型编写了代码,可以满足您的需求。请务必在您的目标浏览器中进行测试。Fiddle https://jsfiddle.net/sirkurt53/kstytcrc/

function ClipMapType(polygon, map) {
  this.tileSize = new google.maps.Size(256, 256);
  this.polygon = polygon;
  this.map = map;
}

ClipMapType.prototype.getTile = function(coord, zoom, ownerDocument) {
  var map = this.map;
  var scale = Math.pow(2, zoom);
  if (coord.y < 0 || coord.y >= scale) return ownerDocument.createElement('div');
  var tileX = ((coord.x % scale) + scale) % scale;
  var tileY = coord.y;
  // Your url pattern below
  var url = "https://khms0.google.com/kh/v=694&x=" + tileX + "&y=" + tileY + "&z=" + zoom;
  var image = new Image();
  image.src = url;

  var canvas = ownerDocument.createElement('canvas');
  canvas.width = this.tileSize.width;
  canvas.height = this.tileSize.height;
  var context = canvas.getContext('2d');

  var xdif = coord.x * this.tileSize.width;
  var ydif = coord.y * this.tileSize.height;

  var ring = this.polygon.getArray()[0];
  var points = ring.getArray().map(function(x) {
    var worldPoint = map.getProjection().fromLatLngToPoint(x);
    return new google.maps.Point((worldPoint.x) * scale - xdif, (worldPoint.y) * scale - ydif);
  });

  image.onload = function() {
    context.beginPath();
    context.moveTo(points[0].x, points[0].y);
    var count = points.length;
    for (var i = 0; i < count; i++) {
      context.lineTo(points[i].x, points[i].y);
    }
    context.lineTo(points[count - 1].x, points[count - 1].y);

    context.clip();
    context.drawImage(image, 0, 0);
    context.closePath();
  };

  return canvas;
};

function initMap() {
  var map = new google.maps.Map(document.getElementById('map'), {
    zoom: 4,
    center: {
      lat: 15,
      lng: 15
    }
  });
  var polygon = new google.maps.Data.Polygon([
    [{
      lat: 0,
      lng: 0
    }, {
      lat: 30,
      lng: 30
    }, {
      lat: 0,
      lng: 30
    }]
  ]);
  var mapType = new ClipMapType(polygon, map);
  map.overlayMapTypes.insertAt(0, mapType);
}
html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
}
#map {
  height: 100%;
}
<div id="map"></div>
<script async defer src="https://maps.googleapis.com/maps/api/js?callback=initMap">
</script>

怎么运行的

基本上ClipMapType类是一个MapType接口。getTile使用图块坐标和缩放级别调用此接口的方法,以获取每个图块的图块。ClipMapType创建一个画布元素作为图块,并绘制剪切到多边形内部的图块图像。如果性能很重要,可以对其进行优化以提高工作速度。

免责声明

通过破解 URL 来使用 Google 图块服务器可能违反 Google 地图服务条款。我用它来演示,不建议在生产中使用它。我的回答是试图让您了解如何创建自己的解决方案。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

将 Google Maps JS API ImageMapType 剪辑为多边形 的相关文章

随机推荐

  • javafx jar 构建正常但无法打开

    所以我创建了一个javafx项目 它有3个包 应用程序 控制器和一个包含我使用的所有图像的图像包 如果我只是编译并运行 程序运行良好 没有错误 但是 当我从中创建一个 jar 时 通过选择 build fxbuild 一切都很顺利 它告诉我
  • 传递给 Delphi 控制台应用程序的命令行参数的最大长度

    传递给 Delphi 控制台应用程序的字符串长度是否有最大限制 我正在考虑传递大量 JSON 数据 我将使用 ParamStr x 函数读取数据 CMD EXE 的最大长度为 8192 个字符 由于 CMD EXE 本身的限制 这将是 De
  • ndb.StringProperty 如何等于 python 字符串?

    我有这个 ndb 模型类 class foo ndb Model abc ndb StringProperty 现在当我使用abc像这样 if foo abc a print I m in 它进入 if 块并打印I m in 这怎么可能 我
  • 是否可以阻止 Google Play 应用程序在安装时创建我的应用程序的快捷方式?

    当您通过 Google Play 安装应用程序时 会在主屏幕上创建该应用程序的快捷方式 用户可以通过禁用 Google Play 应用程序中的 自动添加小部件 设置来防止这种情况发生 从开发人员的角度来看 我想知道是否可以在我自己的应用程序
  • 如何在Swing中画蛇?

    我对 Java Swing 相当陌生 正在为我的大学课程开发一个梯子和蛇形项目 老师告诉我们实现一个游戏 玩家可以准确选择游戏板上有多少条蛇以及蛇的位置 梯子也是如此 所以我不能在游戏中使用一个或多个固定图像 这样玩家就无法再更改它们 我需
  • 具有 @ManyToOne 关系的 QueryDSL 投影

    我将 OpenJPA 与 QueryDSL 一起使用 我尝试通过使用 QueryDSL 的 bean 投影功能来避免操作 Tuple 对象 例如 我有这两个实体 具有 ManyToOne 关系 Entity public class Fol
  • 在临时表列 SQL 中设置排序规则的正确方法

    我有一个临时表 它使用批量插入来插入数据 但是 当我想将临时表中的数据更新到普通表时 它会出现排序规则问题 我知道如何通过使用类似的方法来解决这个问题 UPDATE RegularTable SET r Column1 t ColumnA
  • 在哪里可以找到 Java 语法突出显示库? [关闭]

    Closed 这个问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 help closed questions 目前不接受答案 我正在用 Java 编写一个源代码编辑器 用于 Java 源代码 并且我想添加简单的语法突出显示 关键
  • 我试图在 bulma css 上使用汉堡菜单,但它不起作用。怎么了?

    我是 bulma css 新手http bulma io http bulma io 我正在尝试为移动用户使用汉堡菜单 我只是按照此页面上的说明进行操作 http bulma io documentation components nav
  • 对一组事实进行排序 CLIPS

    我正在尝试根据基于两个字段的比较器对 CLIPS 中的事实集合进行排序 不幸的是 我无法理解为什么如果传递的两个事实中第一个字段相同 则比较器 显然是正确的 会打印 2 我的比较器 deffunction MAIN rating sort
  • C++ 按位复制与按成员复制? [关闭]

    就目前情况而言 这个问题不太适合我们的问答形式 我们希望答案得到事实 参考资料或专业知识的支持 但这个问题可能会引发辩论 争论 民意调查或扩展讨论 如果您觉得这个问题可以改进并可能重新开放 访问帮助中心 help reopen questi
  • Javascript Set() 中的成员数量是否有限制?或者这是V8中的一个错误

    下面是一些简单的 Javascript 代码 它将整数重复添加到 Set 中 var i var limit 1 lt lt 24 var s new Set for i 0 i lt limit 10 i s add i if i gt
  • 关机还是不关机?在ExecutorService(Java8)中

    我试图了解执行程序服务相对于关闭的行为 文档说 除非有 shutdown 调用 否则应用程序不会终止 但在这个简单的示例中 它会在一分钟后精确退出 任何想法 Runnable r new Runnable Override public v
  • 调整阈值cros_val_score sklearn

    有没有办法设置sklearn的cross val score阈值 我训练了一个模型 然后将阈值调整为 0 22 型号如下 Try with Threshold pred proba LGBM Model predict proba X te
  • Python 3 Windows 服务仅在调试模式下启动

    我首先在中发布了答案这个帖子 https stackoverflow com questions 42586805 python 3 windows service 但不符合论坛标准 我希望这次的回答符合论坛标准 这段代码应该更加清晰易读
  • 当参数未显式传递时,默认使用 lambda 进行用户输入

    我写了下面的代码 仍然想知道它的用途 https codereview stackexchange com questions 242702 how effective is it to default to user input in c
  • Visual Studio 在调试时跳到每隔一行

    我现在尝试单步执行代码 Visual Studio 会跳过所有其他行 我知道它是每隔一个 因为当我有一个 ForEach 循环时 它会碰到在以后的迭代中跳过的行 Visual Studio 是否有任何逻辑原因跳过其他行 UPDATE 我添加
  • 如何迭代 Array.prototype 函数

    我想将所有数组函数包装在数组对象中 但在控制台中 gt gt gt Array prototype gt gt gt prototype undefined 但是当我输入时Array prototype在控制台中它显示自动完成中的所有功能
  • System.Diagnostics.Trace.WriteLine 的结果在哪里?

    在我的代码中 我使用以下命令编写了一些跟踪消息System Diagnostics Trace WriteLine 但是我可以从哪里获取消息呢 我查看了事件查看器 但没有找到它们 Are you debugging Look at the
  • 将 Google Maps JS API ImageMapType 剪辑为多边形

    如何将 Google 地图中的 MapType 剪辑为任意多边形 例如 如果我有一个自定义图像映射类型 https developers google com maps documentation javascript maptypes I