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

रंगों को RED, GREEN और BLUE के संयोजन से प्रदर्शित किया जाता है। रंगों को निम्नलिखित विभिन्न तरीकों से निर्दिष्ट किया जा सकता है -

  • रंग नामों से
  • RGB मूल्यों के रूप में
  • हेक्साडेसिमल मानों के रूप में
  • एचएसएल मूल्यों के रूप में
  • HWB मानों के रूप में

डी 3-रंग एपीआई विभिन्न रंगों के लिए प्रतिनिधित्व प्रदान करता है। आप एपीआई में रूपांतरण और हेरफेर संचालन कर सकते हैं। आइए इन ऑपरेशनों को विस्तार से समझते हैं।

API को कॉन्फ़िगर करना

आप निम्न स्क्रिप्ट का उपयोग करके सीधे API लोड कर सकते हैं।

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

</script>

मूलभूत क्रियाएं

डी 3 में मूल रंग संचालन के माध्यम से चलते हैं।

Convert color value to HSL - रंग मूल्य को एचएसएल में परिवर्तित करने के लिए, निम्नलिखित का उपयोग करें Example -

var convert = d3.hsl("green");

आप नीचे दिखाए अनुसार hue को 45 ° से घुमा सकते हैं।

convert.h + =  45;

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

convert.opacity = 0.5;

रंग एपीआई तरीके

निम्नलिखित कुछ सबसे महत्वपूर्ण कलर एपीआई तरीके हैं।

  • d3.color(specifier)
  • color.opacity
  • color.rgb()
  • color.toString()
  • color.displayable()
  • d3.rgb(color)
  • d3.hsl(color)
  • d3.lab(color)
  • d3.hcl(color)
  • d3.cubehelix(color)

आइए हम इन कलर एपीआई तरीकों में से प्रत्येक को विस्तार से समझते हैं।

d3.color (विनिर्देशक)

इसका उपयोग निर्दिष्ट सीएसएस रंग को पार्स करने और आरजीबी या एचएसएल रंग को वापस करने के लिए किया जाता है। यदि निर्दिष्ट नहीं दिया जाता है, तो नल वापस कर दिया जाता है।

Example - आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var color = d3.color("green");  // asign color name directly
   console.log(color);
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे -

{r: 0, g: 128, b: 0, opacity: 1}

color.opacity

यदि हम रंग को फीका करना चाहते हैं, तो हम अस्पष्टता मान को बदल सकते हैं। यह [0, 1] की सीमा में है।

Example - आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var color = d3.color("green");
   console.log(color.opacity);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे -

1

color.rgb ()

यह रंग के लिए RGB मान लौटाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var color = d3.color("green");
   console.log(color.rgb());
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे।

{r: 0, g: 128, b: 0, opacity: 1}

color.toString ()

यह सीएसएस ऑब्जेक्ट मॉडल विनिर्देश के अनुसार रंग का प्रतिनिधित्व करने वाला एक स्ट्रिंग देता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var color = d3.color("green");
   console.log(color.toString());
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे।

rgb(0, 128, 0)

color.displayable ()

सही है, अगर रंग प्रदर्शन योग्य है। गलत रिटर्न देता है, यदि RGB रंग मान 0 से कम या 255 से अधिक है, या यदि अपारदर्शिता रेंज [0, 1] में नहीं है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var color = d3.color("green");
   console.log(color.displayable());
</script>

हम अपनी स्क्रीन पर निम्न प्रतिक्रिया देखेंगे।

true

d3.rgb (रंग)

इस विधि का उपयोग एक नया RGB रंग बनाने के लिए किया जाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   console.log(d3.rgb("yellow"));
   console.log(d3.rgb(200,100,0));
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

{r: 255, g: 255, b: 0, opacity: 1}
{r: 200, g: 100, b: 0, opacity: 1}

d3.hsl (रंग)

इसका उपयोग एक नए एचएसएल रंग के निर्माण के लिए किया जाता है। मानों को वापस दिए गए उदाहरण पर h, s और l गुणों के रूप में उजागर किया जाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var hsl = d3.hsl("blue");
   console.log(hsl.h + =  90);
   console.log(hsl.opacity = 0.5);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

330
0.5

d3.lab (रंग)

यह एक नए लैब रंग का निर्माण करता है। चैनल मान लौटाए गए उदाहरण पर 'l', 'a' और 'b' गुणों के रूप में सामने आते हैं।

<script>
   var lab = d3.lab("blue");
   console.log(lab);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

{l: 32.29701093285073, a: 79.18751984512221, b: -107.8601617541481, opacity: 1}

d3.hcl (रंग)

एक नया एचसीएल रंग का निर्माण करता है। चैनल मान लौटाए गए उदाहरण पर h, c और l गुणों के रूप में सामने आते हैं। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var hcl = d3.hcl("blue");
   console.log(hcl);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे।

{h: 306.2849380699878, c: 133.80761485376166, l: 32.29701093285073, opacity: 1}

d3.cubehelix (रंग)

एक नया क्यूबेलिक्स रंग बनाता है। मानों को वापस दिए गए उदाहरण पर h, s और l गुणों के रूप में उजागर किया जाता है। आइए हम निम्नलिखित उदाहरण पर विचार करें।

<script>
   var hcl = d3.hcl("blue");
   console.log(hcl);
</script>

हम स्क्रीन पर निम्नलिखित प्रतिक्रिया देखेंगे,

{h: 236.94217167732103, s: 4.614386868039719, l: 0.10999954957200976, opacity: 1}

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

आइए हम एक नया वेबपेज बनाएं - color.htmlसभी रंग एपीआई तरीकों का प्रदर्शन करने के लिए। पूर्ण कोड सूची नीचे परिभाषित की गई है।

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 colors API</h3>
      <script>
         var color = d3.color("green");
         console.log(color);
         console.log(color.opacity);
         console.log(color.rgb());
         console.log(color.toString());
         console.log(color.displayable());
         console.log(d3.rgb("yellow"));
         console.log(d3.rgb(200,100,0));
         var hsl = d3.hsl("blue");
         console.log(hsl.h + =  90);
         console.log(hsl.opacity = 0.5);
         var lab = d3.lab("blue");
         console.log(lab);
         var hcl = d3.hcl("blue");
         console.log(hcl);
         var cube = d3.cubehelix("blue");
         console.log(cube);
      </script>
   </body>
</html>

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