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>

यह निम्न आउटपुट उत्पन्न करता है