Añadir marcador al mapa de Google al hacer clic


Estoy sorprendentemente luchando para encontrar un ejemplo muy simple de cómo agregar un marcador(s) a un mapa de Google cuando un usuario hace clic en el mapa.

He mirado alrededor durante las últimas horas, y consultado la documentación de la API de Google Maps, y agradecería un poco de ayuda!

Author: duncan, 2013-04-03

5 answers

Después de mucho más investigación, me las arreglé para encontrar una solución.

google.maps.event.addListener(map, 'click', function(event) {
   placeMarker(event.latLng);
});

function placeMarker(location) {
    var marker = new google.maps.Marker({
        position: location, 
        map: map
    });
}
 149
Author: Andre R.,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2014-01-13 08:50:33

En 2017, la solución es:

map.addListener('click', function(e) {
    placeMarker(e.latLng, map);
});

function placeMarker(position, map) {
    var marker = new google.maps.Marker({
        position: position,
        map: map
    });
    map.panTo(position);
}
 29
Author: David Corral,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2017-03-30 16:02:43

Esto es en realidad una característica documentada, y se puede encontrar aquí

// This event listener calls addMarker() when the map is clicked.
  google.maps.event.addListener(map, 'click', function(e) {
    placeMarker(e.latLng, map);
  });

  function placeMarker(position, map) {
    var marker = new google.maps.Marker({
      position: position,
      map: map
    });  
    map.panTo(position);
  }
 18
Author: epson121,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2015-07-26 12:41:53

Actualmente el método para agregar el oyente al mapa sería

map.addListener('click', function(e) {
    placeMarker(e.latLng, map);
});

Y no

google.maps.event.addListener(map, 'click', function(e) {
    placeMarker(e.latLng, map);
});

Referencia

 6
Author: JamesWorth,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2016-11-11 15:58:38

@Chaibi Alaa, Puede establecer el marcador en el primer clic y luego simplemente cambiar la posición en los clics posteriores.

var marker;

google.maps.event.addListener(map, 'click', function(event) {

   placeMarker(event.latLng);

});

function placeMarker(location) {

 if (marker == null)
 {
   marker = new google.maps.Marker({
      position: location,
      map: map
  }); } else {   marker.setPosition(location); } }
 5
Author: Ahmed Samy,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/ajaxhispano.com/template/agent.layouts/content.php on line 61
2016-12-15 14:16:55