LeafletJS - Hızlı Kılavuz
Leaflet.js nedir
Leaflet.js, basit, etkileşimli, hafif web haritalarını dağıtabileceğimiz açık kaynaklı bir kitaplıktır.
Broşür JavaScript kitaplığı, Döşeme katmanları, WMS, İşaretleyiciler, Açılır Pencereler, Vektör katmanları (çoklu çizgiler, çokgenler, daireler vb.), Görüntü bindirmeleri ve GeoJSON gibi katmanları kullanmanıza olanak tanır.
Broşür haritalarıyla haritayı sürükleyerek, yakınlaştırarak (çift tıklayarak veya tekerlek kaydırarak), klavyeyi kullanarak, olay işlemeyi kullanarak ve işaretçileri sürükleyerek etkileşime girebilirsiniz.
Leaflet, masaüstünde Chrome, Firefox, Safari 5+, Opera 12+, IE 7–11 gibi tarayıcıları ve mobil cihazlar için Safari, Android, Chrome, Firefox gibi tarayıcıları destekler.
Haritayı Web Sayfasına Yükleme Adımları
Web sayfanıza bir harita yüklemek için aşağıdaki adımları izleyin -
1. Adım: Bir HTML Sayfası Oluşturun
İle temel bir HTML sayfası oluşturun head ve body aşağıda gösterildiği gibi etiketler -
<!DOCTYPE html>
<html>
<head>
</head>
<body>
...........
</body>
</html>
Adım 2: Broşür CSS Komut Dosyasını Yükleyin
Broşür CSS komut dosyasını örneğe dahil edin -
<head>
<link rel = "stylesheet" href = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css" />
</head>
Adım 3: Broşür Komut Dosyasını Yükleyin
Leaflet API'yi komut dosyası etiketini kullanarak yükleyin veya dahil edin -
<head>
<script src = "http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script>
</head>
4. Adım: Kapsayıcıyı Oluşturun
Haritayı tutmak için bir konteyner öğesi oluşturmalıyız. Genellikle bu amaç için <div> etiketi (genel bir kapsayıcı) kullanılır.
Bir kap öğesi oluşturun ve boyutlarını tanımlayın -
<div id = "sample" style = "width:900px; height:580px;"></div>
Adım 5: Harita Seçenekleri
Broşür, Kontrol seçenekleri, Etkileşim Seçenekleri, Harita Durumu Seçenekleri, Animasyon Seçenekleri vb. Türleri gibi çeşitli seçenekler sunar. Bunlara değerler ayarlayarak haritayı istediğiniz gibi özelleştirebiliriz.
Oluşturmak mapOptions nesne (tıpkı bir değişmez gibi oluşturulur) ve merkez ve yakınlaştırma seçenekleri için değerleri ayarlayın, burada
center - Bu seçeneğin bir değeri olarak, bir LatLngharitayı ortalamak istediğimiz konumu belirten nesne. (Sadece içindeki enlem ve boylam değerlerini belirtin[] parantez)
zoom - Bu seçeneğin bir değeri olarak, aşağıda gösterildiği gibi, haritanın yakınlaştırma seviyesini temsil eden bir tamsayı geçirmeniz gerekir.
var mapOptions = {
center: [17.385044, 78.486671],
zoom: 10
}
6. Adım: Bir Harita Nesnesi Oluşturun
Kullanmak Mapbroşür API sınıfı, bir sayfada bir harita oluşturabilirsiniz. Çağrılanları örnekleyerek bir harita nesnesi oluşturabilirsiniz.MapLeaflet API. Bu sınıfı başlatırken, iki parametre aktarmanız gerekir -
Bu seçeneğin bir parametresi olarak, DOM kimliğini veya <div> öğesinin bir örneğini temsil eden bir String değişkeni iletmeniz gerekir. Burada <div> öğesi, haritayı tutmak için bir HTML kabıdır.
Harita seçenekleriyle isteğe bağlı bir nesne değişmezi.
Önceki adımda oluşturulan <div> öğesinin ve mapOptions nesnesinin kimliğini ileterek bir Map nesnesi oluşturun.
var map = new L.map('map', mapOptions);
7. Adım: Katman Nesnesini Oluşturma
Örneğini oluşturarak çeşitli harita türlerini (döşeme katmanları) yükleyebilir ve görüntüleyebilirsiniz. TileLayersınıf. Bunun örneğini oluştururken, bir String değişkeni biçiminde servis sağlayıcıdan istenen döşeme katmanını (harita) isteyen bir URL şablonunu iletmeniz gerekir.
Döşeme katmanı nesnesini aşağıda gösterildiği gibi oluşturun.
var layer = new L.TileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');
Burada kullandık openstreetmap.
8. Adım: Haritaya Katman Ekleyin
Son olarak, önceki adımda oluşturulan katmanı, addlayer() yöntemi aşağıda gösterildiği gibi.
map.addLayer(layer);
Misal
Aşağıdaki örnek, bir open street map Haydarabad şehrinin yakınlaştırma değeri 10.
<!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);
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
Broşür Harita Sağlayıcıları
Tıpkı open street map, Open Topo, Thunder forest, Hydda, ESRI, Open weather, NASA GIBS, vb. gibi çeşitli servis sağlayıcıların katmanlarını yükleyebilirsiniz. Bunu yapmak için, oluştururken ilgili URL'lerini iletmeniz gerekir. TileLayer nesne
var layer = new L.TileLayer('URL of the required map');
Aşağıdaki tablo, URL'leri ve Openstreetmap tarafından sağlanan katmanların ilgili örnek haritalarını listeler.
Harita türü | URL ve Çıktı |
---|---|
Mapnik | http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png
|
Siyah ve beyaz | http://{s}.tiles.wmflabs.org/bw-mapnik/{z}/{x}/{y}.png
|
DE | http://{s}.tile.openstreetmap.de/tiles/osmde/{z}/{x}/ {y}.png
|
Fransa | http://{s}.tile.openstreetmap.fr/osmfr/{z}/{x}/{y}.png
|
Sıcak | http://{s}.tile.openstreetmap.fr/hot/{z}/{x}/{y}.png
|
BZH | http://tile.openstreetmap.bzh/br/{z}/{x}/{y}.png
|
Harita üzerinde tek bir konumu işaretlemek için, broşür işaretçiler sağlar. Bu işaretçiler standart bir sembol kullanır ve bu semboller özelleştirilebilir. Bu bölümde, işaretçilerin nasıl ekleneceğini ve bunların nasıl özelleştirileceğini, canlandırılacağını ve kaldırılacağını göreceğiz.
Basit Bir İşaretçi Ekleme
Leaflet JavaScript kitaplığını kullanarak bir haritaya işaretçi eklemek için, aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Örnekleyin Marker sınıf geçerek latlng aşağıda gösterildiği gibi işaretlenecek konumu temsil eden nesne.
// Creating a marker
var marker = new L.Marker([17.385044, 78.486671]);
Step 5 - Önceki adımlarda oluşturulan işaretçi nesnesini kullanarak haritaya ekleyin. addTo() yöntemi Marker sınıf.
// Adding marker to the map
marker.addTo(map);
Misal
Aşağıdaki kod, Haydarabad (Hindistan) adlı şehirdeki işaretçiyi belirler.
<!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>
Aşağıdaki çıktıyı üretir -
Pop-up'ları İşaretleyiciye Bağlama
Bir işaretleyiciye bir mesaj görüntüleyen basit bir açılır pencereyi bağlamak için, aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Örnekleyin Marker sınıf geçerek latlng işaretlenecek konumu temsil eden nesne.
Step 5 - Açılır pencereyi kullanarak işaretçiye ekleyin bindPopup() Aşağıda gösterildiği gibi.
// Adding pop-up to the marker
marker.bindPopup('Hi Welcome to Tutorialspoint').openPopup();
Step 6 - Son olarak, ekleyin Marker kullanılarak haritaya önceki adımlarda oluşturulan nesne addTo() yöntemi Marker sınıf.
Misal
Aşağıdaki kod, Haydarabad (Hindistan) şehrindeki işaretçiyi ayarlar ve ona bir açılır pencere ekler.
<!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>
Aşağıdaki çıktıyı üretir
İşaretçi Seçenekleri
Bir işaretçi oluştururken, bir marker optionsLatlang nesnesine ek olarak değişken. Bu değişkeni kullanarak, simge, sürüklenebilir, klavye, başlık, alt, zInsexOffset, opaklık, yükselmeOnHover, yükselmeOffset, bölme, sürüklenebilir vb. Gibi çeşitli işaret seçeneklerine değerler ayarlayabilirsiniz.
Harita seçeneklerini kullanarak bir harita oluşturmak için, aşağıda verilen adımları izlemeniz gerekir -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - markerOptions için bir değişken oluşturun ve gerekli seçenekler için değerleri belirtin.
Oluşturmak markerOptions nesne (tıpkı bir değişmez gibi oluşturulur) ve seçenekler için değerleri ayarlayın iconUrl ve iconSize.
// Options for the marker
var markerOptions = {
title: "MyLocation",
clickable: true,
draggable: true
}
Step 5 - Örnekleyin Marker sınıf geçerek latlng önceki adımda oluşturulan, işaretlenecek konumu ve seçenekler nesnesini temsil eden nesne.
// Creating a marker
var marker = L.marker([17.385044, 78.486671], markerOptions);
Step 6 - Son olarak, ekleyin Marker kullanılarak haritaya önceki adımlarda oluşturulan nesne addTo() yöntemi Marker sınıf.
Misal
Aşağıdaki kod, Haydarabad (Hindistan) şehrinin işaretleyicisini belirler. Bu işaretçi tıklanabilir, başlıkla sürüklenebilirMyLocation.
<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>
Aşağıdaki çıktıyı üretir
İşaretçi Özel Simgeleri
Broşür kitaplığı tarafından sağlanan varsayılan simge yerine kendi simgenizi de ekleyebilirsiniz. Haritaya varsayılan simge yerine özel bir simge eklemek için aşağıdaki adımları kullanabilirsiniz.
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - için bir değişken oluşturun markerOptions ve gerekli seçenekler için değerler belirtin -
iconUrl - Bu seçeneğin bir değeri olarak, bir String simge olarak kullanmak istediğiniz görüntünün yolunu belirten nesne.
iconSize - Bu seçeneği kullanarak simgenin boyutunu belirleyebilirsiniz.
Note - Bunlara ek olarak, iconSize, shadowSize, iconAnchor, shadowAnchor ve popupAnchor gibi diğer seçeneklere de değerler ayarlayabilirsiniz.
Kullanarak özel bir simge oluşturun L.icon() yukarıdaki seçenekler değişkenini aşağıda gösterildiği gibi geçirerek.
// Icon options
var iconOptions = {
iconUrl: 'logo.png',
iconSize: [50, 50]
}
// Creating a custom icon
var customIcon = L.icon(iconOptions);
Step 5- markerOptions için bir değişken oluşturun ve gerekli seçenekler için değerleri belirtin. Bunlara ek olarak, önceki adımda oluşturulan simge değişkenini bir değer olarak ileterek simgeyi belirtin.
// Options for the marker
var markerOptions = {
title: "MyLocation",
clickable: true,
draggable: true,
icon: customIcon
}
Step 6 - Örnekleyin Marker sınıf geçerek latlng işaretlenecek konumu ve önceki adımda oluşturulan seçenekler nesnesini temsil eden nesne.
// Creating a marker
var marker = L.marker([17.438139, 78.395830], markerOptions);
Step 7 - Son olarak, ekleyin Marker kullanılarak haritaya önceki adımlarda oluşturulan nesne addTo() yöntemi Marker sınıf.
Misal
Aşağıdaki kod, işaretleyiciyi Tutorialspoint'in konumuna ayarlar. Burada varsayılan işaretçi yerine Tutorialspoint logosunu kullanıyoruz.
<!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>
Aşağıdaki çıktıyı üretir
Önceki bölümde, Leaflet'te işaretleyicilerin nasıl kullanılacağını öğrendik. İşaretçilerin yanı sıra, daire, çokgen, dikdörtgen, sürekli çizgi gibi çeşitli şekiller de ekleyebiliriz. Bu bölümde, Google Haritalar tarafından sağlanan şekilleri nasıl kullanacağımızı tartışacağız.
Çoklu çizgi
Leaflet JavaScript kitaplığını kullanarak bir harita üzerinde çoklu çizgi kaplaması çizmek için, aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Bir latlangs değişken, aşağıda gösterildiği gibi çoklu çizgi çizmek için noktaları tutmak için.
// Creating latlng object
var latlngs = [
[17.385044, 78.486671],
[16.506174, 80.648015],
[17.000538, 81.804034],
[17.686816, 83.218482]
];
Step 5 - kullanarak bir çoklu çizgi oluşturun L.polyline(). Çoklu çizgiyi çizmek için konumları değişken olarak geçirin ve çizgilerin rengini belirleme seçeneğini seçin.
// Creating a poly line
var polyline = L.polyline(latlngs, {color: 'red'});
Step 6 - Çoklu çizgiyi kullanarak haritaya ekleyin. addTo() yöntemi Polyline sınıf.
// Adding to poly line to map
polyline.addTo(map);
Misal
Aşağıda, Haydarabad, Vijayawada, Rajamahendrawaram ve Vishakhapatnam (Hindistan) şehirlerini kapsayan bir çoklu çizgi çizen kod bulunmaktadır.
DOCTYPE html>
<html>
<head>
<title>Leaflet Poly lines</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: [16.506174, 80.648015],
zoom: 7
}
// 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 latlng object
var latlngs = [
[17.385044, 78.486671],
[16.506174, 80.648015],
[17.000538, 81.804034],
[17.686816, 83.218482]
];
// Creating a poly line
var polyline = L.polyline(latlngs, {color: 'red'});
// Adding to poly line to map
polyline.addTo(map);
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir
Çokgen
Leaflet JavaScript kitaplığını kullanarak bir harita üzerine bir poligon yer paylaşımı çizmek için, aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Bir latlangs çokgeni çizmek için noktaları tutan değişken.
// Creating latlng object
var latlngs = [
[17.385044, 78.486671],
[16.506174, 80.648015],
[17.686816, 83.218482]
];
Step 5 - kullanarak bir çokgen oluşturun L.polygon(). Çokgeni çizmek için konumları / noktaları değişken olarak ve çokgenin rengini belirtmek için bir seçenek olarak aktarın.
// Creating a polygon
var polygon = L.polygon(latlngs, {color: 'red'});
Step 6 - Şunu kullanarak çokgeni haritaya ekleyin addTo() yöntemi Polygon sınıf.
// Adding to polygon to map
polygon.addTo(map);
Misal
Aşağıda, Haydarabad, Vijayawada ve Vishakhapatnam (Hindistan) şehirlerini kapsayan bir çokgen çizmek için kod verilmiştir.
<!DOCTYPE html>
<html>
<head>
<title>Leaflet Polygons</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: [16.506174, 80.648015],
zoom: 7
}
// 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 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'});
// Adding to polygon to map
polygon.addTo(map);
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
Dikdörtgen
Leaflet JavaScript kitaplığını kullanarak bir haritada Dikdörtgen bindirme çizmek için, aşağıda verilen adımları izleyin
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Harita üzerinde bir dikdörtgen çizmek için noktaları tutan bir latlangs değişkeni oluşturun.
// Creating latlng object
var latlngs = [
[17.342761, 78.552432],
[16.396553, 80.727725]
];
Step 5 - kullanarak bir dikdörtgen oluşturun. L.rectangle()işlevi. Bir dikdörtgen çizmek için konumları / noktaları bir değişken olarak geçirin verectangleOptions dikdörtgenin rengini ve ağırlığını belirtmek için.
// Creating rectOptions
var rectOptions = {color: 'Red', weight: 1}
// Creating a rectangle
var rectangle = L.rectangle(latlngs, rectOptions);
Step 6 - Dikdörtgeni haritaya ekleyin. addTo() yöntemi Polygon sınıf.
// Adding to rectangle to map
rectangle.addTo(map);
Misal
Aşağıda, Leaflet JavaScript kitaplığını kullanarak harita üzerinde bir dikdörtgen çizme kodu verilmiştir.
<!DOCTYPE html>
<html>
<head>
<title>Leaflet Rectangle</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: [16.506174, 80.648015],
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 latlng object
var latlngs = [
[17.342761, 78.552432],
[16.396553, 80.727725]
];
var rectOptions = {color: 'Red', weight: 1} // Creating rectOptions
// Creating a rectangle
var rectangle = L.rectangle(latlngs, rectOptions);
rectangle.addTo(map); // Adding to rectangle to map
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
Daire
Leaflet JavaScript kitaplığını kullanarak bir harita üzerine daire bindirmesi çizmek için aşağıda verilen adımları izleyin.
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Aşağıda gösterildiği gibi dairenin merkezini tutmak için bir latlangs değişkeni oluşturun.
// Center of the circle
var circleCenter = [17.385044, 78.486671];
Step 5 - Renk, fillColor ve fillOpacity seçeneklerine aşağıda gösterildiği gibi değerler belirlemek için değişken bir circleOptions oluşturun.
// Circle options
var circleOptions = {
color: 'red',
fillColor: '#f03',
fillOpacity: 0
}
Step 6 - kullanarak bir çevre oluşturun L.circle(). Dairenin merkezini, yarıçapı ve daire seçeneklerini bu işleve aktarın.
// Creating a circle
var circle = L.circle(circleCenter, 50000, circleOptions);
Step 7 - Yukarıda oluşturulan daireyi kullanarak haritaya ekleyin addTo() yöntemi Polyline sınıf.
// Adding circle to the map
circle.addTo(map);
Misal
Aşağıda, Haydarabad şehrinin koordinatlarını yarıçapı olarak gösteren bir daire çizmek için kod verilmiştir.
<!DOCTYPE html>
<html>
<head>
<title>Leaflet Circle</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
var circleCenter = [17.385044, 78.486671]; // Center of the circle
// Circle options
var circleOptions = {
color: 'red',
fillColor: '#f03',
fillOpacity: 0
}
// Creating a circle
var circle = L.circle(circleCenter, 50000, circleOptions);
circle.addTo(map); // Adding circle to the map
</script>
</body>
</html>>
Aşağıdaki çıktıyı üretir -
Önceki bölümde, çemberler, çokgenler, dikdörtgenler, sürekli çizgiler, vb. Gibi çeşitli şekilleri nasıl ekleyeceğimizi öğrendik. Bu bölümde, çoklu-çokgenlerin, çoklu dikdörtgenin ve sürekli çizgilerin nasıl ekleneceğini tartışalım.
Çoklu Çizgi
Leaflet JavaScript kitaplığını kullanarak bir harita üzerinde çoklu çoklu çizgi yer paylaşımı çizmek için aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Çoklu çoklu çizgiyi çizmek için noktaları tutan bir latlangs değişkeni oluşturun.
// Creating latlng object
var latlang = [
[[17.385044, 78.486671], [16.506174, 80.648015], [17.686816, 83.218482]],
[[13.082680, 80.270718], [12.971599, 77.594563],[15.828126, 78.037279]]
];
Step 5 - kullanarak bir çoklu çoklu çizgi oluşturun L.multiPolyline()işlevi. Çoklu çoklu çizgi çizmek için konumları değişken olarak ve çizgilerin rengini ve ağırlığını belirtmek için bir seçenek olarak aktarın.
// Creating multi polyline options
var multiPolyLineOptions = {color:'red'};
// Creating multi polylines
var multipolyline = L.multiPolyline(latlang , multiPolyLineOptions);
Step 6 - haritaya çoklu çoklu çizgi ekleyin addTo() yöntemi Multipolyline sınıf.
// Adding multi polyline to map
multipolyline.addTo(map);
Misal
Aşağıda, Haydarabad, Vijayawada ve Vishakhapatnam şehirlerini kapsayan bir çoklu çizgi çizmek için kod yer almaktadır; ve Kurnool, Bengaluru ve Chennai.
<!DOCTYPE html>
<html>
<head>
<title>Leaflet Multi Polylines</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: [16.506174, 80.648015],
zoom: 7
}
// 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 latlng object
var latlang = [
[[17.385044, 78.486671], [16.506174, 80.648015], [17.686816, 83.218482]],
[[13.082680, 80.270718], [12.971599, 77.594563],[15.828126, 78.037279]]
];
// Creating poly line options
var multiPolyLineOptions = {color:'red'};
// Creating multi poly-lines
var multipolyline = L.multiPolyline(latlang , multiPolyLineOptions);
// Adding multi poly-line to map
multipolyline.addTo(map);
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
Çok Çokgen
Leaflet JavaScript kitaplığını kullanarak bir harita üzerinde çok poligonlu bir yer paylaşımı çizmek için, aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Çoklu çokgeni çizecek noktaları tutmak için bir latlangs değişkeni oluşturun.
// Creating latlng object
var latlang = [
[[17.385044, 78.486671], [16.506174, 80.648015], [17.686816, 83.218482]],
[[13.082680, 80.270718], [12.971599, 77.594563],[15.828126, 78.037279]]
];
Step 5 - kullanarak bir çoklu çokgen oluşturun L.multiPolygon()işlevi. Çoklu çokgeni çizmek için konumları değişken olarak ve çizgilerin rengini ve ağırlığını belirtmek için bir seçenek olarak aktarın.
// Creating multi polygon options
var multiPolygonOptions = {color:'red'};
// Creating multi polygon
var multipolygon = L.multiPolygon(latlang , multiPolygonOptions);
Step 6 - Çoklu poligonu kullanarak haritaya ekleyin. addTo() yöntemi MultiPolygon sınıf.
// Adding multi polygon to map
multipolygon.addTo(map);
Misal
Aşağıda, Haydarabad, Vijayawada ve Vishakhapatnam şehirlerine dokunan bir çok-çokgen çizmek için kod verilmiştir; ve Kurnool, Bengaluru ve Chennai.
<!DOCTYPE html>
<html>
<head>
<title>Leaflet Multi Polygons</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: [16.506174, 80.648015],
zoom: 7
}
// 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 latlng object
var latlang = [
[[17.385044, 78.486671], [16.506174, 80.648015], [17.686816, 83.218482]],
[[13.082680, 80.270718], [12.971599, 77.594563],[15.828126, 78.037279]]
];
// Creating multi polygon options
var multiPolygonOptions = {color:'red', weight:8};
// Creating multi polygons
var multipolygon = L.multiPolygon(latlang , multiPolygonOptions);
// Adding multi polygon to map
multipolygon.addTo(map);
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
Katman Grupları
Katman grubunu kullanarak, bir haritaya birden çok katman ekleyebilir ve bunları tek bir katman olarak yönetebilirsiniz.
Bir oluşturmak için aşağıda verilen adımları izleyin. LayerGroup ve haritaya ekleyin.
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Aşağıda gösterildiği gibi ilgili sınıfları örnekleyerek ihtiyaç duyulan işaretçiler, çokgenler, daireler vb. Öğeleri (katmanlar) oluşturun.
// 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 - kullanarak Katman Grubunu oluşturun l.layerGroup(). Yukarıda oluşturulan işaretleri, çokgenleri vb. Aşağıda gösterildiği gibi geçirin.
// Creating layer group
var layerGroup = L.layerGroup([hydMarker, vskpMarker, vjwdMarker, polygon]);
Step 6 - Önceki adımda oluşturulan katman grubunu, addTo() yöntem.
// Adding layer group to map
layerGroup.addTo(map);
Misal
Aşağıdaki kod, 3 işaretçi ve bir çokgen içeren bir katman grubu oluşturur ve bunu haritaya ekler.
<!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>
Aşağıdaki çıktıyı üretir -
Bir katman (öğe) ekleme
Özellik grubuna bir katman ekleyebilirsiniz. addLayer()yöntem. Bu yönteme eklenecek elementi geçmeniz gerekmektedir.
Merkezde Haydarabad şehri ile bir daire ekleyebilirsiniz.
// 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);
Aşağıdaki çıktıyı üretecektir. -
Bir Katmanı (Eleman) Kaldırma
Özellik grubundan bir katmanı kaldırabilirsiniz. removeLayer()yöntem. Bu yönteme, kaldırılacak öğeyi iletmeniz gerekir.
Vijayawada isimli şehirdeki işaretleyiciyi aşağıda gösterildiği gibi kaldırabilirsiniz.
// Removing layer from map
layerGroup.removeLayer(vjwdMarker);
Aşağıdaki çıktıyı üretecektir -
Özellik Grupları
Benzer LayerGroupancak fare olaylarına izin verir ve açılır pencereleri ona bağlar. Ayrıca şunu kullanarak tüm gruba stil ayarlayabilirsiniz.setStyle() yöntem.
Bir Özellik Grubu oluşturmak ve bunu haritaya eklemek için aşağıda verilen adımları izleyin.
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Aşağıda gösterildiği gibi ilgili sınıfları örnekleyerek ihtiyaç duyulan işaretçiler, çokgenler ve daireler gibi öğeleri (katmanlar) oluşturun.
// 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 - kullanarak Özellik Grubu oluşturun l.featureGroup(). Yukarıda oluşturulan işaretleri, çokgenleri vb. Aşağıda gösterildiği gibi geçirin.
// Creating feature group
var featureGroup = L.featureGroup([hydMarker, vskpMarker, vjwdMarker, polygon]);
Step 6- Özellik grubuna stil ayarlarsanız, gruptaki her öğeye (katman) uygulanır. Bunu kullanarak yapabilirsinizsetStyle() yöntem ve bu yönteme renk ve opaklık vb. seçeneklere değer aktarmanız gerekir.
Stili, yukarıdaki adımda oluşturulan özellik grubuna ayarlayın.
// Setting style to the feature group
featureGroup.setStyle({color:'blue',opacity:.5});
Step 7 - Açılır pencereyi kullanarak bindPopup() yöntemi aşağıda gösterildiği gibi.
// Binding popup to the feature group
featureGroup.bindPopup("Feature Group");
Step 8 - Önceki adımda oluşturulan özellik grubunu, addTo() yöntem.
// Adding layer group to map
featureGroup.addTo(map);
Misal
Aşağıdaki kod, 3 işaretçi ve bir çokgen içeren bir özellik grubu oluşturur ve bunu haritaya ekler.
<!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>
Aşağıdaki çıktıyı üretir -
Leaflet JavaScript programı, kullanıcı tarafından oluşturulan çeşitli olaylara yanıt verebilir. Bu bölümde, Leaflet ile çalışırken olay işlemenin nasıl gerçekleştirileceğini gösteren birkaç örnek vereceğiz.
Olay işleme
Haritaya olay eklemek için aşağıda verilen adımları izleyin.
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - İşleyiciyi aşağıda gösterildiği gibi haritaya ekleyin.
map.on("click", function(e){
new L.Marker([e.latlng.lat, e.latlng.lng]).addTo(map);
})
Misal
Aşağıdaki kod, Leaflet kullanarak bile işlemeyi gösterir. Yürütüldüğünde, haritayı tıklarsanız, o belirli konumda bir işaretçi oluşturulacaktır.
<!DOCTYPE html>
<html>
<head>
<title>Leaflet Polygons</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: [16.506174, 80.648015],
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
map.on("click", function(e){
new L.Marker([e.latlng.lat, e.latlng.lng]).addTo(map);
})
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
Leaflet uygulamasında harita katmanları yerine görüntü, video katmanları da kullanabilirsiniz. Bu bölümde, bu tür kaplamaları nasıl kullanacağımızı göreceğiz.
Görüntü Bindirme
Bir görüntü bindirmesi kullanmak için aşağıda verilen adımları izleyin.
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - kullanarak görüntü bindirmesini oluşturun L.imageOverlay(). Görüntünün URL'sini ve görüntü sınırlarını temsil eden bir nesneyi aşağıda gösterildiği gibi iletin.
// Creating Image overlay
var imageUrl = 'tpPoster.jpg';
var imageBounds = [[17.342761, 78.552432], [16.396553, 80.727725]];
var overlay = L.imageOverlay(imageUrl, imageBounds);
Step 5 - Bindirmeyi kullanarak haritaya ekleyin addTo() yöntemi imageOverlay sınıf, aşağıda gösterildiği gibi.
// Adding overlay to the map
overlay.addTo(map);
Misal
Aşağıdaki kod, görüntü bindirmenin kullanımını gösterir.
<!DOCTYPE html>
<html>
<head>
<title>Image Overlay 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.342761, 78.552432],
zoom: 8
}
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 Image overlay
var imageUrl = 'tpPoster.jpg';
var imageBounds = [[17.342761, 78.552432], [16.396553, 80.727725]];
var overlay = L.imageOverlay(imageUrl, imageBounds);
overlay.addTo(map);
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
Broşür yakınlaştırma, atıf, ölçek vb. Gibi çeşitli kontroller sağlar, burada -
Zoom- Varsayılan olarak, bu kontrol haritanın sol üst köşesinde bulunur. İki düğmesi var"+" ve "–", bunu kullanarak haritayı yakınlaştırabilir veya uzaklaştırabilirsiniz. Varsayılan yakınlaştırma kontrolünü kaldırabilirsiniz.zoomControl harita seçeneklerinin seçeneği false.
Attribution- Varsayılan olarak, bu kontrol haritanın sağ alt köşesinde bulunur. İlişkilendirme verilerini küçük bir metin kutusunda görüntüler. Varsayılan olarak metni görüntüler. Varsayılan atıf kontrolünü şu ayarlarla kaldırabilirsiniz:attributionControl harita seçeneklerinin seçeneği false.
Scale- Varsayılan olarak, bu kontrol haritanın sol alt köşesinde bulunur. Ekranın mevcut merkezini görüntüler.
Bu bölümde, Leaflet JavaScript kitaplığını kullanarak bu üç kontrolü nasıl oluşturup haritanıza ekleyebileceğinizi açıklayacağız.
Yakınlaştır
Leaflet JavaScript kitaplığını kullanarak haritaya kendi yakınlaştırma kontrolünüzü eklemek için, aşağıda verilen adımları izleyin -
Step 1 - Bir Map bir öğe (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - zoomOptions değişkenini oluşturun ve yakınlaştırma ve uzaklaştırma seçenekleri için varsayılan değerler (+ ve -) yerine kendi metin değerlerinizi tanımlayın.
Ardından, zoomOptions değişkenini şuraya ileterek yakınlaştırma denetimini oluşturun. L.control.zoom() Aşağıda gösterildiği gibi.
// zoom control options
var zoomOptions = {
zoomInText: '1',
zoomOutText: '0',
};
// Creating zoom control
var zoom = L.control.zoom(zoomOptions);
Step 5 - Önceki adımda oluşturulan yakınlaştırma kontrol nesnesini, addTo() yöntem.
// Adding zoom control to the map
zoom.addTo(map);
Misal
Aşağıda, haritanıza varsayılan yerine kendi yakınlaştırma denetiminizi eklemek için kod verilmiştir. Burada, 1'e basıldığında harita yakınlaştırılır ve 0'a basıldığında harita uzaklaşır.
<!DOCTYPE html>
<html>
<head>
<title>Zoom 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,
zoomControl: false
}
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
// zoom control options
var zoomOptions = {
zoomInText: '1',
zoomOutText: '0',
};
var zoom = L.control.zoom(zoomOptions); // Creating zoom control
zoom.addTo(map); // Adding zoom control to the map
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -
İlişkilendirme
Leaflet JavaScript kitaplığını kullanarak haritaya kendinize ait bir atıf eklemek için, aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Katman nesnesini haritaya ekleyin. addLayer() yöntemi Map sınıf.
Step 4 - Oluştur attrOptions değişkeni seçin ve varsayılan değer yerine kendi önek değerinizi tanımlayın (broşür).
Ardından, atıf kontrolünü attrOptions değişken L.control.attribution() Aşağıda gösterildiği gibi.
// Attribution options
var attrOptions = {
prefix: 'attribution sample'
};
// Creating an attribution
var attr = L.control.attribution(attrOptions);
Step 5 - Ekle attribution control kullanılarak haritaya önceki adımda oluşturulan nesne addTo() yöntem.
// Adding attribution to the map
attr.addTo(map);
Misal
Aşağıdaki kod, haritanıza varsayılan yerine kendi atıf kontrolümüzü ekler. Burada, bunun yerine metin ilişkilendirme örneği görüntülenecektir.
<!DOCTYPE html>
<html>
<head>
<title>Attribution 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,
attributionControl: false
}
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
// Attribution options
var attrOptions = {
prefix: 'attribution sample'
};
// Creating an attribution
var attr = L.control.attribution(attrOptions);
attr.addTo(map); // Adding attribution to the map
</script>
</body>
</html>>
Aşağıdaki çıktıyı üretir -
Ölçek
Leaflet JavaScript kitaplığını kullanarak haritaya kendi ölçek kontrolünüzü eklemek için, aşağıda verilen adımları izleyin -
Step 1 - Bir Mapbir < div > öğesi (Dize veya nesne) ve harita seçenekleri (isteğe bağlı) ileterek nesne.
Step 2 - Bir Layer istenen döşemenin URL'sini ileterek nesne.
Step 3 - Ekle layer kullanarak haritaya nesne addLayer() yöntemi Map sınıf.
Step 4 - Kullanarak ölçek kontrolü oluşturun L.control.scale() Aşağıda gösterildiği gibi.
// Creating scale control
var scale = L.control.scale();
Step 5 - Ekle scale control kullanılarak haritaya önceki adımda oluşturulan nesne addTo() yöntemi aşağıda gösterildiği gibi.
// Adding scale control to the map
scale.addTo(map);
Misal
Aşağıdaki kod, haritanıza ölçek kontrolü ekler.
<!DOCTYPE html>
<html>
<head>
<title>Scale 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');
map.addLayer(layer); // Adding layer to the map
var scale = L.control.scale(); // Creating scale control
scale.addTo(map); // Adding scale control to the map
</script>
</body>
</html>
Aşağıdaki çıktıyı üretir -