डी 3.जेएस - एक्सिस एपीआई

डी 3 कुल्हाड़ियों को खींचने के लिए कार्य प्रदान करता है। एक अक्ष रेखा, टिक्स और लेबल से बना होता है। एक अक्ष स्केल का उपयोग करता है, इसलिए प्रत्येक अक्ष को कार्य करने के लिए एक स्केल दिया जाना चाहिए।

एक्सिस एपीआई को कॉन्फ़िगर करना

आप निम्न स्क्रिप्ट का उपयोग करके एपीआई को कॉन्फ़िगर कर सकते हैं।

<script src = "https://d3js.org/d3-axis.v1.min.js"></script>
<script>

</script>

एक्सिस एपीआई तरीके

डी 3 कुल्हाड़ियों को खींचने के लिए निम्नलिखित महत्वपूर्ण कार्य प्रदान करता है। वे संक्षिप्त रूप में वर्णित हैं।

  • d3.axisTop() - इस पद्धति का उपयोग शीर्ष क्षैतिज अक्ष बनाने के लिए किया जाता है।

  • d3.axisRight() - इस पद्धति का उपयोग एक ऊर्ध्वाधर दाएं-उन्मुख धुरी बनाने के लिए किया जाता है।

  • d3.axisBottom() - इस पद्धति का उपयोग नीचे क्षैतिज अक्ष बनाने के लिए किया जाता है।

  • d3.axisLeft() - यह बाएं ऊर्ध्वाधर अक्ष बनाता है।

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

आइए जानें कि x और y- अक्ष को ग्राफ में कैसे जोड़ा जाए। ऐसा करने के लिए, हमें नीचे दिए गए चरणों का पालन करना होगा।

Step 1 - Define variables - एसवीजी और डेटा चर को नीचे दिए गए कोड का उपयोग करके परिभाषित करें।

var width = 400, height = 400;
var data = [100, 150, 200, 250, 280, 300];
var svg = d3.select("body")
   .append("svg")
   .attr("width", width)
   .attr("height", height);

Step 2 - Create a scale linear function - नीचे परिभाषित के रूप में x और y अक्ष दोनों के लिए एक स्केल रैखिक फ़ंक्शन बनाएं।

var xscale = d3.scaleLinear()
   .domain([0, d3.max(data)])
   .range([0, width - 100]);

var yscale = d3.scaleLinear()
   .domain([0, d3.max(data)])
   .range([height/2, 0]);

यहाँ, हमने एक रेखीय पैमाना बनाया है और डोमेन और रेंज को निर्दिष्ट किया है।

Step 3 - Add scales to x-axis - अब, हम निम्नलिखित कोड का उपयोग करके एक्स-एक्सिस में स्केल जोड़ सकते हैं।

var x_axis = d3.axisBottom()
   .scale(xscale);

यहां, हम अपने x- अक्ष बनाने और स्केल के साथ प्रदान करने के लिए d3.axisBottom का उपयोग करते हैं, जिसे पहले परिभाषित किया गया है।

Step 4 - Add scales to the y-axis - y- अक्ष में स्केल जोड़ने के लिए निम्न कोड का उपयोग करें।

var y_axis = d3.axisLeft()
   .scale(yscale);

यहां, हम अपने y- अक्ष बनाने के लिए d3.axisLeft का उपयोग करते हैं और इसे उस पैमाने के साथ प्रदान करते हैं जिसे हमने ऊपर परिभाषित किया है।

Step 5 - Apply transformation - आप एक समूह तत्व जोड़ सकते हैं और एक्स, वाई अक्ष डाल सकते हैं, जो नीचे परिभाषित किया गया है।

svg.append("g")
   .attr("transform", "translate(50, 10)")
   .call(y_axis);

Step 6 - Append group elements - निम्नलिखित कोड का उपयोग करके संक्रमण और समूह तत्वों को लागू करें।

var xAxisTranslate = height/2 + 10;
svg.append("g")
   .attr("transform", "translate(50, " + xAxisTranslate  +")")
   .call(x_axis)

Step 7 - Working Example- पूर्ण कोड लिस्टिंग निम्नलिखित कोड ब्लॉक में दी गई है। एक वेबपेज बनाएंaxes.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
      <style>
         svg text {
            fill: purple;
            font: 12px sans-serif;
            text-anchor: end;
         }
      </style>
   </head>

   <body>
      <script>
         var width = 400, height = 400;
         var data = [100, 120, 140, 160, 180, 200];
         var svg = d3.select("body")
            .append("svg")
            .attr("width", width)
            .attr("height", height);
         
         var xscale = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([0, width - 100]);
         
         var yscale = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([height/2, 0]);
    
         var x_axis = d3.axisBottom().scale(xscale);
         
         var y_axis = d3.axisLeft().scale(yscale);
         
         svg.append("g")
            .attr("transform", "translate(50, 10)")
            .call(y_axis);
         
         var xAxisTranslate = height/2 + 10;
         
         svg.append("g")
            .attr("transform", "translate(50, " + xAxisTranslate  +")")
            .call(x_axis)
      </script>
   </body>
</html>

अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित बदलाव देखेंगे।