CATJS - मार्कर
मानचित्र पर किसी एक स्थान को चिह्नित करने के लिए, पत्रक पत्रक मार्कर प्रदान करता है। ये मार्कर एक मानक प्रतीक का उपयोग करते हैं और इन प्रतीकों को अनुकूलित किया जा सकता है। इस अध्याय में, हम देखेंगे कि मार्करों को कैसे जोड़ा जाए और उन्हें कैसे कस्टमाइज़ किया जाए, उन्हें कैसे हटाया जाए।
एक साधारण मार्कर जोड़ना
USC JavaScript लाइब्रेरी का उपयोग करके मानचित्र में मार्कर जोड़ने के लिए, नीचे दिए गए चरणों का पालन करें -
Step 1 - एक बनाएँ Map< div > तत्व (स्ट्रिंग या ऑब्जेक्ट) और मानचित्र विकल्प (वैकल्पिक) पास करके ऑब्जेक्ट।
Step 2 - एक बनाएँ Layer इच्छित टाइल के URL को पास करके वस्तु।
Step 3 - लेयर ऑब्जेक्ट को मैप का उपयोग करके जोड़ें addLayer() की विधि Map कक्षा।
Step 4 - तुरंत Marker पास करके कक्षा latlng चिह्नित किए जाने की स्थिति का प्रतिनिधित्व करने वाली वस्तु, जैसा कि नीचे दिखाया गया है।
// Creating a marker
var marker = new L.Marker([17.385044, 78.486671]);
Step 5 - पिछले चरणों में बनाए गए मार्कर ऑब्जेक्ट को मैप का उपयोग करके जोड़ें addTo() की विधि Marker कक्षा।
// Adding marker to the map
marker.addTo(map);
उदाहरण
निम्नलिखित कोड हैदराबाद (भारत) नामक शहर पर मार्कर सेट करता है।
<!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>
यह निम्नलिखित उत्पादन उत्पन्न करता है -
मार्कर को बाइंडिंग पॉप-अप
किसी मार्कर को संदेश प्रदर्शित करने वाले साधारण पॉपअप को बांधने के लिए, नीचे दिए गए चरणों का पालन करें -
Step 1 - एक बनाएँ Map< div > तत्व (स्ट्रिंग या ऑब्जेक्ट) और मानचित्र विकल्प (वैकल्पिक) पास करके ऑब्जेक्ट।
Step 2 - एक बनाएँ Layer इच्छित टाइल के URL को पास करके वस्तु।
Step 3 - लेयर ऑब्जेक्ट को मैप का उपयोग करके जोड़ें addLayer() की विधि Map कक्षा।
Step 4 - तुरंत Marker पास करके कक्षा latlng चिह्नित किए जाने वाले स्थान का प्रतिनिधित्व करने वाली वस्तु।
Step 5 - मार्कर का उपयोग करके पॉपअप संलग्न करें bindPopup() जैसा की नीचे दिखाया गया।
// Adding pop-up to the marker
marker.bindPopup('Hi Welcome to Tutorialspoint').openPopup();
Step 6 - अंत में, जोड़ें Marker का उपयोग कर नक्शे के लिए पिछले चरणों में बनाई गई वस्तु addTo() की विधि Marker कक्षा।
उदाहरण
निम्नलिखित कोड शहर हैदराबाद (भारत) पर मार्कर सेट करता है और इसमें एक पॉप-अप जोड़ता है।
<!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>
यह निम्न आउटपुट उत्पन्न करता है
मार्कर विकल्प
मार्कर बनाते समय, आप एक पास भी कर सकते हैं marker optionsलतांग वस्तु के अतिरिक्त चर। इस वैरिएबल का उपयोग करके, आप मार्कर के विभिन्न विकल्पों जैसे कि आइकॉन, ड्रैगबल, कीबोर्ड, टाइटल, ऑल्ट, zInsexOffset, ओपेसिटी, उदयऑनओवर, उदयऑफसेट, पेन, ड्रैगेबल, आदि के लिए मान सेट कर सकते हैं।
मानचित्र विकल्पों का उपयोग करके एक मानचित्र बनाने के लिए, आपको नीचे दिए गए चरणों का पालन करना होगा -
Step 1 - एक बनाएँ Map< div > तत्व (स्ट्रिंग या ऑब्जेक्ट) और मानचित्र विकल्प (वैकल्पिक) पास करके ऑब्जेक्ट।
Step 2 - एक बनाएँ Layer इच्छित टाइल के URL को पास करके वस्तु।
Step 3 - लेयर ऑब्जेक्ट को मैप का उपयोग करके जोड़ें addLayer() की विधि Map कक्षा।
Step 4 - मार्कर के लिए एक चर बनाएं और आवश्यक विकल्पों के लिए मान निर्दिष्ट करें।
बनाओ markerOptions ऑब्जेक्ट (यह एक शाब्दिक की तरह बनाया गया है) और विकल्पों के लिए मान सेट करें iconUrl तथा iconSize।
// Options for the marker
var markerOptions = {
title: "MyLocation",
clickable: true,
draggable: true
}
Step 5 - तुरंत Marker पास करके कक्षा latlng चिह्नित किए जाने वाले स्थान और विकल्प ऑब्जेक्ट का प्रतिनिधित्व करने वाली वस्तु, पिछले चरण में बनाई गई।
// Creating a marker
var marker = L.marker([17.385044, 78.486671], markerOptions);
Step 6 - अंत में, जोड़ें Marker का उपयोग कर नक्शे के लिए पिछले चरणों में बनाई गई वस्तु addTo() की विधि Marker कक्षा।
उदाहरण
निम्नलिखित कोड शहर हैदराबाद (भारत) पर मार्कर सेट करता है। यह मार्कर क्लिक करने योग्य है, शीर्षक के साथ खींचने योग्य है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>
यह निम्न आउटपुट उत्पन्न करता है
मार्कर कस्टम प्रतीक
USC लाइब्रेरी द्वारा प्रदान किए गए डिफ़ॉल्ट आइकन के बजाय, आप अपना खुद का आइकन भी जोड़ सकते हैं। आप डिफ़ॉल्ट एक के बजाय नक्शे में एक कस्टम आइकन जोड़ने के लिए निम्न चरणों का उपयोग कर सकते हैं।
Step 1 - एक बनाएँ Map< div > तत्व (स्ट्रिंग या ऑब्जेक्ट) और मानचित्र विकल्प (वैकल्पिक) पास करके ऑब्जेक्ट।
Step 2 - एक बनाएँ Layer इच्छित टाइल के URL को पास करके वस्तु।
Step 3 - लेयर ऑब्जेक्ट को मैप का उपयोग करके जोड़ें addLayer() की विधि Map कक्षा।
Step 4 - के लिए एक वैरिएबल बनाएं markerOptions और आवश्यक विकल्पों के लिए मान निर्दिष्ट करें -
iconUrl - इस विकल्प के मूल्य के रूप में, आपको पास होने की आवश्यकता है String छवि का पथ निर्दिष्ट करना जिसे आप एक आइकन के रूप में उपयोग करना चाहते हैं।
iconSize - इस विकल्प का उपयोग करके, आप आइकन का आकार निर्दिष्ट कर सकते हैं।
Note - इन के अलावा, आप अन्य विकल्पों जैसे iconSize, shadowSize, iconAnchor, shadowAnchor, और popupAnchor पर भी मान सेट कर सकते हैं।
एक कस्टम आइकन का उपयोग कर बनाएँ L.icon() ऊपर दिए गए विकल्प चर को नीचे बताए अनुसार पास करके।
// Icon options
var iconOptions = {
iconUrl: 'logo.png',
iconSize: [50, 50]
}
// Creating a custom icon
var customIcon = L.icon(iconOptions);
Step 5- मार्कर के लिए एक चर बनाएं और आवश्यक विकल्पों के लिए मान निर्दिष्ट करें। इन के अलावा, मूल्य के रूप में पिछले चरण में बनाए गए आइकन चर को पास करके आइकन निर्दिष्ट करें।
// Options for the marker
var markerOptions = {
title: "MyLocation",
clickable: true,
draggable: true,
icon: customIcon
}
Step 6 - तुरंत Marker पास करके कक्षा latlng चिह्नित किए जाने वाले स्थान और पिछले चरण में बनाए गए विकल्प ऑब्जेक्ट का प्रतिनिधित्व करने वाली वस्तु।
// Creating a marker
var marker = L.marker([17.438139, 78.395830], markerOptions);
Step 7 - अंत में, जोड़ें Marker का उपयोग कर नक्शे के लिए पिछले चरणों में बनाई गई वस्तु addTo() की विधि Marker कक्षा।
उदाहरण
निम्न कोड मार्कर को Tutorialspoint के स्थान पर सेट करता है। यहां हम डिफॉल्ट मार्कर के बजाय ट्यूटोरियलस्पॉट के लोगो का उपयोग कर रहे हैं।
<!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>
यह निम्न आउटपुट उत्पन्न करता है