LeafletJS - Spidol

Untuk menandai satu lokasi di peta, selebaran menyediakan penanda. Penanda ini menggunakan simbol standar dan simbol ini dapat disesuaikan. Di bab ini, kita akan melihat cara menambahkan penanda dan cara menyesuaikan, menghidupkan, dan menghapusnya.

Menambahkan Penanda Sederhana

Untuk menambahkan penanda ke peta menggunakan pustaka JavaScript Leaflet, ikuti langkah-langkah yang diberikan di bawah ini -

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 - Instantiate Marker kelas dengan melewati a latlng objek yang mewakili posisi yang akan ditandai, seperti yang ditunjukkan di bawah ini.

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

Step 5 - Tambahkan objek penanda yang dibuat pada langkah sebelumnya ke peta menggunakan addTo() metode dari Marker kelas.

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

Contoh

Kode berikut menetapkan penanda di kota bernama 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>

Ini menghasilkan output berikut -

Mengikat Pop-up ke Marker

Untuk mengikat popup sederhana yang menampilkan pesan ke penanda, ikuti langkah-langkah yang diberikan di bawah ini -

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 - Instantiate Marker kelas dengan melewati a latlng objek yang mewakili posisi yang akan ditandai.

Step 5 - Lampirkan popup ke penanda menggunakan bindPopup() seperti gambar dibawah.

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

Step 6 - Terakhir, tambahkan Marker objek yang dibuat pada langkah sebelumnya ke peta menggunakan addTo() metode dari Marker kelas.

Contoh

Kode berikut menetapkan penanda di kota Hyderabad (India) dan menambahkan pop-up padanya.

<!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>

Ini menghasilkan keluaran berikut

Opsi Penanda

Saat membuat penanda, Anda juga bisa memberikan marker optionsvariabel selain objek latlang. Dengan menggunakan variabel ini, Anda dapat menyetel nilai ke berbagai opsi penanda seperti ikon, dapat diseret, keyboard, judul, alt, zInsexOffset, opacity, riseOnHover, riseOffset, panel, dragable, dll.

Untuk membuat peta menggunakan opsi peta, Anda perlu mengikuti langkah-langkah yang diberikan di bawah ini -

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 - Buat variabel untuk markerOptions dan tentukan nilai ke opsi yang diperlukan.

Membuat markerOptions objek (dibuat seperti literal) dan nilai set untuk opsi iconUrl dan iconSize.

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

Step 5 - Instantiate Marker kelas dengan melewati a latlng objek yang mewakili posisi yang akan ditandai dan objek opsi, dibuat pada langkah sebelumnya.

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

Step 6 - Terakhir, tambahkan Marker objek yang dibuat pada langkah sebelumnya ke peta menggunakan addTo() metode dari Marker kelas.

Contoh

Kode berikut menetapkan penanda di kota Hyderabad (India). Penanda ini dapat diklik, dapat diseret dengan judulMyLocation.

<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>

Ini menghasilkan keluaran berikut

Ikon Kustom Penanda

Alih-alih ikon default yang disediakan oleh pustaka Leaflet, Anda juga dapat menambahkan ikon Anda sendiri. Anda dapat menggunakan langkah-langkah berikut untuk menambahkan ikon khusus ke peta daripada yang default.

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 - Buat variabel untuk markerOptions dan tentukan nilai ke opsi yang diperlukan -

  • iconUrl - Sebagai nilai untuk opsi ini, Anda harus meneruskan a String objek yang menentukan jalur gambar yang ingin Anda gunakan sebagai ikon.

  • iconSize - Dengan menggunakan opsi ini, Anda dapat menentukan ukuran ikon.

Note - Selain itu, Anda juga dapat menyetel nilai ke opsi lain seperti iconSize, shadowSize, iconAnchor, shadowAnchor, dan popupAnchor.

Buat ikon kustom menggunakan L.icon() dengan melewatkan variabel opsi di atas seperti yang ditunjukkan di bawah ini.

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

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

Step 5- Buat variabel untuk markerOptions dan tentukan nilai ke opsi yang diperlukan. Selain itu, tentukan ikon dengan meneruskan variabel ikon yang dibuat pada langkah sebelumnya sebagai nilai.

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

Step 6 - Instantiate Marker kelas dengan melewati a latlng objek yang mewakili posisi yang akan ditandai dan objek opsi dibuat pada langkah sebelumnya.

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

Step 7 - Terakhir, tambahkan Marker objek yang dibuat pada langkah sebelumnya ke peta menggunakan addTo() metode dari Marker kelas.

Contoh

Kode berikut menetapkan penanda di lokasi Tutorialspoint. Di sini kami menggunakan logo Tutorialspoint alih-alih penanda default.

<!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>

Ini menghasilkan keluaran berikut