javascript - 如何从gmaps RECTANGLE(覆盖)中获取4个顶点坐标?

标签 javascript google-maps

如何从 gmaps RECTANGLE(叠加)中获取 4 个顶点坐标?

我只能从 selectedShape.getBounds() 获取 NE 和 SW 纬度

我需要一个 4 顶点矩形来在 MySQL php 函数中进行后处理检查。

最佳答案

西北=东北纬度,西南经度

东南 = 西南纬度,东北经度

var bounds = rectangle.getBounds();
var NE = bounds.getNorthEast();
var SW = bounds.getSouthWest();
// North West
var NW = new google.maps.LatLng(NE.lat(),SW.lng());
// South East
var SE = new google.maps.LatLng(SW.lat(),NE.lng());

example fiddle

代码片段:

var geocoder;
var map;

function initialize() {
  var map = new google.maps.Map(
    document.getElementById("map_canvas"), {
      center: new google.maps.LatLng(37.4419, -122.1419),
      zoom: 13,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });
  google.maps.event.addListenerOnce(map, 'bounds_changed', function() {
    var rectangle = new google.maps.Rectangle({
      bounds: map.getBounds()
    })
    var bounds = rectangle.getBounds();
    var NE = bounds.getNorthEast();
    var NEmark = new google.maps.Marker({
      map: map,
      position: NE,
      title: "NE"
    });
    var SW = bounds.getSouthWest();
    var SWmark = new google.maps.Marker({
      map: map,
      position: SW,
      title: "SW"
    });
    // North West
    var NW = new google.maps.LatLng(NE.lat(), SW.lng());
    var NWmark = new google.maps.Marker({
      map: map,
      position: NW,
      title: "NW"
    });
    // South East
    var SE = new google.maps.LatLng(SW.lat(), NE.lng());
    var SEmark = new google.maps.Marker({
      map: map,
      position: SE,
      title: "SE"
    });

    var polygon = new google.maps.Polygon({
      map: map,
      paths: [
        [NE, NW, SW, SE]
      ]
    });
    map.setZoom(map.getZoom() - 1);
  });
}
google.maps.event.addDomListener(window, "load", initialize);
html,
body,
#map_canvas {
  height: 100%;
  width: 100%;
  margin: 0px;
  padding: 0px
}
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCkUOdZ5y7hMm0yrcCQoCvLwzdM6M8s5qk"></script>
<div id="map_canvas"></div>

关于javascript - 如何从gmaps RECTANGLE(覆盖)中获取4个顶点坐标?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15536241/

相关文章:

javascript - 对象内部的函数无法正常工作 - Javascript

javascript - JS函数属性和内存

java - 屏幕关闭时获取 GPS 信息

android - 重新创建 map 后如何删除标记?

google-maps - 如何从Google map 获取最近的重要城镇?

jquery - 在AJAX上初始化Google map 刷新部分

javascript - 是否可以通过编程方式检测关闭?

javascript - 页面错误($.plot 不是函数)

javascript - onclick 打开最近的详细信息元素

javascript - 谷歌地图 API : calculate remaining time according to predefined route