डी 3.जेएस - भौगोलिक

भू-स्थानिक निर्देशांक अक्सर मौसम या जनसंख्या डेटा के लिए उपयोग किए जाते हैं। D3.js हमें भौगोलिक डेटा के लिए तीन उपकरण देता है -

  • Paths - वे अंतिम पिक्सल का उत्पादन करते हैं।

  • Projections - वे कार्टेशियन निर्देशांक और क्षेत्र में निर्देशांक बारी

  • Streams - वे चीजों को गति देते हैं।

D3.js में भूगोल क्या हैं, यह जानने से पहले हमें निम्नलिखित दो शब्दों को समझना चाहिए -

  • डी 3 जियो पथ और
  • Projections

आइए इन दो शब्दों पर विस्तार से चर्चा करें।

डी 3 जियो पथ

यह एक भौगोलिक पथ जनरेटर है। GeoJSON SVG पथ डेटा स्ट्रिंग उत्पन्न करता है या एक कैनवास को पथ प्रदान करता है। प्रदर्शन को बेहतर बनाने के लिए गतिशील या इंटरैक्टिव अनुमानों के लिए एक कैनवस की सिफारिश की जाती है। डी 3 जियो पाथ डेटा जेनरेटर जेनरेट करने के लिए, आप निम्न फ़ंक्शन को कॉल कर सकते हैं।

d3.geo.path()

यहां ही d3.geo.path() पथ जनरेटर फ़ंक्शन हमें यह चुनने की अनुमति देता है कि हम कौन से मैप प्रोजेक्शन का उपयोग जियो निर्देशांक से कार्टेशियन निर्देशांक में अनुवाद के लिए करना चाहते हैं।

उदाहरण के लिए, यदि हम भारत का नक्शा विवरण दिखाना चाहते हैं, तो हम नीचे दिखाए गए मार्ग को परिभाषित कर सकते हैं।

var path = d3.geo.path()
svg.append("path")
   .attr("d", path(states))

अनुमानों

अनुमान गोलाकार बहुभुज ज्यामिति को प्लानेर बहुभुज ज्यामिति में बदल देते हैं। डी 3 निम्नलिखित प्रक्षेपण कार्यान्वयन प्रदान करता है।

  • Azimuthal - अजीमुथल के अनुमानों का सीधा क्षेत्र हवाई जहाज पर है।

  • Composite - समग्र में कई अनुमान शामिल होते हैं जो एकल प्रदर्शन में शामिल होते हैं।

  • Conic - एक शंकु पर गोले को प्रोजेक्ट करता है और फिर विमान पर शंकु को अनियंत्रित करता है।

  • Cylindrical - बेलनाकार प्रोजेक्शन एक युक्त सिलेंडर पर क्षेत्र को प्रोजेक्ट करते हैं, और फिर विमान पर सिलेंडर को अनियंत्रित करते हैं।

एक नया प्रक्षेपण बनाने के लिए, आप निम्न फ़ंक्शन का उपयोग कर सकते हैं।

d3.geoProjection(project)

यह निर्दिष्ट कच्चे प्रक्षेपण परियोजना से एक नए प्रक्षेपण का निर्माण करता है। प्रोजेक्ट फ़ंक्शन रेडियंस में दिए गए बिंदु के देशांतर और अक्षांश को लेता है। आप अपने कोड में निम्नलिखित प्रक्षेपण लागू कर सकते हैं।

var width = 400
var height = 400
var projection = d3.geo.orthographic() 
var projections = d3.geo.equirectangular()
var project = d3.geo.gnomonic()
var p = d3.geo.mercator()
var pro = d3.geo.transverseMercator()
   .scale(100)
   .rotate([100,0,0])
   .translate([width/2, height/2])
   .clipAngle(45);

यहां, हम उपरोक्त किसी भी अनुमान को लागू कर सकते हैं। आइए हम इनमें से प्रत्येक अनुमान पर संक्षिप्त चर्चा करें।

  • d3.geo.orthographic()- ऑर्थोग्राफिक प्रक्षेपण एक एकल गोलार्ध को प्रदर्शित करने के लिए उपयुक्त एक अज़ीमुथल प्रक्षेपण है; दृष्टिकोण की बात अनंत पर है।

  • d3.geo.gnomonic() - ग्नोमोनिक प्रक्षेपण एक अज़ीमुथल प्रक्षेपण है जो बड़ी रेखाओं को सीधी रेखाओं के रूप में प्रोजेक्ट करता है।

  • d3.geo.equirectangular()- समभुज सबसे सरल भौगोलिक प्रक्षेपण है। पहचान समारोह। यह न तो समान-क्षेत्र है और न ही अनुरूप है, लेकिन कभी-कभी रेखापुंज डेटा के लिए उपयोग किया जाता है।

  • d3.geo.mercator() - गोलाकार मर्केटर प्रक्षेपण का उपयोग आमतौर पर टाइलों की मैपिंग लाइब्रेरी द्वारा किया जाता है।

  • d3.geo.transverseMercator() - अनुप्रस्थ मर्केटर प्रक्षेपण।

काम करने का उदाहरण

इस उदाहरण में भारत का नक्शा बनाते हैं। ऐसा करने के लिए, हमें निम्नलिखित चरणों का पालन करना चाहिए।

Step 1 - Apply styles - नीचे दिए गए कोड का उपयोग करके हम मैप में शैलियों को जोड़ते हैं।

<style>
   path {
      stroke: white;
      stroke-width: 0.5px;
      fill: grey;
   }
   
   .stateTN { fill: red; }
   .stateAP { fill: blue; }
   .stateMP{ fill: green; }
</style>

यहां, हमने राज्य TN, AP और MP के लिए विशेष रंग लागू किए हैं।

Step 2 - Include topojson script - TopoJSON, GeoJSON का एक विस्तार है जो टोपोलॉजी को एन्कोड करता है, जो नीचे परिभाषित किया गया है।

<script src = "http://d3js.org/topojson.v0.min.js"></script>

हम इस स्क्रिप्ट को अपनी कोडिंग में शामिल कर सकते हैं।

Step 3 - Define variables - नीचे दिए गए कोड का उपयोग करके अपनी स्क्रिप्ट में चर जोड़ें।

var width = 600;
var height = 400;
var projection = d3.geo.mercator()
   .center([78, 22])
   .scale(680)
   .translate([width / 2, height / 2]);

यहां, एसवीजी की चौड़ाई 600 है और ऊंचाई 400 है। स्क्रीन एक दो आयामी स्थान है और हम तीन आयामी वस्तु पेश करने की कोशिश कर रहे हैं। इसलिए, हम भूमि के आकार / आकार का उपयोग करके शिकायत को विकृत कर सकते हैंd3.geo.mercator() समारोह।

केंद्र निर्दिष्ट किया गया है [78 center, २२], यह प्रक्षेपण के केंद्र को निर्दिष्ट स्थान के दो तत्व सरणी देशांतर और अक्षांश में डिग्री के रूप में निर्धारित करता है और प्रक्षेपण लौटाता है।

यहां, नक्शा 78 डिग्री पश्चिम और 22 डिग्री उत्तर पर केंद्रित किया गया है।

स्केल को 680 के रूप में निर्दिष्ट किया गया है, यह प्रक्षेपण के पैमाने कारक को निर्दिष्ट मूल्य पर सेट करता है। यदि स्केल निर्दिष्ट नहीं है, तो यह वर्तमान स्केल फैक्टर को लौटाता है, जो 150 में चूकता है। यह ध्यान रखना महत्वपूर्ण है कि स्केल फैक्टर अनुमानों के अनुरूप नहीं हैं।

Step 4 - Append SVG - अब, SVG विशेषताएँ जोड़ें।

var svg = d3.select("body").append("svg")
   .attr("width", width)
   .attr("height", height);

Step 5 - Create path - कोड का निम्नलिखित भाग एक नया भौगोलिक पथ जनरेटर बनाता है।

var path = d3.geo.path()
   .projection(projection);

यहां, पथ जनरेटर (d3.geo.path ()) का उपयोग एक प्रक्षेपण प्रकार (.projection) को निर्दिष्ट करने के लिए किया जाता है, जिसे पहले चर प्रक्षेपण का उपयोग करके एक व्यापारी के रूप में परिभाषित किया गया था।

Step 6 - Generate data - indiatopo.json - इस फ़ाइल में बहुत सारे रिकॉर्ड हैं, जिन्हें हम निम्नलिखित अनुलग्नक से आसानी से डाउनलोड कर सकते हैं।

डाउनलोड indiatopo.json file

फ़ाइल डाउनलोड होने के बाद, हम इसे अपने डी 3 स्थान में जोड़ सकते हैं। नमूना प्रारूप नीचे दिखाया गया है।

{"type":"Topology","transform":{"scale":[0.002923182318231823,0.0027427542754275428],
"translate":[68.1862,8.0765]},"objects":
{"states":{"type":"GeometryCollection",
"geometries":[{"type":"MultiPolygon","id":"AP","arcs":
[[[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,
25,26,27,28,29,30,31,32,33,34]],[[35,36,37,38,39,40,41]],[[42]],
[[43,44,45]],[[46]],[[47]],[[48]],[[49]],[[50]],[[51]],[[52,53]],
[[54]],[[55]],[[56]],[[57,58]],[[59]],[[60]],[[61,62,63]],[[64]],
[[65]],[[66]],[[67]],[[68]],[[69]],[[-41,70]],
[[71]],[[72]],[[73]],[[74]],[[75]]],
"properties":{"name":"Andhra Pradesh"}},{"type":"MultiPolygon",
"id":"AR","arcs":[[[76,77,78,79,80,81,82]]],
"properties":{"name":"Arunachal Pradesh"}},{"type":"MultiPolygon",
"id":"AS","arcs":[[[83,84,85,86,87,88,89,90,
91,92,93,94,95,96,97,98,99,100,101,102,103]],
[[104,105,106,107]],[[108,109]]], ......

........................................

Step 7 - Draw map - अब, से डेटा पढ़ें indiatopo.json फ़ाइल और नक्शा खींचें।

d3.json("indiatopo.json", function(error, topology) {
   g.selectAll("path")
   .data(topojson.object(topology, topology.objects.states)
   .geometries)
   .enter()
   .append("path")
   .attr("class", function(d) { return "state" + d.id; })
   .attr("d", path)
});

यहां, हम TopoJSON फ़ाइल को भारत के नक्शे (indiatopo.json) के निर्देशांक के साथ लोड करेंगे। फिर हम घोषणा करते हैं कि हम ग्राफिक में सभी पथ तत्वों पर कार्य करने जा रहे हैं। इसे g.selectAll ("path") के रूप में परिभाषित किया गया है। हम तब TopoJSON फ़ाइल से देशों को परिभाषित करने वाले डेटा को खींच लेंगे।

.data(topojson.object(topology, topology.objects.states)
   .geometries)

अंत में, हम इसे उस डेटा में जोड़ देंगे जिसका उपयोग हम प्रदर्शित करने जा रहे हैं .enter() विधि और फिर हम उस डेटा को पथ तत्वों के रूप में उपयोग करते हैं .append(“path”) तरीका।