WebGL - प्रसंग

WebGL एप्लिकेशन लिखने के लिए, WebGL रेंडरिंग ऑब्जेक्ट ऑब्जेक्ट को प्राप्त करने के लिए पहला कदम है। यह ऑब्जेक्ट WebGL ड्राइंग बफर के साथ इंटरैक्ट करता है और सभी WebGL तरीकों को कॉल कर सकता है। वेबलॉग संदर्भ प्राप्त करने के लिए निम्नलिखित ऑपरेशन किए जाते हैं -

  • HTML-5 कैनवास बनाएं
  • कैनवास आईडी प्राप्त करें
  • WebGL को प्राप्त करें

एचटीएमएल -5 कैनवस एलिमेंट बनाना

अध्याय 5 में, हमने HTML-5 कैनवास तत्व बनाने का तरीका बताया। HTML-5 दस्तावेज़ के मुख्य भाग के भीतर, एक कैनवास लिखें, इसे एक नाम दें, और इसे विशेषता आईडी के पैरामीटर के रूप में पास करें। आप चौड़ाई और ऊंचाई विशेषताओं (वैकल्पिक) का उपयोग करके कैनवास के आयामों को परिभाषित कर सकते हैं।

उदाहरण

निम्न उदाहरण से पता चलता है कि 500 ​​× 500 के आयामों के साथ एक कैनवास तत्व कैसे बनाया जाता है। हमने दृश्यता के लिए CSS का उपयोग करके कैनवास पर एक सीमा बनाई है। नाम के साथ फ़ाइल में निम्न कोड को कॉपी और पेस्ट करेंmy_canvas.html

<!DOCTYPE HTML>
<html>
   <head>
      <style>
         #mycanvas{border:1px solid blue;}
      </style>
   </head>
   <body>
      <canvas id = "mycanvas" width = "300" height = "300"></canvas>
   </body>
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

कैनवस आईडी प्राप्त करें

कैनवास बनाने के बाद, आपको वेबजीएल संदर्भ प्राप्त करना होगा। वेबजीएल ड्राइंग संदर्भ प्राप्त करने के लिए पहली चीज वर्तमान कैनवास तत्व की आईडी प्राप्त करना है।

कैनवस आईडी को DOM (डॉक्यूमेंट ऑब्जेक्ट मॉडल) विधि कहकर अधिग्रहित किया जाता है getElementById()। यह विधि पैरामीटर के रूप में एक स्ट्रिंग मान को स्वीकार करती है, इसलिए हम वर्तमान कैनवास का नाम इसे पास करते हैं।

उदाहरण के लिए, यदि कैनवास का नाम है my_canvas, तो कैनवास आईडी नीचे के रूप में दिखाया गया है

var canvas = document.getElementById('my_Canvas');

वेबलॉग ड्राइंग संदर्भ प्राप्त करें

WebGLRenderingContext ऑब्जेक्ट (या WebGL ड्राइंग संदर्भ ऑब्जेक्ट या बस WebGL संदर्भ) प्राप्त करने के लिए, कॉल करें getContext() वर्तमान की विधि HTMLCanvasElement। GetContext का सिंटैक्स इस प्रकार है -

canvas.getContext(contextType, contextAttributes);

स्ट्रिंग्स पास करें webgl या experimental-webgl के रूप में contentTypecontextAttributesपैरामीटर वैकल्पिक है। (इस चरण के साथ आगे बढ़ते समय, सुनिश्चित करें कि आपका ब्राउज़र WebGL संस्करण 1 (OpenGL ES 2.0) लागू करता है )।

निम्न कोड स्निपेट दिखाता है कि WebGL रेंडरिंग संदर्भ कैसे प्राप्त करें। यहाँgl प्राप्त संदर्भ वस्तु का संदर्भ चर है।

var canvas = document.getElementById('my_Canvas');
var gl = canvas.getContext('experimental-webgl');

WebGLContextAttributes

पैरामीटर WebGLContextAttributesअनिवार्य नहीं है। यह पैरामीटर विभिन्न विकल्प प्रदान करता है जो बूलियन मूल्यों को नीचे सूचीबद्ध के रूप में स्वीकार करते हैं -

अनु क्रमांक। विशेषताएँ और विवरण
1

Alpha

यदि इसका मान सही है, तो यह कैनवास को एक अल्फा बफर प्रदान करता है।

डिफ़ॉल्ट रूप से, इसका मान सत्य है।

2

depth

यदि इसका मान सत्य है, तो आपको एक ड्राइंग बफ़र मिलेगा जिसमें कम से कम 16 बिट्स की गहराई बफर होती है।

डिफ़ॉल्ट रूप से, इसका मान सत्य है।

3

stencil

यदि इसका मान सत्य है, तो आपको एक ड्राइंग बफर मिलेगा जिसमें कम से कम 8 बिट्स का स्टैंसिल बफर होगा।

डिफ़ॉल्ट रूप से, इसका मान गलत है।

4

antialias

यदि इसका मूल्य सही है, तो आपको एक ड्राइंग बफर मिलेगा जो एंटी-अलियासिंग करता है।

डिफ़ॉल्ट रूप से, इसका मान सत्य है।

5

premultipliedAlpha

यदि इसका मान सत्य है, तो आपको एक ड्राइंग बफर मिलेगा जिसमें पूर्व-गुणा वाले अल्फा वाले रंग शामिल हैं।

डिफ़ॉल्ट रूप से, इसका मान सत्य है।

6

preserveDrawingBuffer

यदि इसका मान सही है, तो बफ़र्स साफ़ नहीं किए जाएँगे और जब तक लेखक द्वारा साफ़ या अधिलेखित नहीं किया जाता है तब तक वे अपने मूल्यों को संरक्षित रखेंगे।

डिफ़ॉल्ट रूप से, इसका मान गलत है।

निम्न कोड स्निपेट दिखाता है कि स्टैंसिल बफर के साथ वेबजीएल संदर्भ कैसे बनाया जाए, जो प्रदर्शन नहीं करेगा anti-aliasing

var canvas = document.getElementById('canvas1');
var context = canvas.getContext('webgl', { antialias: false, stencil: true });

WebGLRenderingContext बनाने के समय, एक ड्राइंग बफर बनाया जाता है। प्रसंग ऑब्जेक्ट OpenGL राज्य का प्रबंधन करता है और ड्राइंग बफर में रेंडर करता है।

WebGLRenderingContext

यह WebGL में प्रमुख इंटरफ़ेस है। यह वेबजीएल ड्राइंग संदर्भ का प्रतिनिधित्व करता है। इस इंटरफ़ेस में ड्राइंग बफ़र पर विभिन्न कार्यों को करने के लिए उपयोग की जाने वाली सभी विधियाँ शामिल हैं। इस इंटरफ़ेस की विशेषताएं निम्नलिखित तालिका में दी गई हैं।

अनु क्रमांक। विशेषताएँ और विवरण
1

Canvas

यह कैनवास तत्व का एक संदर्भ है जिसने इस संदर्भ को बनाया है।

2

drawingBufferWidth

यह विशेषता ड्राइंग बफर की वास्तविक चौड़ाई का प्रतिनिधित्व करती है। यह HTMLCanvasElement की चौड़ाई विशेषता से भिन्न हो सकता है।

3

drawingBufferHeight

यह विशेषता ड्राइंग बफर की वास्तविक ऊंचाई का प्रतिनिधित्व करती है। यह HTMLCanvasElement की ऊंचाई विशेषता से भिन्न हो सकता है।