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 के रूप में contentType। contextAttributesपैरामीटर वैकल्पिक है। (इस चरण के साथ आगे बढ़ते समय, सुनिश्चित करें कि आपका ब्राउज़र 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 की ऊंचाई विशेषता से भिन्न हो सकता है। |