LeafletJS - Grup Lapisan

Grup Lapisan

Dengan menggunakan grup lapisan, Anda dapat menambahkan beberapa lapisan ke peta dan mengelolanya sebagai satu lapisan.

Ikuti langkah-langkah yang diberikan di bawah ini untuk membuat file LayerGroup dan menambahkannya ke peta.

Step 1 - Buat Mapobjek dengan meneruskan elemen < div > (String atau objek) dan opsi peta (opsional).

Step 2 - Buat Layer objek dengan meneruskan URL ubin yang diinginkan.

Step 3 - Tambahkan objek lapisan ke peta menggunakan addLayer() metode dari Map kelas.

Step 4 - Membuat elemen (lapisan) seperti penanda, poligon, lingkaran, dll., Yang diperlukan, dengan membuat instance kelas masing-masing seperti yang ditunjukkan di bawah ini.

// Creating markers
var hydMarker = new L.Marker([17.385044, 78.486671]);
var vskpMarker = new L.Marker([17.686816, 83.218482]);
var vjwdMarker = new L.Marker([16.506174, 80.648015]);

// Creating latlng object
var latlngs = [
   [17.385044, 78.486671],
   [16.506174, 80.648015],
   [17.686816, 83.218482]
];
// Creating a polygon
var polygon = L.polygon(latlngs, {color: 'red'});

Step 5 - Buat Grup Lapisan menggunakan l.layerGroup(). Lewati penanda, poligon, dll yang dibuat di atas, seperti yang ditunjukkan di bawah ini.

// Creating layer group
var layerGroup = L.layerGroup([hydMarker, vskpMarker, vjwdMarker, polygon]);

Step 6 - Tambahkan grup lapisan yang dibuat pada langkah sebelumnya menggunakan addTo() metode.

// Adding layer group to map
layerGroup.addTo(map);

Contoh

Kode berikut membuat grup lapisan yang menampung 3 penanda dan poligon, dan menambahkannya ke peta.

<!DOCTYPE html>
<html>
   <head>
      <title>Leaflet Layer Group</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: 7
         }
         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
         
         // Creating markers
         var hydMarker = new L.Marker([17.385044, 78.486671]);
         var vskpMarker = new L.Marker([17.686816, 83.218482]);
         var vjwdMarker = new L.Marker([16.506174, 80.648015]);
         
         // Creating latlng object
         var latlngs = [
            [17.385044, 78.486671],
            [16.506174, 80.648015],
            [17.686816, 83.218482]
         ];
         // Creating a polygon
         var polygon = L.polygon(latlngs, {color: 'red'});
         
         // Creating layer group
         var layerGroup = L.layerGroup([hydMarker, vskpMarker, vjwdMarker, polygon]);
         layerGroup.addTo(map);    // Adding layer group to map
      </script>
   </body>
   
</html>

Ini menghasilkan output berikut -

Menambahkan lapisan (elemen)

Anda dapat menambahkan lapisan ke grup fitur menggunakan addLayer()metode. Untuk metode ini, Anda harus meneruskan elemen yang akan ditambahkan.

Anda dapat menambahkan lingkaran dengan kota Hyderabad di tengahnya.

// Creating a circle
var circle = L.circle([16.506174, 80.648015], 50000, {color: 'red', fillColor:
   '#f03', fillOpacity: 0} );

// Adding circle to the layer group
layerGroup.addLayer(circle);

Ini akan menghasilkan keluaran sebagai berikut. -

Menghapus Lapisan (Elemen)

Anda dapat menghapus lapisan dari grup fitur menggunakan removeLayer()metode. Untuk metode ini, Anda harus meneruskan elemen yang akan dihapus.

Anda dapat menghapus penanda pada kota bernama Vijayawada seperti yang ditunjukkan di bawah ini.

// Removing layer from map
layerGroup.removeLayer(vjwdMarker);

Ini akan menghasilkan keluaran sebagai berikut -

Grup Fitur

Ini mirip dengan LayerGrouptetapi memungkinkan kejadian mouse dan mengikat popup ke sana. Anda juga dapat mengatur gaya ke seluruh grup menggunakansetStyle() metode.

Ikuti langkah-langkah yang diberikan di bawah ini untuk membuat Grup Fitur dan menambahkannya ke peta.

Step 1 - Buat Mapobjek dengan meneruskan elemen < div > (String atau objek) dan opsi peta (opsional).

Step 2 - Buat Layer objek dengan meneruskan URL ubin yang diinginkan.

Step 3 - Tambahkan objek lapisan ke peta menggunakan addLayer() metode dari Map kelas.

Step 4 - Membuat elemen (lapisan) seperti penanda, poligon, dan lingkaran yang dibutuhkan, dengan membuat instance kelas masing-masing seperti yang ditunjukkan di bawah ini.

// Creating markers
var hydMarker = new L.Marker([17.385044, 78.486671]);
var vskpMarker = new L.Marker([17.686816, 83.218482]);
var vjwdMarker = new L.Marker([16.506174, 80.648015]);

// Creating latlng object
var latlngs = [
   [17.385044, 78.486671],
   [16.506174, 80.648015],
   [17.686816, 83.218482]
];
// Creating a polygon
var polygon = L.polygon(latlngs, {color: 'red'});>

Step 5 - Buat Grup Fitur menggunakan l.featureGroup(). Teruskan penanda, poligon, dll. Yang dibuat di atas, seperti yang ditunjukkan di bawah ini.

// Creating feature group
var featureGroup = L.featureGroup([hydMarker, vskpMarker, vjwdMarker, polygon]);

Step 6- Jika Anda menyetel gaya ke grup fitur, itu akan diterapkan ke setiap elemen (lapisan) di grup. Anda dapat melakukannya dengan menggunakansetStyle() metode dan ke metode ini, Anda perlu meneruskan nilai ke opsi seperti warna dan opasitas, dll.

Setel gaya ke grup fitur yang dibuat pada langkah di atas.

// Setting style to the feature group
featureGroup.setStyle({color:'blue',opacity:.5});

Step 7 - Ikat popup menggunakan bindPopup() metode, seperti yang ditunjukkan di bawah ini.

// Binding popup to the feature group
featureGroup.bindPopup("Feature Group");

Step 8 - Tambahkan grup fitur yang dibuat pada langkah sebelumnya menggunakan addTo() metode.

// Adding layer group to map
featureGroup.addTo(map);

Contoh

Kode berikut membuat grup fitur yang menampung 3 penanda dan poligon, dan menambahkannya ke peta.

<!DOCTYPE html>
<html>
   <head>
      <title>Leaflet Feature Group</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: 7
         }
         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
         
         // Creating markers
         var hydMarker = new L.Marker([17.385044, 78.486671]);
         var vskpMarker = new L.Marker([17.686816, 83.218482]);
         var vjwdMarker = new L.Marker([16.506174, 80.648015]);
         
         // Creating latlng object
         var latlngs = [
            [17.385044, 78.486671],
            [16.506174, 80.648015],
            [17.686816, 83.218482]
         ];
         var polygon = L.polygon(latlngs, {color: 'red'}); // Creating a polygon
         
         // Creating feature group
         var featureGroup = L.featureGroup([hydMarker, vskpMarker, vjwdMarker, polygon]);
         featureGroup.setStyle({color:'blue',opacity:.5});
         featureGroup.bindPopup("Feature Group");
         featureGroup.addTo(map);      // Adding layer group to map
      </script>
   </body>
   
</html>

Ini menghasilkan output berikut -