डी 3.जेएस - स्केल एपीआई
D3.js डेटा ट्रांसफ़ॉर्मेशन करने के लिए स्केल फ़ंक्शंस प्रदान करता है। ये फ़ंक्शन इनपुट डोमेन को आउटपुट रेंज में मैप करते हैं।
API को कॉन्फ़िगर करना
हम निम्नलिखित स्क्रिप्ट का उपयोग करके सीधे एपीआई को कॉन्फ़िगर कर सकते हैं।
<script src = "https://d3js.org/d3-array.v1.min.js"></script>
<script src = "https://d3js.org/d3-collection.v1.min.js"></script>
<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-format.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-time.v1.min.js"></script>
<script src = "https://d3js.org/d3-time-format.v2.min.js"></script>
<script src = "https://d3js.org/d3-scale.v1.min.js"></script>
<script>
</script>
तराजू एपीआई तरीके
डी 3 विभिन्न प्रकार के चार्ट के लिए निम्न महत्वपूर्ण स्केलिंग विधियाँ प्रदान करता है। आइए फिर विस्तार से समझते हैं।
d3.scaleLinear() - एक सतत रेखीय पैमाने का निर्माण करता है जहां हम निर्दिष्ट आउटपुट रेंज में डेटा (डोमेन) मैप्स इनपुट कर सकते हैं।
d3.scaleIdentity() - एक रैखिक पैमाने का निर्माण करें जहां इनपुट डेटा आउटपुट के समान है।
d3.scaleTime() - एक रेखीय पैमाने का निर्माण करें जहां इनपुट डेटा दिनांक और आउटपुट संख्याओं में है।
d3.scaleLog() - एक लघुगणकीय पैमाने का निर्माण।
d3.scaleSqrt() - एक वर्गमूल पैमाने का निर्माण।
d3.scalePow() - एक घातीय पैमाने का निर्माण।
d3.scaleSequential() - एक अनुक्रमिक पैमाने का निर्माण करें जहां आउटपुट रेंज इंटरपोलर फ़ंक्शन द्वारा तय की गई है।
d3.scaleQuantize() - असतत उत्पादन सीमा के साथ एक मात्रा पैमाने का निर्माण।
d3.scaleQuantile() - जहां इनपुट नमूना डेटा नक्शे असतत उत्पादन सीमा के लिए एक मात्रात्मक पैमाने का निर्माण।
d3.scaleThreshold() - एक पैमाने का निर्माण करें जहां असतत आउटपुट रेंज के लिए मनमाना इनपुट डेटा मैप करता है।
d3.scaleBand() - बैंड स्केल ऑर्डिनल स्केल की तरह होते हैं सिवाय आउटपुट रेंज के निरंतर और न्यूमेरिक।
d3.scalePoint() - एक बिंदु पैमाने का निर्माण।
d3.scaleOrdinal() - एक क्रमिक पैमाने का निर्माण करें जहां इनपुट डेटा में अक्षर शामिल हैं और असतत संख्यात्मक आउटपुट रेंज में मैप किए जाते हैं।
कार्य का उदाहरण देने से पहले, आइए पहले निम्नलिखित दो शब्दों को समझें -
Domain - डोमेन आपके इनपुट डेटा के न्यूनतम और अधिकतम मूल्यों को दर्शाता है।
Range - रेंज आउटपुट रेंज है, जिसे हम मैप करने के लिए इनपुट मानों की तरह चाहेंगे ...
काम करने का उदाहरण
इस उदाहरण में d3.scaleLinear फ़ंक्शन करते हैं। ऐसा करने के लिए, आपको निम्नलिखित चरणों का पालन करना होगा -
Step 1 - Define variables - एसवीजी चर और डेटा को परिभाषित करें नीचे दिए गए कोडिंग का उपयोग करें।
var data = [100, 200, 300, 400, 800, 0]
var width = 500,
barHeight = 20,
margin = 1;
Step 2 - Create linear scale - लीनियर स्केल बनाने के लिए निम्न कोड का उपयोग करें।
var scale = d3.scaleLinear()
.domain([d3.min(data), d3.max(data)])
.range([100, 400]);
यहां, हमारे डोमेन के लिए न्यूनतम और अधिकतम मूल्य के लिए मैन्युअल रूप से, हम बिल्ट-इन का उपयोग कर सकते हैं d3.min() तथा d3.max() फ़ंक्शंस, जो हमारे डेटा ऐरे से क्रमशः न्यूनतम और अधिकतम मान लौटाएंगे।
Step 3 - Append SVG attributes - नीचे दिए गए कोड का उपयोग करके एसवीजी तत्वों को जोड़ें।
var svg = d3.select("body")
.append("svg")
.attr("width", width)
.attr("height", barHeight * data.length);
Step 4 - Apply transformation - नीचे दिए गए कोड का उपयोग करके परिवर्तन लागू करें।
var g = svg.selectAll("g")
.data(data).enter().append("g")
.attr("transform", function (d, i) {
return "translate(0," + i * barHeight + ")";
});
Step 5 - Append rect elements - नीचे दिखाए गए अनुसार स्केलिंग के लिए मूल तत्वों को जोड़ें।
g.append("rect")
.attr("width", function (d) {
return scale(d);
})
.attr("height", barHeight - margin)
Step 6 - Display data - अब नीचे दिए गए कोडिंग का उपयोग करके डेटा प्रदर्शित करें।
g.append("text")
.attr("x", function (d) { return (scale(d)); })
.attr("y", barHeight / 2)
.attr("dy", ".35em")
.text(function (d) { return d; });
Step 7 - Working Example - अब, d3.scaleLinear () फ़ंक्शन का उपयोग करके एक बार चार्ट बनाते हैं।
एक वेबपेज "scales.html" बनाएं और उसमें निम्नलिखित परिवर्तन जोड़ें।
<!DOCTYPE html>
<html>
<head>
<script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
</head>
<body>
<script>
var data = [100, 200, 300, 350, 400, 250]
var width = 500, barHeight = 20, margin = 1;
var scale = d3.scaleLinear()
.domain([d3.min(data), d3.max(data)])
.range([100, 400]);
var svg = d3.select("body")
.append("svg")
.attr("width", width)
.attr("height", barHeight * data.length);
var g = svg.selectAll("g")
.data(data)
.enter()
.append("g")
.attr("transform", function (d, i) {
return "translate(0," + i * barHeight + ")";
});
g.append("rect")
.attr("width", function (d) {
return scale(d);
})
.attr("height", barHeight - margin)
g.append("text")
.attr("x", function (d) { return (scale(d)); })
.attr("y", barHeight / 2).attr("dy", ".35em")
.text(function (d) { return d; });
</script>
</body>
</html>
उपरोक्त कोड ब्राउज़र में निम्नलिखित परिणाम प्रदर्शित करेगा।