LeafletJS - Marcadores

Para marcar una única ubicación en el mapa, el folleto proporciona marcadores. Estos marcadores utilizan un símbolo estándar y estos símbolos se pueden personalizar. En este capítulo, veremos cómo agregar marcadores y cómo personalizarlos, animarlos y eliminarlos.

Agregar un marcador simple

Para agregar un marcador a un mapa usando la biblioteca de JavaScript de Leaflet, siga los pasos que se detallan a continuación:

Step 1 - Crea un Mapobjeto pasando un elemento < div > (String u objeto) y opciones de mapa (opcional).

Step 2 - Crea un Layer objeto pasando la URL del mosaico deseado.

Step 3 - Agregue el objeto de capa al mapa usando el addLayer() método del Map clase.

Step 4 - Instancia del Marker clase pasando un latlng objeto que representa la posición a marcar, como se muestra a continuación.

// Creating a marker
var marker = new L.Marker([17.385044, 78.486671]);

Step 5 - Agregue el objeto marcador creado en los pasos anteriores al mapa usando el addTo() método del Marker clase.

// Adding marker to the map
marker.addTo(map);

Ejemplo

El siguiente código establece el marcador en la ciudad denominada Hyderabad (India).

<!DOCTYPE html>
<html>
   <head>
      <title>Leaflet sample</title>
      <link rel = "stylesheet" href = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css"/>
      <script src = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script>
   </head>
   
   <body>
      <div id = "map" style = "width:900px; height:580px"></div>
      <script>
         // Creating map options
         var mapOptions = {
            center: [17.385044, 78.486671],
            zoom: 10
         }
         // Creating a map object
         var map = new L.map('map', mapOptions);
         
         // Creating a Layer object
         var layer = new L.TileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');
         
         // Adding layer to the map
         map.addLayer(layer);
         
         // Creating a marker
         var marker = L.marker([17.385044, 78.486671]);
         
         // Adding marker to the map
         marker.addTo(map);
      </script>
   </body>
   
</html>

Genera la siguiente salida:

Vinculación de ventanas emergentes al marcador

Para vincular una ventana emergente simple que muestra un mensaje a un marcador, siga los pasos que se indican a continuación:

Step 1 - Crea un Mapobjeto pasando un elemento < div > (String u objeto) y opciones de mapa (opcional).

Step 2 - Crea un Layer objeto pasando la URL del mosaico deseado.

Step 3 - Agregue el objeto de capa al mapa usando el addLayer() método del Map clase.

Step 4 - Instancia del Marker clase pasando un latlng objeto que representa la posición a marcar.

Step 5 - Adjuntar ventana emergente al marcador usando bindPopup() Como se muestra abajo.

// Adding pop-up to the marker
marker.bindPopup('Hi Welcome to Tutorialspoint').openPopup();

Step 6 - Finalmente, agregue el Marker objeto creado en los pasos anteriores al mapa utilizando el addTo() método del Marker clase.

Ejemplo

El siguiente código establece el marcador en la ciudad de Hyderabad (India) y le agrega una ventana emergente.

<!DOCTYPE html>
<html>
   <head>
      <title>Binding pop-Ups to marker</title>
      <link rel = "stylesheet" href = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css"/>
      <script src = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script>
   </head>
   
   <body>
      <div id = "map" style = "width:900px; height:580px"></div>
      <script>
         // Creating map options
         var mapOptions = {
            center: [17.385044, 78.486671],
            zoom: 15
         }
         var map = new L.map('map', mapOptions); // Creating a map object
         
         // Creating a Layer object
         var layer = new L.TileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');
         map.addLayer(layer);         // Adding layer to the map
         var marker = L.marker([17.438139, 78.395830]);    // Creating a Marker
         
         // Adding popup to the marker
         marker.bindPopup('This is Tutorialspoint').openPopup();
         marker.addTo(map); // Adding marker to the map
      </script>
   </body>
   
</html>

Genera la siguiente salida

Opciones de marcador

Mientras crea un marcador, también puede pasar un marker optionsvariable además del objeto latlang. Con esta variable, puede establecer valores para varias opciones del marcador, como icono, dragable, teclado, título, alt, zInsexOffset, opacity, riseOnHover, riseOffset, panel, dragable, etc.

Para crear un mapa utilizando las opciones de mapa, debe seguir los pasos que se indican a continuación:

Step 1 - Crea un Mapobjeto pasando un elemento < div > (String u objeto) y opciones de mapa (opcional).

Step 2 - Crea un Layer objeto pasando la URL del mosaico deseado.

Step 3 - Agregue el objeto de capa al mapa usando el addLayer() método del Map clase.

Step 4 - Cree una variable para markerOptions y especifique valores para las opciones requeridas.

Crear un markerOptions objeto (se crea como un literal) y establece valores para las opciones iconUrl y iconSize.

// Options for the marker
var markerOptions = {
   title: "MyLocation",
   clickable: true,
   draggable: true
}

Step 5 - Instancia del Marker clase pasando un latlng objeto que representa la posición a marcar y el objeto de opciones, creado en el paso anterior.

// Creating a marker
var marker = L.marker([17.385044, 78.486671], markerOptions);

Step 6 - Finalmente, agregue el Marker objeto creado en los pasos anteriores al mapa utilizando el addTo() método del Marker clase.

Ejemplo

El siguiente código establece el marcador en la ciudad de Hyderabad (India). Se puede hacer clic en este marcador y se puede arrastrar con el título.MyLocation.

<html>
   <head>
      <title>Marker Options Example</title>
      <link rel = "stylesheet" href = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css"/>
      <script src = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script>
   </head>
   
   <body>
      <div id = "map" style = "width:900px; height:580px"></div>
      <script>
         // Creating map options
         var mapOptions = {
            center: [17.385044, 78.486671],
            zoom: 10
         }
         // Creating a map object
         var map = new L.map('map', mapOptions);
         
         // Creating a Layer object
         var layer = new L.TileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');
        
         // Adding layer to the map
         map.addLayer(layer);
         
         // Creating a Marker
         var markerOptions = {
            title: "MyLocation",
            clickable: true,
            draggable: true
         }
         // Creating a marker
         var marker = L.marker([17.385044, 78.486671], markerOptions);
         
         // Adding marker to the map
         marker.addTo(map);
      </script>
   </body>
   
</html>

Genera la siguiente salida

Iconos personalizados de marcadores

En lugar del icono predeterminado proporcionado por la biblioteca de folletos, también puede agregar su propio icono. Puede utilizar los siguientes pasos para agregar un icono personalizado al mapa en lugar del predeterminado.

Step 1 - Crea un Mapobjeto pasando un elemento < div > (String u objeto) y opciones de mapa (opcional).

Step 2 - Crea un Layer objeto pasando la URL del mosaico deseado.

Step 3 - Agregue el objeto de capa al mapa usando el addLayer() método del Map clase.

Step 4 - Crea una variable para markerOptions y especificar valores para las opciones requeridas -

  • iconUrl - Como valor de esta opción, debe pasar un String objeto que especifica la ruta de la imagen que desea utilizar como icono.

  • iconSize - Con esta opción, puede especificar el tamaño del icono.

Note - Además de estos, también puede establecer valores para otras opciones como iconSize, shadowSize, iconAnchor, shadowAnchor y popupAnchor.

Crea un icono personalizado usando L.icon() pasando la variable de opciones anterior como se muestra a continuación.

// Icon options
var iconOptions = {
   iconUrl: 'logo.png',
   iconSize: [50, 50]
}

// Creating a custom icon
var customIcon = L.icon(iconOptions);

Step 5- Cree una variable para markerOptions y especifique valores para las opciones requeridas. Además de estos, especifique el icono pasando la variable de icono creada en el paso anterior como valor.

// Options for the marker
var markerOptions = {
   title: "MyLocation",
   clickable: true,
   draggable: true,
   icon: customIcon
}

Step 6 - Instancia del Marker clase pasando un latlng objeto que representa la posición a marcar y el objeto de opciones creado en el paso anterior.

// Creating a marker
var marker = L.marker([17.438139, 78.395830], markerOptions);

Step 7 - Finalmente, agregue el Marker objeto creado en los pasos anteriores al mapa utilizando el addTo() método del Marker clase.

Ejemplo

El siguiente código establece el marcador en la ubicación de Tutorialspoint. Aquí estamos usando el logo de Tutorialspoint en lugar del marcador predeterminado.

<!DOCTYPE html>
<html>
   <head>
      <title>Marker Custom Icons Example</title>
      <link rel = "stylesheet" href = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css"/>
      <script src = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script>
   </head>
   
   <body>
      <div id = "map" style = "width:900px; height:580px"></div>
      <script>
         // Creating map options
         var mapOptions = {
            center: [17.438139, 78.395830],
            zoom: 10
         }
         // Creating a map object
         var map = new L.map('map', mapOptions);
         
         // Creating a Layer object
         var layer = new L.TileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');

         // Adding layer to the map
         map.addLayer(layer);
         
         // Icon options
         var iconOptions = {
            iconUrl: 'logo.png',
            iconSize: [50, 50]
         }
         // Creating a custom icon
         var customIcon = L.icon(iconOptions);
         
         // Creating Marker Options
         var markerOptions = {
            title: "MyLocation",
            clickable: true,
            draggable: true,
            icon: customIcon
         }
         // Creating a Marker
         var marker = L.marker([17.438139, 78.395830], markerOptions);
         
         // Adding popup to the marker
         marker.bindPopup('Hi welcome to Tutorialspoint').openPopup();
         
         // Adding marker to the map
         marker.addTo(map);
      </script>
   </body>
   
</html>

Genera la siguiente salida