javascript - 是否可以隐藏(切换)主 map 层并仅显示地面覆盖图像本身?

标签 javascript google-maps google-maps-api-3 gmsgroundoverlay

我有一个 groundOverlay 图像,我希望可以打开/关闭主 map ,以便只显示叠加图像。那可能吗?

PS:我使用的是 javascript api v3。

最佳答案

您可以实现一个自定义 MapType(不渲染 Tiles),然后您只需要在这个自定义 MapType 和一个内置 MapType(例如 ROADMAP)之间切换:

function initialize() {
  var goo = google.maps,
    map = new goo.Map(document.getElementById('map-canvas'), {
      zoom: 11,
      center: new goo.LatLng(40.740, -74.18),
      mapTypeControl: false

    }),

    mt = function() {
      this.getTile = function() {
        var n = document.createElement('div');
        n.style.cssText = 'background:#fff;width:256px;height:256px;';
        return n;
      };
      this.tileSize = new google.maps.Size(256, 256);
      this.maxZoom = 20;
    },
    //maptype-control
    mtc = document.createElement('div');

  mtc.id = 'mtc';
  map.controls[google.maps.ControlPosition.LEFT_BOTTOM].push(mtc);

  google.maps.event.addDomListener(mtc, 'click', function() {
    console.log(map.getMapTypeId())
    map.setMapTypeId((map.getMapTypeId() === 'hidden') ? google.maps.MapTypeId.ROADMAP : 'hidden');
  });
  google.maps.event.addListener(map, 'maptypeid_changed', function() {
    mtc.style.textDecoration = ((this.getMapTypeId() === 'hidden') ? 'none' : 'line-through');
  });

  map.mapTypes.set('hidden', new mt);
  map.setMapTypeId('hidden');

  new goo.GroundOverlay(
    'https://www.lib.utexas.edu/maps/historical/newark_nj_1922.jpg',
    new goo.LatLngBounds(
      new goo.LatLng(40.712216, -74.22655),
      new goo.LatLng(40.773941, -74.12544)
    ), {
      map: map
    }
  );

}

google.maps.event.addDomListener(window, 'load', initialize);
html,
body,
#map-canvas {
  height: 100%;
  margin: 0px;
  padding: 0px
}
#mtc {
  border: 1px solid #000;
  background: tomato;
  padding: 2px;
  margin: 4px;
  cursor: pointer;
  font-size: 1.4em;
  font-weight: bold;
  border-radius:2px;
}
#mtc:after {
  content: 'Tiles';
}
<script src="https://maps.googleapis.com/maps/api/js?v=3"></script>
<div id="map-canvas"></div>

关于javascript - 是否可以隐藏(切换)主 map 层并仅显示地面覆盖图像本身?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31355216/

相关文章:

java - onLocationChanged 被调用一次(Android Studio)

javascript - 在html map 中拖动线条并显示线条之间的差异

javascript - 从简单的 Google map v3 示例中删除标记

javascript - Google map ,用户创建标记,如何保存

javascript - 多个数组到 JavaScript 对象

javascript - 嵌入式媒体未显示在 TinyMCE 的 html 编辑器中

javascript - Eloquent JS 中的 "makeAddFunction"是如何工作的?

android - 从哪里了解 Android 中的 Google Maps API

javascript - Drupal 7 - Javascript 与 Google map 自动完成的集成问题

javascript 在数组元素中搜索