google maps - получить координаты перетаскиваемого маркера - PullRequest
1 голос
/ 04 января 2011

Я использую этот превосходный плагин jquery для работы с картами Google:

http://googlemaps.mayzes.org/

Я использую пример "Перетаскивание маркера карты".

После перетаскиваниямаркер, как я могу получить новые / текущие координаты маркера?

Спасибо

Ответы [ 3 ]

3 голосов
/ 04 января 2011

Я написал проект, который делает именно это, он использует версию 2 Google Maps API.Вот фрагмент кода для создания перетаскиваемого маркера, который будет показывать широту / долготу после того, как вы перетащите его в новое место на карте:

            function createMarker(latlng, number, html) {
                var marker = new GMarker(latlng, {draggable: true});
                marker.value = number;
                    var myHtml = html;
                    var center = marker.getLatLng();
                    map.openInfoWindowHtml(latlng, "<font color=black>" + myHtml + "<br>" + center.toString() + "</font>");
                GEvent.addListener(marker, "dragstart", function() {
                    map.closeInfoWindow();
                });
                GEvent.addListener(marker, "dragend", function() {
                    var center = marker.getLatLng();
                    marker.openInfoWindowHtml("<font color=black>" + myHtml + "<br>" + center.toString() + "</font>");
                });
                return marker;
            }
2 голосов
/ 26 мая 2012

Попробуйте что-то подобное, используя JavaScript и API Google Maps:

// update element with latest lat and lon
function updateMarkerPosition(latLng) {
  document.getElementById('ll').value = [
    latLng.lat(),
    latLng.lng()
  ].join(', ');
}

function initialize() {
  // look for any lat lon in url, to set map center
  if ($.urlParam('ll')) {
    var llparam = $.urlParam('ll').split(', ');
    var lat = parseFloat(llparam[0]);
    var lon = parseFloat(llparam[1]);
    var latLng = new google.maps.LatLng(lat, lon);
  } else {
    var latLng = new google.maps.LatLng(47.65130629733119, -122.34994607543945);
  }

  var map = new google.maps.Map(document.getElementById('mapCanvas'), {
    zoom: 12,
    center: latLng,
    mapTypeId: google.maps.MapTypeId.ROADMAP
  });

  var marker = new google.maps.Marker({
    position: latLng,
    map: map,
    draggable: true
  });

  // Update current position info.
  updateMarkerPosition(latLng);

  // Add dragging event listeners.

  google.maps.event.addListener(marker, 'drag', function() {
    updateMarkerPosition(marker.getPosition());
  });
}
0 голосов
/ 04 января 2011

Вы можете получить доступ к маркерам .latLng (), чтобы получить координаты любого маркера.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...