从 Google 地图中保存坐标 Javascript

save coordinates from Google Map in Javascript

你好,我有一个简单的问题!我想要一个带有 google 地图的标记,我将移动它,坐标 (lan,lon) 将保存在 Jsfiddle 的两个变量中 (Javascript).我找到了一个代码(带有 HTML 和 CSS),但它不是我需要的,因为它有两个标记并且它不同......提前非常感谢!

https://jsfiddle.net/irinikonsta/ryvpo5ux/

<!DOCTYPE html>
<title>Street View side-by-side</title>

<body>
  <div id="map"></div>
  <div id="pano"></div>
  <div id="floating-panel">
    Origin:
    <input type="text" readonly id="origin"> Destination:
    <input type="text" readonly id="destination">
    <br> Heading:
    <input type="text" readonly id="heading"> degrees
  </div>
  <script>
    var marker1, marker2;
    var poly, geodesicPoly;

    function initMap() {
      var map = new google.maps.Map(document.getElementById('map'), {
        zoom: 4,
        center: {
          lat: 37.983810,
          lng: 23.727539
        }
      });
      map.controls[google.maps.ControlPosition.TOP_CENTER].push(
        document.getElementById('info'));
      marker1 = new google.maps.Marker({
        map: map,
        draggable: true,
        position: {
          lat: 38.017973,
          lng: 23.694077
        }
      });
      marker2 = new google.maps.Marker({
        map: map,
        draggable: true,
        position: {
          lat: 37.990920,
          lng: 23.751755
        }
      });
      var bounds = new google.maps.LatLngBounds(
        marker1.getPosition(), marker2.getPosition());
      map.fitBounds(bounds);
      google.maps.event.addListener(marker1, 'position_changed', update);
      google.maps.event.addListener(marker2, 'position_changed', update);
      poly = new google.maps.Polyline({
        strokeColor: '#FF0000',
        strokeOpacity: 1.0,
        strokeWeight: 3,
        map: map,
      });
      geodesicPoly = new google.maps.Polyline({
        strokeColor: '#CC0099',
        strokeOpacity: 1.0,
        strokeWeight: 3,
        geodesic: true,
        map: map
      });
      update();
    }

    function update() {
      var path = [marker1.getPosition(), marker2.getPosition()];
      poly.setPath(path);
      geodesicPoly.setPath(path);
      var heading = google.maps.geometry.spherical.computeHeading(path[0],
        path[1]);
      document.getElementById('heading').value = heading;
      document.getElementById('origin').value = path[0].toString();
      document.getElementById('destination').value = path[1].toString();
    }

  </script>
  <script src="https://maps.googleapis.com/maps/api/jskey=AIzaSyBojvE89boyOqT01eKQd-UV_Dc4dpLRpzw&libraries=geometry&callback=initMap" async defer></script>
</body>

你的问题不是很清楚......Buuuut......你需要的是这样的东西http://jsfiddle.net/yorch/z67mxhbu/1/ ?

只需将 markerlatlng 保留为全局变量并在必要时存储它们(在本例中我选择了 dragend 事件,但您可以check all events here)

google.maps.event.addListener(marker, 'dragend', update);

然后在更新方法中发挥你的魔力,在我的例子中:

function update() {
  var path = marker.getPosition();
  lat = path.lat();
  lng = path.lng()
  alert("Lat: " + lat + "\nLon: " + lng);
}

注意: jsfiddle 基于 http://thinkingstiff.com/ in this answer

中的示例