WebGL - त्वरित गाइड
कुछ साल पहले, जावा एप्लिकेशन - एप्लेट्स और जेओजीएल के संयोजन के रूप में - जीपीयू (ग्राफिकल प्रोसेसिंग यूनिट) को संबोधित करके वेब पर 3 डी ग्राफिक्स को संसाधित करने के लिए उपयोग किया गया था। चूंकि एप्लेट्स को चलाने के लिए जेवीएम की आवश्यकता होती है, इसलिए जावा एप्लेट्स पर भरोसा करना मुश्किल हो गया। कुछ साल बाद, लोगों ने जावा एप्लेट का उपयोग करना बंद कर दिया।
Adobe (Flash, AIR) द्वारा प्रदान की जाने वाली स्टेज 3 डी एपीआई ने GPU हार्डवेयर त्वरित वास्तुकला की पेशकश की। इन तकनीकों का उपयोग करके, प्रोग्रामर वेब ब्राउज़र के साथ-साथ IOS और Android प्लेटफॉर्म पर 2D और 3D क्षमताओं के साथ एप्लिकेशन विकसित कर सकते हैं। चूंकि फ्लैश एक मालिकाना सॉफ्टवेयर था, इसलिए इसे वेब मानक के रूप में उपयोग नहीं किया गया था।
मार्च 2011 में, वेबजीएल जारी किया गया था। यह एक ओपनवेयर है जो बिना JVM के चल सकता है। यह पूरी तरह से वेब ब्राउज़र द्वारा नियंत्रित किया जाता है।
HTML 5 की नई रिलीज़ में 3D ग्राफिक्स जैसे 2D Canvas, WebGL, SVG, 3D CSS ट्रांसफ़ॉर्म और SMIL को सपोर्ट करने के लिए कई फीचर्स हैं। इस ट्यूटोरियल में, हम WebGL की मूल बातें कवर करेंगे।
OpenGL क्या है?
ओपनजीएल (ओपन ग्राफिक्स लाइब्रेरी) 2 डी और 3 डी ग्राफिक्स के लिए एक क्रॉस-भाषा, क्रॉस-प्लेटफॉर्म एपीआई है। यह आज्ञाओं का संग्रह है। OpenGL4.5 OpenGL का नवीनतम संस्करण है। निम्न तालिका OpenGL से संबंधित प्रौद्योगिकियों के एक सेट को सूचीबद्ध करती है।
एपीआई | प्रौद्योगिकी का इस्तेमाल किया |
---|---|
OpenGL ES | यह एम्बेडेड सिस्टम पर 2 डी और 3 डी ग्राफिक्स के लिए पुस्तकालय है - जिसमें कंसोल, फोन, उपकरण और वाहन शामिल हैं। OpenGL ES 3.1 इसका नवीनतम संस्करण है। इसका रखरखाव ख्रोनोस ग्रुप www.khronos.org द्वारा किया जाता है |
JOGL | यह ओपनजीएल के लिए जावा बाइंडिंग है। JOGL 4.5 इसका नवीनतम संस्करण है और इसे jogamp.org द्वारा बनाए रखा गया है । |
WebGL | यह OpenGL के लिए जावास्क्रिप्ट बाइंडिंग है। WebGL 1.0 इसका नवीनतम संस्करण है और इसे क्रोनोस समूह द्वारा बनाए रखा गया है । |
OpenGLSL | OpenGL Shading Language। यह एक प्रोग्रामिंग भाषा है जो OpenGL 2.0 और उच्चतर का एक साथी है। यह कोर OpenGL 4.4 विनिर्देशन का एक हिस्सा है। यह एक एपीआई है जो विशेष रूप से एम्बेडेड सिस्टम जैसे मोबाइल फोन और टैबलेट पर मौजूद है। |
Note - WebGL में, हम shaders को लिखने के लिए GLSL का उपयोग करते हैं।
WebGL क्या है?
वेबलॉग (वेब ग्राफिक्स लाइब्रेरी) वेब पर 3 डी ग्राफिक्स के लिए नया मानक है, यह 2 डी ग्राफिक्स और इंटरैक्टिव 3 डी ग्राफिक्स के प्रतिपादन के उद्देश्य से बनाया गया है। यह ओपनजीएल के ईएस 2.0 पुस्तकालय से लिया गया है जो फोन और अन्य मोबाइल उपकरणों के लिए एक निम्न-स्तरीय 3 डी एपीआई है। WebGL ES 2.0 (एंबेडेड सिस्टम) की समान कार्यक्षमता प्रदान करता है और आधुनिक 3 डी ग्राफिक्स हार्डवेयर पर अच्छा प्रदर्शन करता है।
यह एक जावास्क्रिप्ट एपीआई है जिसका उपयोग एचटीएमएल 5 के साथ किया जा सकता है। WebGL कोड <कैनवास> HTML5 के टैग के भीतर लिखा गया है। यह एक विनिर्देश है जो इंटरनेट ब्राउज़रों को उन कंप्यूटरों पर ग्राफिक प्रसंस्करण इकाइयों (जीपीयू) तक पहुंचने की अनुमति देता है जहां उनका उपयोग किया गया था।
जिन्होंने WebGL विकसित किया है
एक अमेरिकी-सर्बियाई सॉफ्टवेयर इंजीनियर का नाम Vladimir Vukicevic नींव का काम किया और वेबजीएल के निर्माण का नेतृत्व किया
2007 में, व्लादिमीर ने एक पर काम करना शुरू किया OpenGL HTML दस्तावेज़ के कैनवास तत्व के लिए प्रोटोटाइप।
मार्च 2011 में क्रोनोस ग्रुप ने वेबजीएल बनाया।
प्रतिपादन
रेंडरिंग कंप्यूटर प्रोग्राम का उपयोग करके एक मॉडल से एक छवि बनाने की प्रक्रिया है। ग्राफिक्स में, ज्यामिति, दृष्टिकोण, बनावट, प्रकाश और छायांकन जैसी जानकारी का उपयोग करके एक आभासी दृश्य का वर्णन किया जाता है, जिसे एक रेंडर प्रोग्राम के माध्यम से पारित किया जाता है। इस रेंडर प्रोग्राम का आउटपुट एक डिजिटल इमेज होगा।
प्रतिपादन के दो प्रकार हैं -
Software Rendering - सभी रेंडर कैलकुलेशन CPU की मदद से किए जाते हैं।
Hardware Rendering - सभी ग्राफिक्स कंप्यूटर्स GPU (ग्राफिकल प्रोसेसिंग यूनिट) द्वारा किए जाते हैं।
रेंडरिंग स्थानीय या दूरस्थ रूप से किया जा सकता है। यदि प्रदान की जाने वाली छवि बहुत जटिल है, तो जटिल दृश्यों को प्रस्तुत करने के लिए आवश्यक हार्डवेयर संसाधनों का पर्याप्त उपयोग करने वाले समर्पित सर्वर पर दूरस्थ रूप से प्रतिपादन किया जाता है। इसे भी कहा जाता हैserver-based rendering। सीपीयू द्वारा रेंडरिंग स्थानीय स्तर पर भी किया जा सकता है। इसे कहा जाता हैclient-based rendering।
WebGL 3D दृश्यों को प्रस्तुत करने के लिए क्लाइंट-आधारित रेंडरिंग दृष्टिकोण का अनुसरण करता है। छवि प्राप्त करने के लिए आवश्यक सभी प्रसंस्करण स्थानीय रूप से क्लाइंट के ग्राफिक्स हार्डवेयर का उपयोग करके किया जाता है।
GPU
एनवीआईडीआईए के अनुसार, एक जीपीयू "एक सिंगल चिप प्रोसेसर है जिसमें इंटीग्रेटेड ट्रांसफॉर्मेशन, लाइटिंग, ट्रायंगल सेटअप / क्लिपिंग, और रेंडरिंग इंजन हैं जो न्यूनतम 10 मिलियन पॉलीगोन प्रति सेकंड की प्रोसेसिंग में सक्षम हैं।" अनुक्रमिक प्रसंस्करण के लिए अनुकूलित कुछ कोर के साथ मल्टी-कोर प्रोसेसर के विपरीत, एक GPU में हजारों छोटे कोर होते हैं जो समानांतर रूप से कार्यभार को कुशलतापूर्वक संसाधित करते हैं। इसलिए, GPU एक डिस्प्ले बफर (RAM का एक भाग जिसमें पूर्ण फ्रेम डेटा होता है) में डिस्प्ले के आउटपुट के लिए छवियों के निर्माण को तेज करता है।
GPU त्वरित कम्प्यूटिंग
GPU त्वरित कंप्यूटिंग में, एप्लिकेशन को सीपीयू में लोड किया जाता है। जब भी उसका सामना होता है एcompute-intensiveकोड का हिस्सा, फिर कोड का वह हिस्सा लोड हो जाएगा और GPU पर चलेगा। यह प्रणाली को एक कुशल तरीके से ग्राफिक्स को संसाधित करने की क्षमता देता है।
GPU में एक अलग मेमोरी होगी और यह एक बार में कोड के एक छोटे हिस्से की कई प्रतियाँ चलाता है। GPU उन सभी डेटा को संसाधित करता है जो इसकी स्थानीय मेमोरी में हैं, केंद्रीय मेमोरी में नहीं। इसलिए, GPU द्वारा संसाधित किए जाने वाले डेटा को GPU मेमोरी में लोड / कॉपी किया जाना चाहिए और फिर संसाधित किया जाना चाहिए।
उपरोक्त आर्किटेक्चर वाली प्रणालियों में, 3 डी कार्यक्रमों के तेजी से प्रसंस्करण को प्राप्त करने के लिए सीपीयू और जीपीयू के बीच संचार उपरि को कम किया जाना चाहिए। इसके लिए, हमें बार-बार GPU के साथ संचार करने के बजाय, सभी डेटा को कॉपी करना होगा और इसे GPU पर रखना होगा।
ब्राउज़रों का समर्थन किया
निम्न तालिका वेबलॉग का समर्थन करने वाले ब्राउज़रों की एक सूची दिखाती है -
वेब ब्राउज़र्स
ब्राउज़र का नाम | संस्करण | सहयोग |
---|---|---|
Internet Explorer | 11 और ऊपर | पूरा समर्थन |
गूगल क्रोम | 39 और ऊपर | पूरा समर्थन |
सफारी | 8 | पूरा समर्थन |
फ़ायर्फ़ॉक्स | 36 और ऊपर | आंशिक समर्थन |
ओपेरा | 27 और ऊपर | आंशिक समर्थन |
मोबाइल ब्राउजर
ब्राउज़र का नाम | संस्करण | सहयोग |
---|---|---|
Android के लिए क्रोम | 42 | आंशिक समर्थन |
Android ब्राउज़र | 40 | आंशिक समर्थन |
IOS सफारी | 8.3 | पूरा समर्थन |
ओपेरा मिनी | 8 | समर्थन नहीं करता |
ब्लैकबेरी ब्राउज़र | 10 | पूरा समर्थन |
IE मोबाइल | 10 | आंशिक समर्थन |
WebGL के फायदे
यहाँ WebGL का उपयोग करने के फायदे हैं -
JavaScript programming- WebGL एप्लिकेशन जावास्क्रिप्ट में लिखे गए हैं। इन अनुप्रयोगों का उपयोग करके, आप सीधे HTML दस्तावेज़ के अन्य तत्वों के साथ बातचीत कर सकते हैं। WebGL एप्लिकेशन को समृद्ध करने के लिए आप अन्य जावास्क्रिप्ट पुस्तकालयों (जैसे JQuery) और HTML तकनीकों का भी उपयोग कर सकते हैं।
Increasing support with mobile browsers - WebGL मोबाइल ब्राउज़र जैसे iOS सफारी, Android ब्राउज़र और Android के लिए Chrome का भी समर्थन करता है।
Open source- WebGL एक ओपन सोर्स है। आप लाइब्रेरी के स्रोत कोड तक पहुंच सकते हैं और समझ सकते हैं कि यह कैसे काम करता है और इसे कैसे विकसित किया गया था।
No need for compilation- जावास्क्रिप्ट एक आधा-प्रोग्रामिंग और आधा-एचटीएमएल घटक है। इस स्क्रिप्ट को निष्पादित करने के लिए, फ़ाइल को संकलित करने की आवश्यकता नहीं है। इसके बजाय, आप किसी भी ब्राउज़र का उपयोग करके सीधे फ़ाइल खोल सकते हैं और परिणाम की जांच कर सकते हैं। चूंकि WebGL एप्लिकेशन को जावास्क्रिप्ट का उपयोग करके विकसित किया जाता है, इसलिए WebGL अनुप्रयोगों को भी संकलित करने की आवश्यकता नहीं है।
Automatic memory management- जावास्क्रिप्ट स्वचालित मेमोरी प्रबंधन का समर्थन करता है। मेमोरी के मैनुअल आवंटन की कोई आवश्यकता नहीं है। WebGL को जावास्क्रिप्ट की यह विशेषता विरासत में मिली है।
Easy to set up- चूंकि WebGL HTML 5 के भीतर एकीकृत है, अतिरिक्त सेट अप की कोई आवश्यकता नहीं है। WebGL एप्लिकेशन को लिखने के लिए, आपको एक टेक्स्ट एडिटर और एक वेब ब्राउज़र की आवश्यकता है।
पर्यावरण सेटअप
WebGL के लिए अलग वातावरण सेट करने की आवश्यकता नहीं है। WebGL का समर्थन करने वाले ब्राउज़र के पास WebGL के लिए अपना स्वयं का इन-बिल्ट सेटअप है।
वेब पर ग्राफ़िकल एप्लिकेशन बनाने के लिए, HTML-5 में 2 डी कैनवस, वेबजीएल, एसवीजी, 3 डी सीएसएस ट्रांसफ़ॉर्म और एसएमआईएल जैसी सुविधाओं का एक समृद्ध सेट प्रदान किया गया है। WebGL एप्लिकेशन लिखने के लिए, हम HTML-5 के मौजूदा कैनवास तत्व का उपयोग करते हैं। यह अध्याय HTML-5 2D कैनवास तत्व का अवलोकन प्रदान करता है।
एचटीएमएल 5 कैनवस
एचटीएमएल -5 <canvas>जावास्क्रिप्ट का उपयोग करके ग्राफिक्स बनाने के लिए एक आसान और शक्तिशाली विकल्प प्रदान करता है। इसका उपयोग ग्राफ खींचने, फोटो रचनाएं बनाने, या सरल (और इतना सरल नहीं) एनिमेशन करने के लिए किया जा सकता है।
यहाँ एक सरल है <canvas> तत्व में केवल दो विशिष्ट गुण होते हैं width तथा height प्लस सभी कोर HTML-5 विशेषताओं जैसे आईडी, नाम और वर्ग।
वाक्य - विन्यास
HTML कैनवास टैग का सिंटैक्स नीचे दिया गया है। आपको दोहरे उद्धरणों ("") के अंदर कैनवास के नाम का उल्लेख करना होगा।
<canvas id = "mycanvas" width = "100" height = "100"></canvas>
कैनवास विशेषताएँ
कैनवस टैग में तीन विशेषताएं हैं, आईडी, चौड़ाई और ऊंचाई।
Id- Id दस्तावेज़ ऑब्जेक्ट मॉडल (DOM) में कैनवास तत्व के पहचानकर्ता का प्रतिनिधित्व करता है ।
Width - चौड़ाई कैनवास की चौड़ाई का प्रतिनिधित्व करती है।
Height - ऊँचाई कैनवास की ऊँचाई का प्रतिनिधित्व करती है।
ये विशेषताएँ कैनवास के आकार को निर्धारित करती हैं। यदि कोई प्रोग्रामर कैनवास टैग के तहत उन्हें निर्दिष्ट नहीं कर रहा है, तो फ़ायरफ़ॉक्स, क्रोम और वेब किट जैसे ब्राउज़र डिफ़ॉल्ट रूप से 300 × 150 आकार का एक कैनवास तत्व प्रदान करते हैं।
उदाहरण - एक कैनवस बनाएँ
निम्नलिखित कोड दिखाता है कि एक कैनवास कैसे बनाया जाए। हमने कैनवास को रंगीन बॉर्डर देने के लिए CSS का उपयोग किया है।
<html>
<head>
<style>
#mycanvas{border:1px solid red;}
</style>
</head>
<body>
<canvas id = "mycanvas" width = "100" height = "100"></canvas>
</body>
</html>
निष्पादित करने पर, उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -
प्रतिपादन प्रसंग
<कैनवास> प्रारंभ में रिक्त है। कैनवास तत्व पर कुछ प्रदर्शित करने के लिए, हमें एक स्क्रिप्टिंग भाषा का उपयोग करना होगा। इस स्क्रिप्टिंग भाषा को प्रतिपादन संदर्भ तक पहुंचना चाहिए और उस पर आकर्षित होना चाहिए।
कैनवास तत्व में एक DOM विधि होती है जिसे कहा जाता है getContext(), जिसका उपयोग प्रतिपादन के संदर्भ और उसके ड्राइंग कार्यों को प्राप्त करने के लिए किया जाता है। यह विधि एक पैरामीटर, संदर्भ के प्रकार को लेती है2d।
आवश्यक संदर्भ प्राप्त करने के लिए निम्नलिखित कोड लिखा जाना है। आप इस स्क्रिप्ट को बॉडी टैग के अंदर लिख सकते हैं जैसा कि नीचे दिखाया गया है।
<!DOCTYPE HTML>
<html>
<body>
<canvas id = "mycanvas" width = "600" height = "200"></canvas>
<script>
var canvas = document.getElementById('mycanvas');
var context = canvas.getContext('2d');
context.font = '20pt Calibri';
context.fillStyle = 'green';
context.fillText('Welcome to Tutorialspoint', 70, 70);
</script>
</body>
</html>
निष्पादित करने पर, उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -
HTML-5 2D कैनवस पर अधिक उदाहरण के लिए, निम्न लिंक HTML-5 कैनवस देखें ।
WebGL प्रसंग
HTML5 कैनवस का उपयोग WebGL एप्लिकेशन को लिखने के लिए भी किया जाता है। कैनवास तत्व पर WebGL रेंडरिंग संदर्भ बनाने के लिए, आपको स्ट्रिंग को पास करना चाहिएexperimental-webgl, के बजाय 2d को canvas.getContext()तरीका। कुछ ब्राउज़र केवल समर्थन करते हैं 'webgl'।
<!DOCTYPE html>
<html>
<canvas id = 'my_canvas'></canvas>
<script>
var canvas = document.getElementById('my_canvas');
var gl = canvas.getContext('experimental-webgl');
gl.clearColor(0.9,0.9,0.8,1);
gl.clear(gl.COLOR_BUFFER_BIT);
</script>
</html>
निष्पादित करने पर, उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -
WebGL ज्यादातर 3D API के बजाय एक निम्न-स्तर का रेखांकन एपीआई है। WebGL का उपयोग करके एक छवि बनाने के लिए, आपको छवि का प्रतिनिधित्व करने वाला एक वेक्टर पास करना होगा। यह तब दिए गए वेक्टर को OpenGL SL का उपयोग करके पिक्सेल प्रारूप में परिवर्तित करता है और स्क्रीन पर छवि प्रदर्शित करता है। WebGL एप्लिकेशन लिखने में चरणों का एक सेट शामिल होता है जिसे हम इस अध्याय में समझा रहे हैं।
WebGL - समन्वय प्रणाली
किसी अन्य 3D सिस्टम की तरह, आपके पास WebGL में x, y और z axes होंगे, जहां z अक्ष दर्शाता है depth। WebGL में निर्देशांक (1, 1, 1) और (-1, -1, - 1) तक सीमित हैं। इसका अर्थ है - यदि आप वेबलॉग ग्राफिक्स को क्यूब के रूप में पेश करने वाले स्क्रीन पर विचार करते हैं, तो क्यूब का एक कोना (1, 1, 1) होगा और विपरीत कॉर्नर (-1, -1, -1) होगा। WebGL इन सीमाओं से परे खींची गई किसी भी चीज़ को प्रदर्शित नहीं करेगा।
निम्न आरेख में WebGL समन्वय प्रणाली को दर्शाया गया है। Z- अक्ष गहराई का द्योतक है। Z का एक सकारात्मक मान इंगित करता है कि ऑब्जेक्ट स्क्रीन / दर्शक के पास है, जबकि z का एक नकारात्मक मान इंगित करता है कि ऑब्जेक्ट स्क्रीन से दूर है। इसी तरह, x का एक सकारात्मक मान इंगित करता है कि ऑब्जेक्ट स्क्रीन के दाईं ओर है और एक नकारात्मक मान इंगित करता है कि ऑब्जेक्ट बाईं ओर है। इसी तरह, y के सकारात्मक और नकारात्मक मूल्य इंगित करते हैं कि वस्तु स्क्रीन के शीर्ष भाग पर है या नीचे।
वेबलॉग ग्राफिक्स
कैनवास ऑब्जेक्ट के WebGL संदर्भ प्राप्त करने के बाद, आप जावास्क्रिप्ट में WebGL API का उपयोग करके चित्रमय तत्वों को बनाना शुरू कर सकते हैं।
वेबलॉग के साथ शुरू करने से पहले आपको कुछ मूलभूत शर्तें बताई जानी चाहिए।
कोने
आम तौर पर, एक बहुभुज जैसी वस्तुओं को खींचने के लिए, हम विमान पर बिंदुओं को चिह्नित करते हैं और उन्हें एक वांछित बहुभुज बनाने के लिए जोड़ते हैं। एvertexएक बिंदु है जो एक 3D ऑब्जेक्ट के किनारों के संयोजन को परिभाषित करता है। यह तीन फ्लोटिंग पॉइंट वैल्यू द्वारा दर्शाया जाता है, जिसमें क्रमशः प्रत्येक x, y, z axes का प्रतिनिधित्व करता है।
उदाहरण
निम्नलिखित उदाहरण में, हम निम्नलिखित त्रिकोणों के साथ एक त्रिकोण खींच रहे हैं - (0.5, 0.5), (-0.5, 0.5), (-0.5, -0.5)।
Note - हमें जावास्क्रिप्ट कोणों का उपयोग करके मैन्युअल रूप से इन शीर्षों को संग्रहीत करना होगा और उन्हें वर्टेक्स बफर का उपयोग करते हुए WebGL रेंडरिंग पाइपलाइन को पास करना होगा।
सूचकांकों
WebGL में, वर्टिकल की पहचान करने के लिए संख्यात्मक मानों का उपयोग किया जाता है। इन संख्यात्मक मूल्यों को सूचकांक के रूप में जाना जाता है। इन सूचकांकों का उपयोग वेबजीएल में मेश खींचने के लिए किया जाता है।
Note - सिरों की तरह, हम जावास्क्रिप्ट सरणियों का उपयोग करके सूचकांकों को संग्रहीत करते हैं और उन्हें सूचकांक बफर का उपयोग करके WebGL रेंडरिंग पाइपलाइन को पास करते हैं।
सरणियों
OpenGL और JoGL के विपरीत, सीधे वर्जन को रेंडर करने के लिए WebGL में कोई पूर्वनिर्धारित तरीके नहीं हैं। हमें उन्हें जावास्क्रिप्ट सरणियों का उपयोग करके मैन्युअल रूप से संग्रहीत करना होगा।
उदाहरण
var vertices = [ 0.5, 0.5, 0.1,-0.5, 0.5,-0.5]
बफ़र
बफ़र WebGL का मेमोरी क्षेत्र है जो डेटा को होल्ड करता है। ड्राइंग बफर, फ्रेम बफर, वीटेक्स बफर, और इंडेक्स बफर जैसे विभिन्न बफर हैं। vertex buffer तथा index buffer मॉडल की ज्यामिति का वर्णन करने और संसाधित करने के लिए उपयोग किया जाता है।
वर्टेक्स बफर ऑब्जेक्ट डेटा को कोने के बारे में संग्रहीत करते हैं, जबकि इंडेक्स बफर ऑब्जेक्ट इंडेक्स के बारे में डेटा स्टोर करते हैं। सरणियों को एरे में संग्रहीत करने के बाद, हम इन बफर ऑब्जेक्ट्स का उपयोग करके उन्हें वीजीजीएल ग्राफिक्स पाइपलाइन में पास करते हैं।
Frame bufferग्राफिक्स मेमोरी का एक हिस्सा है जो दृश्य डेटा को धारण करता है। इस बफ़र में सतह की चौड़ाई और ऊँचाई (पिक्सेल में), प्रत्येक पिक्सेल का रंग, गहराई और स्टेंसिल बफ़र्स जैसे विवरण होते हैं।
जाल
2D या 3D ऑब्जेक्ट बनाने के लिए, WebGL API दो तरीके प्रदान करता है, drawArrays() तथा drawElements()। ये दो विधियां एक पैरामीटर को स्वीकार करती हैं जिसे कहा जाता हैmodeजिसका उपयोग करके आप उस ऑब्जेक्ट का चयन कर सकते हैं जिसे आप ड्रा करना चाहते हैं। इस क्षेत्र द्वारा उपलब्ध कराए गए विकल्प बिंदुओं, रेखाओं और त्रिभुजों तक सीमित हैं।
इन दो विधियों का उपयोग करके एक 3D ऑब्जेक्ट बनाने के लिए, हमें बिंदुओं, रेखाओं या त्रिकोणों का उपयोग करके एक या एक से अधिक आदिम बहुभुजों का निर्माण करना होगा। इसके बाद, उन आदिम बहुभुजों का उपयोग करके, हम एक जाल बना सकते हैं।
आदिम बहुभुजों का उपयोग करके खींची गई एक 3D वस्तु को कहा जाता है mesh। वेबजीएल 3 डी चित्रमय वस्तुओं को खींचने के लिए कई तरीके प्रदान करता है, हालांकि उपयोगकर्ता आमतौर पर एक जाल खींचना पसंद करते हैं।
उदाहरण
निम्नलिखित उदाहरण में, आप देख सकते हैं कि हमने दो त्रिकोण → {1, 2, 3} और {4, 1, 3} का उपयोग करके एक वर्ग तैयार किया है।
शेडर कार्यक्रम
हम आम तौर पर मेषों के निर्माण के लिए त्रिकोण का उपयोग करते हैं। चूंकि WebGL GPU त्वरित कंप्यूटिंग का उपयोग करता है, इन त्रिकोणों के बारे में जानकारी CPU से GPU में स्थानांतरित की जानी चाहिए जो बहुत अधिक संचार उपरि लेता है।
वेबजीएल संचार ओवरहेड को कम करने के लिए एक समाधान प्रदान करता है। चूंकि यह ES SL (एंबेडेड सिस्टम शेडर लैंग्वेज) का उपयोग करता है जो GPU पर चलता है, हम क्लाइंट सिस्टम पर ग्राफिकल तत्वों का उपयोग करने के लिए सभी आवश्यक प्रोग्राम लिखते हैंshader programs (प्रोग्राम जो हम OpenGL ES छायांकन भाषा का उपयोग करके लिखते हैं / GLSL)।
ये शेड्स GPU के लिए प्रोग्राम हैं और shader प्रोग्राम लिखने के लिए इस्तेमाल की जाने वाली भाषा GLSL है। इन शेड्स में, हम वास्तव में परिभाषित करते हैं कि किसी विशेष छवि को बनाने के लिए वर्टिकल, ट्रांसफ़ॉर्मेशन, मटेरियल, लाइट और कैमरा आपस में किस तरह से बातचीत करते हैं।
संक्षेप में, यह एक स्निपेट है जो एक जाल के लिए पिक्सेल प्राप्त करने के लिए एल्गोरिदम को लागू करता है। हम बाद के अध्यायों में shaders के बारे में अधिक चर्चा करेंगे। दो प्रकार के शेड हैं - वर्टेक्स शेडर और फ्रैगमेंट शैडर।
वर्टेक्स शेडर
वर्टेक्स शेडर प्रत्येक वर्टेक्स पर कॉल किया जाने वाला प्रोग्राम कोड है। इसका उपयोग एक स्थान से दूसरे स्थान पर ज्यामिति (उदा: त्रिकोण) को बदलने (स्थानांतरित करने) के लिए किया जाता है। यह प्रत्येक वर्टेक्स (प्रति-शीर्ष डेटा) के डेटा को संभालता है जैसे कि वर्टेक्स निर्देशांक, मानदंड, रंग और बनावट निर्देशांक।
में ES GLवर्टेक्स शेडर के कोड, प्रोग्रामर को डेटा को संभालने के लिए विशेषताओं को परिभाषित करना होगा। ये विशेषताएँ ए की ओर इशारा करती हैंVertex Buffer Object जावास्क्रिप्ट में लिखा है।
निम्नलिखित कार्यों को शीर्ष शेड का उपयोग करके किया जा सकता है -
- वर्टेक्स परिवर्तन
- सामान्य परिवर्तन और सामान्यीकरण
- बनावट समन्वय पीढ़ी
- बनावट परिवर्तन का समन्वय करती है
- Lighting
- रंग सामग्री आवेदन
फ्रैगमेंट शैडर (पिक्सेल शेडर)
एक जाल कई त्रिकोणों द्वारा बनता है, और प्रत्येक त्रिकोण की सतह को एक के रूप में जाना जाता है fragment। Fragment Shader वह कोड होता है जो हर टुकड़े के सभी पिक्सल पर चलता है। यह व्यक्तिगत पिक्सेल पर रंग की गणना और भरने के लिए लिखा गया है ।
निम्नलिखित कार्यों को Fragment shaders का उपयोग करके किया जा सकता है -
- प्रक्षेपित मूल्यों पर संचालन
- बनावट का उपयोग
- बनावट आवेदन
- Fog
- रंग राशि
OpenGL ES SL चर
का फुल फॉर्म है OpenGL ES SLOpenGL एंबेडेड सिस्टम शेडिंग लैंग्वेज है। शेडर कार्यक्रमों में डेटा को संभालने के लिए, ES SL तीन प्रकार के चर प्रदान करता है। वे इस प्रकार हैं -
Attributes- ये चर कशेरुका शैडर कार्यक्रम के इनपुट मूल्यों को धारण करते हैं। विशेषताएँ वर्टेक्स बफर ऑब्जेक्ट्स को इंगित करती हैं जिनमें प्रति-वर्टेक्स डेटा होता है। हर बार जब वर्टिकल शेडर लगाया जाता है, तो विशेषताएँ अलग-अलग चक्करों के वीबीओ की ओर इशारा करती हैं।
Uniforms - ये चर इनपुट डेटा को धारण करते हैं जो कि वर्टेक्स और फ्रेग्मेंट शेड्स, जैसे कि प्रकाश की स्थिति, बनावट निर्देशांक और रंग दोनों के लिए सामान्य है।
Varyings - इन वेरिएबल्स का उपयोग वर्टेक्स शैडर से फ्रैगमेंट शैडर में डेटा पास करने के लिए किया जाता है।
इस मूल बातों के साथ, हम अब ग्राफिक्स पाइपलाइन पर चर्चा करेंगे।
3 डी ग्राफिक्स रेंडर करने के लिए, हमें चरणों के एक अनुक्रम का पालन करना होगा। इन चरणों के रूप में जाना जाता हैgraphics pipeline या rendering pipeline। निम्न आरेख में WebGL ग्राफिक्स पाइपलाइन को दर्शाया गया है।
निम्नलिखित वर्गों में, हम पाइपलाइन में प्रत्येक चरण की एक-एक भूमिका पर चर्चा करेंगे।
जावास्क्रिप्ट
WebGL एप्लिकेशन विकसित करते समय, हम GPU के साथ संवाद करने के लिए Shader भाषा कोड लिखते हैं। जावास्क्रिप्ट का उपयोग कार्यक्रम के नियंत्रण कोड को लिखने के लिए किया जाता है, जिसमें निम्नलिखित क्रियाएं शामिल हैं -
Initialize WebGL - वेबलॉग संदर्भ को आरंभ करने के लिए जावास्क्रिप्ट का उपयोग किया जाता है।
Create arrays - हम ज्यामिति के डेटा को धारण करने के लिए जावास्क्रिप्ट सरणियों का निर्माण करते हैं।
Buffer objects - हम सरणियों को पैरामीटर के रूप में पारित करके बफर ऑब्जेक्ट (वर्टेक्स और इंडेक्स) बनाते हैं।
Shaders - हम जावास्क्रिप्ट का उपयोग करके शेड्स बनाते, संकलित और लिंक करते हैं।
Attributes - हम विशेषताएँ बना सकते हैं, उन्हें सक्षम कर सकते हैं और उन्हें जावास्क्रिप्ट का उपयोग करके बफर ऑब्जेक्ट के साथ जोड़ सकते हैं।
Uniforms - हम जावास्क्रिप्ट का उपयोग करके वर्दी को भी जोड़ सकते हैं।
Transformation matrix - जावास्क्रिप्ट का उपयोग करके, हम परिवर्तन मैट्रिक्स बना सकते हैं।
प्रारंभ में हम आवश्यक ज्यामिति के लिए डेटा बनाते हैं और उन्हें बफ़र्स के रूप में शेड में पास करते हैं। शेडर भाषा का विशेषता चर बफर ऑब्जेक्ट्स की ओर इशारा करता है, जो कि वर्टेक्स शेडर के इनपुट के रूप में पारित किए जाते हैं।
वर्टेक्स शेडर
जब हम तरीकों को लागू करके प्रतिपादन प्रक्रिया शुरू करते हैं drawElements() तथा drawArray()वर्टेक्स बफर ऑब्जेक्ट में दिए गए प्रत्येक वर्टेक्स के लिए वर्टेक्स शेडर निष्पादित किया जाता है। यह एक आदिम बहुभुज के प्रत्येक शीर्ष की स्थिति की गणना करता है और इसे अलग-अलग में संग्रहीत करता हैgl_position। यह इस तरह के रूप में अन्य विशेषताओं की गणना करता हैcolor, texture coordinates, तथा vertices यह सामान्य रूप से एक शीर्ष के साथ जुड़ा हुआ है।
आदिम सभा
प्रत्येक शीर्ष की स्थिति और अन्य विवरणों की गणना करने के बाद, अगला चरण है primitive assembly stage। यहां त्रिभुजों को इकट्ठा किया जाता है और रैस्टराइज़र को पास किया जाता है।
रैस्टराइज़ेशन
रैस्टराइज़ेशन चरण में, आदिम की अंतिम छवि में पिक्सेल निर्धारित किए जाते हैं। इसके दो चरण हैं -
Culling- शुरू में बहुभुज का अभिविन्यास (यह सामने या पीछे की ओर है?) निर्धारित किया जाता है। अनुचित अभिविन्यास वाले सभी त्रिकोण जो दृश्य क्षेत्र में दिखाई नहीं देते हैं, त्याग दिए जाते हैं। इस प्रक्रिया को कलिंग कहा जाता है।
Clipping- यदि त्रिभुज आंशिक रूप से दृश्य क्षेत्र के बाहर है, तो दृश्य क्षेत्र के बाहर का भाग हटा दिया जाता है। इस प्रक्रिया को क्लिपिंग के रूप में जाना जाता है।
भगदड़ शैडर
टुकड़े टुकड़े हो जाता है
- चर चर में डेटा भिन्न चर में,
- रस्टीजेशन चरण से प्रिमिटिव और फिर
- कोने के बीच प्रत्येक पिक्सेल के लिए रंग मानों की गणना करता है।
टुकड़ा shader प्रत्येक पिक्सेल के रंग मानों को प्रत्येक टुकड़े में संग्रहीत करता है। इन रंग मूल्यों को खंड संचालन के दौरान एक्सेस किया जा सकता है, जिसके बारे में हम आगे चर्चा करने जा रहे हैं।
खंड संचालन
आदिम में प्रत्येक पिक्सेल के रंग का निर्धारण करने के बाद टुकड़े संचालन किया जाता है। इन टुकड़े के संचालन में निम्नलिखित शामिल हो सकते हैं -
- Depth
- रंग बफर मिश्रण
- Dithering
एक बार सभी टुकड़े संसाधित हो जाने के बाद, एक 2D छवि बनती है और स्क्रीन पर प्रदर्शित होती है। frame buffer रेंडरिंग पाइपलाइन का अंतिम गंतव्य है।
फ्रेम बफर
फ्रेम बफर ग्राफिक्स मेमोरी का एक हिस्सा है जो दृश्य डेटा को धारण करता है। इस बफ़र में सतह की चौड़ाई और ऊँचाई (पिक्सेल में), प्रत्येक पिक्सेल का रंग और गहराई और स्टेंसिल बफ़र्स जैसे विवरण होते हैं।
हमने WebGL की मूल बातें और WebGL पाइपलाइन (ग्राफिक्स अनुप्रयोगों को प्रस्तुत करने के लिए एक प्रक्रिया का पालन किया) पर चर्चा की है। इस अध्याय में, हम WebGL का उपयोग करके एक त्रिभुज बनाने के लिए एक नमूना आवेदन लेने जा रहे हैं और आवेदन में निम्नलिखित चरणों का पालन करते हैं।
WebGL एप्लिकेशन की संरचना
WebGL एप्लिकेशन कोड जावास्क्रिप्ट और OpenGL Shader भाषा का एक संयोजन है।
- सीपीयू के साथ संचार करने के लिए जावास्क्रिप्ट आवश्यक है
- OpenGL Shader Language को GPU के साथ संवाद करना आवश्यक है।
नमूना आवेदन
आइए अब हम एक सरल उदाहरण लेते हैं कि 2D निर्देशांक के साथ एक सरल त्रिभुज बनाने के लिए WebGL का उपयोग कैसे करें।
<!doctype html>
<html>
<body>
<canvas width = "300" height = "300" id = "my_Canvas"></canvas>
<script>
/* Step1: Prepare the canvas and get WebGL context */
var canvas = document.getElementById('my_Canvas');
var gl = canvas.getContext('experimental-webgl');
/* Step2: Define the geometry and store it in buffer objects */
var vertices = [-0.5, 0.5, -0.5, -0.5, 0.0, -0.5,];
// Create a new buffer object
var vertex_buffer = gl.createBuffer();
// Bind an empty array buffer to it
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Pass the vertices data to the buffer
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Unbind the buffer
gl.bindBuffer(gl.ARRAY_BUFFER, null);
/* Step3: Create and compile Shader programs */
// Vertex shader source code
var vertCode =
'attribute vec2 coordinates;' +
'void main(void) {' + ' gl_Position = vec4(coordinates,0.0, 1.0);' + '}';
//Create a vertex shader object
var vertShader = gl.createShader(gl.VERTEX_SHADER);
//Attach vertex shader source code
gl.shaderSource(vertShader, vertCode);
//Compile the vertex shader
gl.compileShader(vertShader);
//Fragment shader source code
var fragCode = 'void main(void) {' + 'gl_FragColor = vec4(0.0, 0.0, 0.0, 0.1);' + '}';
// Create fragment shader object
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
// Attach fragment shader source code
gl.shaderSource(fragShader, fragCode);
// Compile the fragment shader
gl.compileShader(fragShader);
// Create a shader program object to store combined shader program
var shaderProgram = gl.createProgram();
// Attach a vertex shader
gl.attachShader(shaderProgram, vertShader);
// Attach a fragment shader
gl.attachShader(shaderProgram, fragShader);
// Link both programs
gl.linkProgram(shaderProgram);
// Use the combined shader program object
gl.useProgram(shaderProgram);
/* Step 4: Associate the shader programs to buffer objects */
//Bind vertex buffer object
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
//Get the attribute location
var coord = gl.getAttribLocation(shaderProgram, "coordinates");
//point an attribute to the currently bound VBO
gl.vertexAttribPointer(coord, 2, gl.FLOAT, false, 0, 0);
//Enable the attribute
gl.enableVertexAttribArray(coord);
/* Step5: Drawing the required object (triangle) */
// Clear the canvas
gl.clearColor(0.5, 0.5, 0.5, 0.9);
// Enable the depth test
gl.enable(gl.DEPTH_TEST);
// Clear the color buffer bit
gl.clear(gl.COLOR_BUFFER_BIT);
// Set the view port
gl.viewport(0,0,canvas.width,canvas.height);
// Draw the triangle
gl.drawArrays(gl.TRIANGLES, 0, 3);
</script>
</body>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
यदि आप उपरोक्त कार्यक्रम को ध्यान से देखते हैं, तो हमने WebGL का उपयोग करके एक सरल त्रिभुज बनाने के लिए पांच अनुक्रमिक चरणों का पालन किया है। कदम इस प्रकार हैं -
Step 1 − Prepare the canvas and get WebGL rendering context
हमें वर्तमान HTML कैनवास ऑब्जेक्ट मिलता है और इसके WebGL रेंडरिंग संदर्भ को प्राप्त करता है।
Step 2 − Define the geometry and store it in buffer objects
हम ज्यामिति की विशेषताओं जैसे कि कोने, सूचकांक, रंग आदि को परिभाषित करते हैं, और उन्हें जावास्क्रिप्ट सरणियों में संग्रहीत करते हैं। फिर, हम एक या अधिक बफ़र ऑब्जेक्ट बनाते हैं और संबंधित बफ़र ऑब्जेक्ट में डेटा वाले ऐरे पास करते हैं। उदाहरण में, हम एक जावास्क्रिप्ट सरणी में त्रिकोण के कोने को संग्रहीत करते हैं और इस सरणी को एक शीर्ष बफर ऑब्जेक्ट पर पास करते हैं।
Step 3 − Create and compile Shader programs
हम शीर्ष shader और टुकड़ा shader प्रोग्राम लिखते हैं, उन्हें संकलित करते हैं, और इन दो कार्यक्रमों को जोड़कर एक संयुक्त कार्यक्रम बनाते हैं।
Step 4 − Associate the shader programs with buffer objects
हम बफर ऑब्जेक्ट और संयुक्त shader प्रोग्राम को जोड़ते हैं।
Step 5 − Drawing the required object (triangle)
इस कदम में रंग को साफ़ करना, बफर बिट को साफ़ करना, गहराई परीक्षण को सक्षम करना, व्यू पोर्ट को सेट करना इत्यादि जैसे ऑपरेशन शामिल हैं। अंत में, आपको किसी एक तरीके का उपयोग करके आवश्यक प्राइमेटिव्स को आकर्षित करने की आवश्यकता है - drawArrays() या drawElements()।
इन सभी चरणों को इस ट्यूटोरियल में आगे समझाया गया है।
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 की ऊंचाई विशेषता से भिन्न हो सकता है। |
WebGL संदर्भ प्राप्त करने के बाद, आपको आदिम के लिए ज्यामिति को परिभाषित करना होगा (जिस वस्तु को आप खींचना चाहते हैं) और उसे संग्रहीत करना है। WebGL में, हम एक ज्यामिति के विवरण को परिभाषित करते हैं - उदाहरण के लिए, वर्टिकल, इंडेक्स, आदिम का रंग - जावास्क्रिप्ट सरणियों का उपयोग करते हुए। इन विवरणों को shader प्रोग्राम्स में पास करने के लिए, हमें बफर ऑब्जेक्ट्स बनाने होंगे और संबंधित बफ़र्स में मौजूद डेटा को जावास्क्रिप्ट सरणियों को स्टोर (अटैच) करना होगा।
Note: बाद में, इन बफर ऑब्जेक्ट्स को shader प्रोग्राम (वर्टेक्स shader) की विशेषताओं के साथ जोड़ा जाएगा।
आवश्यक ज्यामिति को परिभाषित करना
एक 2 डी या 3 डी मॉडल को कोने का उपयोग करके तैयार किया जाता है mesh। एक जाल में प्रत्येक पहलू एक कहा जाता हैpolygon और एक बहुभुज 3 या अधिक चक्करों से बना है।
WebGL रेंडरिंग संदर्भ में मॉडल तैयार करने के लिए, आपको जावास्क्रिप्ट सरणियों का उपयोग करके कोने और सूचकांकों को परिभाषित करना होगा। उदाहरण के लिए, यदि हम एक त्रिभुज बनाना चाहते हैं जो निर्देशांक {(5,5), (-5,5), (-5, -5)} पर आधारित हो जैसा कि चित्र में दिखाया गया है, तो आप इसके लिए एक सरणी बना सकते हैं के रूप में कोने -
var vertices = [
0.5,0.5, //Vertex 1
0.5,-0.5, //Vertex 2
-0.5,-0.5, //Vertex 3
];
इसी तरह, आप सूचकांकों के लिए एक सरणी बना सकते हैं। उपरोक्त त्रिकोण सूचकांकों के लिए संकेत [0, 1, 2] होंगे और इन्हें इस प्रकार परिभाषित किया जा सकता है -
var indices = [ 0,1,2 ]
सूचकांकों की बेहतर समझ के लिए, वर्ग जैसे अधिक जटिल मॉडल पर विचार करें। हम दो त्रिकोणों के एक समूह के रूप में एक वर्ग का प्रतिनिधित्व कर सकते हैं। यदि (0,3,1) और (3,1,2) दो त्रिकोण हैं, जिनका उपयोग करके हम एक वर्ग आकर्षित करना चाहते हैं, तो सूचकांकों को परिभाषित किया जाएगा -
var indices = [0,3,1,3,1,2];
Note -
आदिम ड्राइंग के लिए, WebGL निम्नलिखित दो तरीके प्रदान करता है -
drawArrays() - इस पद्धति का उपयोग करते समय, हम जावास्क्रिप्ट सरणियों का उपयोग करके आदिम के कोने को पास करते हैं।
drawElements() - इस पद्धति का उपयोग करते हुए, हम जावास्क्रिप्ट सरणी का उपयोग करके आदिम के दोनों कोने और सूचकांक पास करते हैं।
बफर ऑब्जेक्ट्स
एक बफर ऑब्जेक्ट WebGL द्वारा प्रदान किया गया एक तंत्र है जो सिस्टम में आवंटित मेमोरी क्षेत्र को इंगित करता है। इन बफ़र ऑब्जेक्ट्स में, आप उस मॉडल के डेटा को स्टोर कर सकते हैं जिसे आप खींचना चाहते हैं, जो कि कोने, सूचकांक, रंग, आदि के अनुरूप है।
इन बफ़र ऑब्जेक्ट्स का उपयोग करते हुए, आप इसके एक विशेषता चर के माध्यम से shader प्रोग्राम (वर्टेक्स shader) में कई डेटा पास कर सकते हैं। चूंकि ये बफर ऑब्जेक्ट जीपीयू मेमोरी में रहते हैं, इसलिए उन्हें सीधे प्रदान किया जा सकता है, जो बदले में प्रदर्शन में सुधार करता है।
ज्यामिति को संसाधित करने के लिए, दो प्रकार के बफर ऑब्जेक्ट हैं। वे हैं -
Vertex buffer object (VBO)- यह ग्राफिकल मॉडल के प्रति-वर्टेक्स डेटा को धारण करता है, जो प्रस्तुत होने वाला है। हम वर्टिकल निर्देशांक, मानदंड, रंग, और बनावट निर्देशांक के रूप में डेटा को संग्रहीत और संसाधित करने के लिए WebGL में वर्टेक्स बफर ऑब्जेक्ट का उपयोग करते हैं।
Index buffer objects (IBO) - यह चित्रमय मॉडल के सूचकांकों (सूचकांक डेटा) को धारण करता है, जो इसका प्रतिपादन करने वाला है।
आवश्यक ज्यामिति को परिभाषित करने और उन्हें जावास्क्रिप्ट सरणियों में संग्रहीत करने के बाद, आपको इन सरणियों को बफर ऑब्जेक्ट्स को पास करने की आवश्यकता है, जहां से डेटा को shader कार्यक्रमों में पारित किया जाएगा। बफ़र्स में डेटा संग्रहीत करने के लिए निम्न चरणों का पालन किया जाना चाहिए।
एक खाली बफर बनाएं।
खाली बफर के लिए एक उपयुक्त सरणी वस्तु को बांधें।
किसी एक का उपयोग करके बफ़र को डेटा (कोने / सूचकांक) पास करें typed arrays।
बफर (वैकल्पिक) को खोल दें।
बफ़र बनाना
खाली बफर ऑब्जेक्ट बनाने के लिए, WebGL नामक एक विधि प्रदान करता है createBuffer()। यह विधि एक नई बनाई गई बफर वस्तु लौटाती है, अगर निर्माण सफल रहा; अन्यथा यह विफलता के मामले में एक अशक्त मूल्य देता है।
WebGL एक स्टेट मशीन के रूप में काम करती है। एक बार एक बफर बनाने के बाद, किसी भी बाद के बफर ऑपरेशन को वर्तमान बफर पर निष्पादित किया जाएगा जब तक कि हम इसे अनबाउंड नहीं करते। बफर बनाने के लिए निम्न कोड का उपयोग करें -
var vertex_buffer = gl.createBuffer();
Note - gl वर्तमान WebGL संदर्भ का संदर्भ चर है।
बफ़र को बांधें
एक खाली बफर ऑब्जेक्ट बनाने के बाद, आपको इसे एक उपयुक्त सरणी बफर (लक्ष्य) को बांधने की आवश्यकता है। WebGL नामक एक विधि प्रदान करता हैbindBuffer() इस काम के लिए।
वाक्य - विन्यास
का वाक्य विन्यास bindBuffer() विधि इस प्रकार है -
void bindBuffer (enum target, Object buffer)
यह विधि दो मापदंडों को स्वीकार करती है और नीचे उनकी चर्चा की जाती है।
target- पहला वेरिएबल एक एनम वैल्यू है, जिसे हम उस बफर के प्रकार को दर्शाते हैं, जिसे हम खाली बफर से बांधना चाहते हैं। इस पैरामीटर के विकल्प के रूप में आपके पास दो पूर्वनिर्धारित एनम मान हैं। वे हैं -
ARRAY_BUFFER जो वर्टेक्स डेटा का प्रतिनिधित्व करता है।
ELEMENT_ARRAY_BUFFER जो सूचकांक डेटा का प्रतिनिधित्व करता है।
Object buffer- दूसरा चरण पिछले चरण में बनाई गई बफर ऑब्जेक्ट के लिए संदर्भ चर है। संदर्भ चर एक वर्टिकल बफर ऑब्जेक्ट या इंडेक्स बफर ऑब्जेक्ट का हो सकता है।
उदाहरण
निम्न कोड स्निपेट दिखाता है कि bindBuffer () विधि का उपयोग कैसे करें।
//vertex buffer
var vertex_buffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
//Index buffer
var Index_Buffer = gl.createBuffer();
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, index_buffer);
बफ़र में डेटा पास करना
अगला कदम बफर को डेटा (कोने / सूचकांक) पास करना है। अब तक डेटा एक सरणी के रूप में है और इसे बफर में पास करने से पहले, हमें इसे वेबजीएल टाइपिंग सरणियों में से एक में लपेटने की आवश्यकता है। WebGL नामक एक विधि प्रदान करता हैbufferData() इस काम के लिए।
वाक्य - विन्यास
बफरडेटा () विधि का वाक्य विन्यास इस प्रकार है -
void bufferData (enum target, Object data, enum usage)
यह विधि तीन मापदंडों को स्वीकार करती है और नीचे उनकी चर्चा की गई है -
target - पहला पैरामीटर एक एनम वैल्यू है जो हम उपयोग किए गए सरणी बफर के प्रकार का प्रतिनिधित्व करते हैं। इस पैरामीटर के लिए विकल्प हैं -
ARRAY_BUFFER जो दर्शाता है vertex data।
ELEMENT_ARRAY_BUFFER जो दर्शाता है index data।
Object data- दूसरा पैरामीटर ऑब्जेक्ट वैल्यू है जिसमें बफर ऑब्जेक्ट को लिखा जाने वाला डेटा होता है। यहां हमें डेटा का उपयोग करके पास करना होगाtyped arrays।
Usage- इस विधि का तीसरा पैरामीटर एक एनम चर है जो यह बताता है कि आकृतियों को खींचने के लिए बफर ऑब्जेक्ट डेटा (संग्रहीत डेटा) का उपयोग कैसे करें। नीचे सूचीबद्ध के रूप में इस पैरामीटर के लिए तीन विकल्प हैं।
gl.STATIC_DRAW - डेटा एक बार निर्दिष्ट किया जाएगा और कई बार उपयोग किया जाएगा।
gl.STREAM_DRAW - डेटा एक बार निर्दिष्ट किया जाएगा और कुछ समय का उपयोग किया जाएगा।
gl.DYNAMIC_DRAW - डेटा को बार-बार निर्दिष्ट किया जाएगा और कई बार उपयोग किया जाएगा।
उदाहरण
निम्न कोड स्निपेट दिखाता है कि कैसे उपयोग करना है bufferData()तरीका। वर्टिस और इंडेक्स क्रमशः ऐरेक्स और इंडेक्स डेटा को धारण करने वाले ऐरे हैं।
//vertex buffer
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
//Index buffer
gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
टाइप किए गए एरे
WebGL नामक एक विशेष प्रकार की सरणी प्रदान करता है typed arraysसूचकांक और बनावट जैसे डेटा तत्वों को स्थानांतरित करने के लिए। ये टाइप किए गए सरणियाँ बड़ी मात्रा में डेटा संग्रहीत करते हैं और उन्हें मूल द्विआधारी प्रारूप में संसाधित करते हैं जिसके परिणामस्वरूप बेहतर प्रदर्शन होता है। WebGL द्वारा उपयोग किए गए टाइप किए गए सरणियों में Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, UInt32Array, Float32Array और Float64Array हैं।
Note
आमतौर पर, शीर्ष डेटा संग्रहीत करने के लिए, हम उपयोग करते हैं Float32Array; और इंडेक्स डेटा को स्टोर करने के लिए, हम उपयोग करते हैंUint16Array।
आप जावास्क्रिप्ट सरणियों का उपयोग करके टाइप किए गए सरणियों को बना सकते हैं new कीवर्ड।
बफ़र्स को अनबाइंड करें
यह अनुशंसा की जाती है कि आप बफ़र्स को उपयोग करने के बाद उन्मुक्त कर दें। इसे बफर ऑब्जेक्ट के स्थान पर एक शून्य मान पास करके किया जा सकता है, जैसा कि नीचे दिखाया गया है।
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);
WebGL बफर संचालन करने के लिए निम्नलिखित तरीके प्रदान करता है -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | शून्य bindBuffer(एनम टारगेट , ऑब्जेक्ट बफर ) लक्ष्य - ARRAY_BUFFER, ELEMENT_ARRAY_BUFFER |
2 | शून्य bufferData(enum target , long size , enum उपयोग ) लक्ष्य - ARRAY_BUFFER, ELEMENT_ARRAY_BUFFER उपयोग - STATIC_DRAW, STREAM_DRAW, DYNAMIC_DRAW |
3 | शून्य bufferData(एनम टारगेट , ऑब्जेक्ट डेटा , एनम यूसेज ) लक्ष्य और उपयोग - के लिए भीbufferData ऊपर |
4 | शून्य bufferSubData(enum target , long ऑफसेट , ऑब्जेक्ट डेटा ) लक्ष्य - ARRAY_BUFFER, ELEMENT_ARRAY_BUFFER |
5 | वस्तु createBuffer() |
6 | शून्य deleteBuffer(ऑब्जेक्ट बफर ) |
7 | कोई भी getBufferParameter(enum target , enum pname ) लक्ष्य - ARRAY_BUFFER, ELEMENT_ ARRAY_BUFFER pname - BUFFER_SIZE, BUFFER_USAGE |
8 | bool isBuffer(ऑब्जेक्ट बफर ) |
शेडर्स वे प्रोग्राम हैं जो GPU पर चलते हैं। शेड्स OpenGL ES Shader Language (ES SL के रूप में जाना जाता है) में लिखे गए हैं। ES SL के अपने स्वयं के चर, डेटा प्रकार, क्वालिफायर, अंतर्निहित इनपुट और आउटपुट हैं।
जानकारी का प्रकार
निम्न तालिका OpenGL ES SL द्वारा प्रदान किए गए मूल डेटा प्रकारों को सूचीबद्ध करती है।
अनु क्रमांक। | टाइप और विवरण |
---|---|
1 | void एक खाली मूल्य का प्रतिनिधित्व करता है। |
2 | bool सही या गलत को स्वीकार करता है। |
3 | int यह एक हस्ताक्षरित पूर्णांक डेटा प्रकार है। |
4 | float यह एक फ्लोटिंग स्केलर डेटा टाइप है। |
5 | vec2, vec3, vec4 n- घटक फ्लोटिंग पॉइंट वेक्टर |
6 | bvec2, bvec3, bvec4 बूलियन वेक्टर |
7 | ivec2, ivec3, ivec4 पूर्णांक वेक्टर पर हस्ताक्षर किए |
8 | mat2, mat3, mat4 2x2, 3x3, 4x4 फ्लोट मैट्रिक्स |
9 | sampler2D 2 डी बनावट तक पहुंचें |
10 | samplerCube एक्सेस क्यूब मैप्ड बनावट |
क्वालिफायर
OpenGL ES SL में तीन मुख्य क्वालिफायर हैं -
अनु क्रमांक। | क्वालीफायर और विवरण |
---|---|
1 | attribute यह क्वालीफायर प्रति-शीर्ष डेटा के लिए एक वर्टेक्स शेडर और ओपनजीएल ईएस के बीच एक लिंक के रूप में कार्य करता है। इस विशेषता का मूल्य वर्टिकल शेडर के प्रत्येक निष्पादन के लिए बदलता है। |
2 | uniform यह क्वालीफायर shader प्रोग्राम और WebGL एप्लिकेशन को जोड़ता है। विशेषता योग्यता के विपरीत, वर्दी के मूल्य नहीं बदलते हैं। वर्दी केवल पढ़ने के लिए है; आप किसी भी बुनियादी डेटा प्रकार के साथ उनका उपयोग कर सकते हैं, एक चर घोषित करने के लिए। Example - वर्दी vec4 lightPosition; |
3 | varying यह क्वालीफायर प्रक्षेपित डेटा के लिए एक वर्टेक्स shader और टुकड़ा shader के बीच एक लिंक बनाता है। इसका उपयोग निम्न डेटा प्रकारों के साथ किया जा सकता है - फ्लोट, vec2, vec3, vec4, mat2, mat3, mat4, या सरणियाँ। Example - अलग-अलग vec3 सामान्य; |
वर्टेक्स शेडर
वर्टेक्स शेडर एक प्रोग्राम कोड है, जिसे हर वर्टेक्स पर बुलाया जाता है। यह एक स्थान से दूसरे स्थान पर ज्यामिति (उदा: त्रिकोण) को परिवर्तित (स्थानांतरित) करता है। यह प्रत्येक वर्टेक्स (प्रति-शीर्ष डेटा) के डेटा को संभालता है जैसे कि वर्टेक्स निर्देशांक, मानदंड, रंग और बनावट निर्देशांक।
वर्टेक्स शेडर के ईएस जीएल कोड में, प्रोग्रामर को डेटा को संभालने के लिए विशेषताओं को परिभाषित करना होता है। ये विशेषताएँ जावास्क्रिप्ट में लिखे गए वर्टेक्स बफर ऑब्जेक्ट को इंगित करती हैं। निम्नलिखित कार्यों को शीर्ष परिवर्तन के साथ-साथ शीर्ष परिवर्तन का उपयोग करके किया जा सकता है -
- वर्टेक्स परिवर्तन
- सामान्य परिवर्तन और सामान्यीकरण
- बनावट समन्वय पीढ़ी
- बनावट परिवर्तन का समन्वय करती है
- Lighting
- रंग सामग्री आवेदन
पूर्वनिर्धारित चर
ओपनजीएल एसएल एसएलआर शाफ़्ट के लिए निम्नलिखित पूर्वनिर्धारित चर प्रदान करता है -
अनु क्रमांक। | चर और विवरण |
---|---|
1 | highp vec4 gl_Position; शीर्ष की स्थिति धारण करता है। |
2 | mediump float gl_PointSize; रूपांतरित बिंदु आकार धारण करता है। इस चर के लिए इकाइयाँ पिक्सेल हैं। |
नमूना कोड
एक शीर्ष shader के निम्नलिखित नमूना कोड पर एक नज़र डालें। यह एक त्रिभुज के कोने को संसाधित करता है।
attribute vec2 coordinates;
void main(void) {
gl_Position = vec4(coordinates, 0.0, 1.0);
};
यदि आप उपरोक्त कोड को ध्यान से देखते हैं, तो हमने नाम के साथ एक विशेषता चर घोषित किया है coordinates। (यह चर विधि का उपयोग करके वर्टेक्स बफर ऑब्जेक्ट के साथ जुड़ा होगाgetAttribLocation()। विशेषता हैcoordinates shader कार्यक्रम ऑब्जेक्ट के साथ इस विधि के लिए एक पैरामीटर के रूप में पारित किया गया है।)
दिए गए वर्टेक्स शेडर प्रोग्राम के दूसरे चरण में, gl_position चर परिभाषित किया गया है।
gl_Position
gl_Position पूर्वनिर्धारित चर है जो केवल शीर्ष shader प्रोग्राम में उपलब्ध है। इसमें शीर्ष स्थिति होती है। उपरोक्त कोड में,coordinatesविशेषता को वेक्टर के रूप में पारित किया जाता है। जैसा कि वर्टेक्स शेडर एक-वर्टेक्स ऑपरेशन है, प्रत्येक वर्टेक्स के लिए gl_position मान की गणना की जाती है।
बाद में, gl_position मान का उपयोग आदिम असेंबली द्वारा किया जाता है, क्लिपिंग, पुलिंग, और अन्य निश्चित कार्यक्षमता संचालन जो क्रियाओं के समाप्त होने के बाद आदिम पर काम करते हैं।
हम सभी शीर्ष संचालन के लिए वर्टेक्स शेडर प्रोग्राम लिख सकते हैं, जिसे हम इस ट्यूटोरियल में अलग-अलग चर्चा करेंगे।
भगदड़ शैडर
ए mesh कई त्रिकोणों द्वारा बनता है, और प्रत्येक त्रिकोण की सतह को एक के रूप में जाना जाता है fragment। एक टुकड़ा shader कोड है जो प्रत्येक टुकड़े पर प्रत्येक पिक्सेल पर चलता है। यह व्यक्तिगत पिक्सेल पर रंग की गणना और भरने के लिए लिखा गया है। निम्नांकित कार्यों को टुकड़े टुकड़े का उपयोग करके किया जा सकता है -
- प्रक्षेपित मूल्यों पर संचालन
- बनावट का उपयोग
- बनावट आवेदन
- Fog
- रंग राशि
पूर्वनिर्धारित चर
OpenGL ES SL टुकड़ा shader के लिए निम्नलिखित पूर्वनिर्धारित चर प्रदान करता है -
अनु क्रमांक। | चर और विवरण |
---|---|
1 | मध्यम वीसी ४ gl_FragCoord; फ़्रेम बफ़र के भीतर खंड स्थिति रखता है। |
2 | bool gl_FrontFacing; उस टुकड़े को पकड़ता है जो सामने वाले आदिम का है। |
3 | mediump vec2 gl_PointCoord; एक बिंदु के भीतर टुकड़े की स्थिति को जोड़ता है (केवल बिंदु विघटन)। |
4 | mediump vec4 gl_FragColor; शेडर के आउटपुट विखंडन रंग मान को धारण करता है |
5 | mediump vec4 gl_FragData[n] रंग लगाव के लिए टुकड़ा रंग धारण करता है n। |
नमूना कोड
एक टुकड़ा shader का निम्नलिखित नमूना कोड दिखाता है कि त्रिकोण में प्रत्येक पिक्सेल पर रंग कैसे लागू किया जाए।
void main(void) {
gl_FragColor = vec4(0, 0.8, 0, 1);
}
उपरोक्त कोड में, colorमान चर में संग्रहीत किया जाता है gl.FragColor
। टुकड़ा shader प्रोग्राम फिक्स्ड फ़ंक्शन चर का उपयोग करके पाइप लाइन के लिए आउटपुट पास करता है; FragColor उनमें से एक है। यह चर मॉडल के पिक्सल का रंग मूल्य रखता है।
शेडर प्रोग्राम्स को संग्रहीत करना और उनका संकलन करना
चूंकि शेड स्वतंत्र कार्यक्रम हैं, हम उन्हें एक अलग स्क्रिप्ट के रूप में लिख सकते हैं और एप्लिकेशन में उपयोग कर सकते हैं। या, आप उन्हें सीधे स्टोर कर सकते हैंstring प्रारूप, जैसा कि नीचे दिखाया गया है।
var vertCode =
'attribute vec2 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 0.0, 1.0);' +
'}';
शाडर का संकलन
संकलन में तीन चरण शामिल हैं -
- शेडर ऑब्जेक्ट बनाना
- स्रोत कोड को निर्मित shader ऑब्जेक्ट में संलग्न करना
- कार्यक्रम का संकलन
वर्टेक्स शेडर बनाना
खाली shader बनाने के लिए, WebGL नामक एक विधि प्रदान करता है createShader()। यह shader ऑब्जेक्ट बनाता है और देता है। इसका सिंटैक्स इस प्रकार है -
Object createShader (enum type)
सिंटैक्स में देखा गया है, यह विधि पैरामीटर के रूप में पूर्वनिर्धारित एनम मान को स्वीकार करती है। हमारे पास इसके लिए दो विकल्प हैं -
gl.VERTEX_SHADER शीर्ष shader बनाने के लिए
gl.FRAGMENT_SHADER टुकड़ा बनाने के लिए।
स्रोत को Shader में संलग्न करना
आप विधि कोड का उपयोग करके बनाई गई shader ऑब्जेक्ट में संलग्न कर सकते हैं shaderSource()। इसका सिंटैक्स इस प्रकार है -
void shaderSource(Object shader, string source)
यह विधि दो मापदंडों को स्वीकार करती है -
shader - आपको बनाए गए shader ऑब्जेक्ट को एक पैरामीटर के रूप में पास करना होगा।
Source - आपको shader program code को string format में पास करना होगा।
कार्यक्रम का संकलन
कार्यक्रम को संकलित करने के लिए, आपको विधि का उपयोग करना होगा compileShader()। इसका सिंटैक्स निम्नानुसार है -
compileShader(Object shader)
यह विधि shader प्रोग्राम ऑब्जेक्ट को एक पैरामीटर के रूप में स्वीकार करता है। शेडर प्रोग्राम ऑब्जेक्ट बनाने के बाद, स्रोत कोड को इसमें संलग्न करें और उस ऑब्जेक्ट को इस विधि से पास करें।
निम्न कोड स्निपेट दिखाता है कि कैसे एक ट्राइसेप्टर बनाने के लिए एक वर्टेक्स शेडर के साथ-साथ एक टुकड़े टुकड़े करने वाले को संकलित किया जाए।
// Vertex Shader
var vertCode =
'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'}';
var vertShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertShader, vertCode);
gl.compileShader(vertShader);
// Fragment Shader
var fragCode =
'void main(void) {' +
' gl_FragColor = vec4(0, 0.8, 0, 1);' +
'}';
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragShader, fragCode);
gl.compileShader(fragShader);
संयुक्त कार्यक्रम
दोनों shader प्रोग्राम को बनाने और संकलित करने के बाद, आपको एक संयुक्त प्रोग्राम बनाना होगा जिसमें दोनों shaders (वर्टेक्स और टुकड़ा) हों। निम्नलिखित चरणों का पालन करने की आवश्यकता है -
- एक प्रोग्राम ऑब्जेक्ट बनाएँ
- दोनों शेड्स को अटैच करें
- दोनों shaders को लिंक करें
- प्रोग्राम का उपयोग करें
एक कार्यक्रम वस्तु बनाएँ
विधि का उपयोग करके एक प्रोग्राम ऑब्जेक्ट बनाएं createProgram()। यह एक खाली प्रोग्राम ऑब्जेक्ट लौटाएगा। यहाँ इसका सिंटेक्स है -
createProgram();
शेड्स संलग्न करें
विधि का उपयोग करके बनाई गई प्रोग्राम ऑब्जेक्ट को शेड्स संलग्न करें attachShader()। इसका सिंटैक्स इस प्रकार है -
attachShader(Object program, Object shader);
यह विधि दो मापदंडों को स्वीकार करती है -
Program - बनाए गए खाली प्रोग्राम ऑब्जेक्ट को एक पैरामीटर के रूप में पास करें।
Shader - संकलित शेड कार्यक्रमों में से एक को पास करें (वर्टेक्स शेडर, टुकड़ा shader)
Note - आपको इस विधि का उपयोग करके दोनों शेड्स को संलग्न करना होगा।
लिंक लिंक करें
विधि का उपयोग करके शेड्स को लिंक करें linkProgram(), प्रोग्राम ऑब्जेक्ट को पास करके, जिससे आपने शेड्स संलग्न किए हैं। इसका सिंटैक्स इस प्रकार है -
linkProgram(shaderProgram);
प्रोग्राम का उपयोग करें
WebGL नामक एक विधि प्रदान करता है useProgram()। आपको इससे जुड़े प्रोग्राम को पास करना होगा। इसका सिंटैक्स इस प्रकार है -
useProgram(shaderProgram);
निम्न कोड स्निपेट दिखाता है कि एक संयुक्त shader प्रोग्राम कैसे बनाया जाए, लिंक किया जाए और उसका उपयोग कैसे किया जाए।
var shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertShader);
gl.attachShader(shaderProgram, fragShader);
gl.linkProgram(shaderProgram);
gl.useProgram(shaderProgram);
वर्टेक्स शेडर प्रोग्राम में प्रत्येक विशेषता एक वर्टेक्स बफर ऑब्जेक्ट को इंगित करता है। वर्टेक्स बफर ऑब्जेक्ट बनाने के बाद, प्रोग्रामर को उन्हें वर्टेक्स शेडर प्रोग्राम की विशेषताओं के साथ जोड़ना होगा। प्रत्येक विशेषता केवल एक शीर्ष बफ़र ऑब्जेक्ट को इंगित करती है जिसमें से वे डेटा मान निकालते हैं, और फिर इन विशेषताओं को shader प्रोग्राम में पास किया जाता है।
वर्टेक्स शैडर प्रोग्राम की विशेषताओं के साथ वर्टेक्स बफर ऑब्जेक्ट्स को जोड़ने के लिए, आपको नीचे दिए गए चरणों का पालन करना होगा -
- विशेषता स्थान प्राप्त करें
- विशेषता को एक शीर्ष बफर ऑब्जेक्ट पर इंगित करें
- विशेषता सक्षम करें
गुण स्थान प्राप्त करें
WebGL नामक एक विधि प्रदान करता है getAttribLocation()जो विशेषता स्थान देता है। इसका सिंटैक्स इस प्रकार है -
ulong getAttribLocation(Object program, string name)
यह विधि वर्टेक्स शेडर प्रोग्राम ऑब्जेक्ट और वर्टेक्स शेडर प्रोग्राम के विशेषता मानों को स्वीकार करती है।
निम्न कोड स्निपेट दिखाता है कि इस विधि का उपयोग कैसे किया जाए।
var coordinatesVar = gl.getAttribLocation(shader_program, "coordinates");
यहाँ, shader_program shader कार्यक्रम का उद्देश्य है और coordinates वर्टेक्स शेडर प्रोग्राम की विशेषता है।
एक वीबीओ के लिए विशेषता को इंगित करें
विशेषता चर के बफर ऑब्जेक्ट को असाइन करने के लिए, WebGL नामक एक विधि प्रदान करता है vertexAttribPointer()। यहाँ इस विधि का वाक्य रचना है -
void vertexAttribPointer(location, int size, enum type, bool normalized, long stride, long offset)
यह विधि छह मापदंडों को स्वीकार करती है और नीचे उनकी चर्चा की जाती है।
Location- यह एक विशेषता चर के भंडारण स्थान को निर्दिष्ट करता है। इस विकल्प के तहत, आपको द्वारा दिए गए मान को पास करना होगाgetAttribLocation() तरीका।
Size - यह बफर ऑब्जेक्ट में प्रति शीर्ष घटक की संख्या को निर्दिष्ट करता है।
Type - यह डेटा के प्रकार को निर्दिष्ट करता है।
Normalized- यह बूलियन मान है। यदि सच है, तो गैर-अस्थायी डेटा को सामान्यीकृत किया जाता है [0, 1]; वरना, इसे सामान्यीकृत किया जाता है [-1, 1]।
Stride - यह अलग-अलग शीर्ष डेटा तत्वों के बीच बाइट्स की संख्या को निर्दिष्ट करता है, या डिफ़ॉल्ट स्ट्राइड के लिए शून्य है।
Offset- यह इंगित करने के लिए बफर ऑब्जेक्ट में ऑफसेट (बाइट्स में) निर्दिष्ट करता है कि किस बाइट से डेटा संग्रहीत किया जाता है। यदि डेटा शुरुआत से संग्रहीत है, तो ऑफसेट 0 है।
निम्नलिखित स्निपेट दिखाता है कि कैसे उपयोग करना है vertexAttribPointer() एक कार्यक्रम में -
gl.vertexAttribPointer(coordinatesVar, 3, gl.FLOAT, false, 0, 0);
गुण को सक्षम करना
एक शीर्ष छाया में बफर वस्तु तक पहुँचने के लिए वर्टेक्स शेडर विशेषता को सक्रिय करें। इस ऑपरेशन के लिए, WebGL प्रदान करता हैenableVertexAttribArray()तरीका। यह विधि एक पैरामीटर के रूप में विशेषता के स्थान को स्वीकार करती है। एक कार्यक्रम में इस विधि का उपयोग करने का तरीका बताया गया है -
gl.enableVertexAttribArray(coordinatesVar);
बफ़र्स को शेड्स के साथ जोड़ने के बाद, अंतिम कदम आवश्यक प्राइमिटिव को आकर्षित करना है। WebGL दो तरीके प्रदान करता है,drawArrays() तथा drawElements() मॉडल बनाने के लिए।
drawArrays ()
drawArrays()वह विधि है जो वर्टिकल का उपयोग करके मॉडल बनाने के लिए उपयोग की जाती है। यहाँ इसका सिंटेक्स है -
void drawArrays(enum mode, int first, long count)
यह विधि निम्नलिखित तीन मापदंडों को लेती है -
mode- WebGL में, मॉडल आदिम प्रकारों का उपयोग करके तैयार किए जाते हैं। मोड का उपयोग करते हुए, प्रोग्रामर को WebGL द्वारा प्रदान किए गए आदिम प्रकारों में से एक को चुनना होगा। इस विकल्प के लिए संभावित मान हैं - gl.POINTS, gl.LINE_STRIP, gl.LINE_LOOP, gl.LINES, gl.TRIANGLE_STRIP, gl.TRIANGLE_FAN और gltTRIANGLES।
first- यह विकल्प सक्षम सरणियों में प्रारंभिक तत्व को निर्दिष्ट करता है। यह एक नकारात्मक मूल्य नहीं हो सकता।
count - यह विकल्प प्रदान किए जाने वाले तत्वों की संख्या को निर्दिष्ट करता है।
यदि आप एक मॉडल का उपयोग करते हैं drawArrays() विधि, फिर WebGL, आकृतियों का प्रतिपादन करते हुए, ज्यामिति का निर्माण उस क्रम में करता है जिसमें शीर्ष निर्देशांक परिभाषित होते हैं।
उदाहरण
यदि आप एक त्रिभुज का उपयोग करना चाहते हैं drawArray() विधि, फिर आपको तीन कोने पास करने होंगे और कॉल करना होगा drawArrays() विधि, जैसा कि नीचे दिखाया गया है।
var vertices = [-0.5,-0.5, -0.25,0.5, 0.0,-0.5,];
gl.drawArrays(gl.TRIANGLES, 0, 3);
यह नीचे दिखाए गए अनुसार एक त्रिकोण का उत्पादन करेगा।
मान लीजिए कि आप सन्निहित त्रिभुज बनाना चाहते हैं, तो आपको अगले तीन शीर्षकों को पास करना होगा, ताकि वे शीर्ष बफ़र में हों और 6 के रूप में प्रस्तुत किए जाने वाले तत्वों की संख्या का उल्लेख करें।
var vertices = [-0.5,-0.5, -0.25,0.5, 0.0,-0.5, 0.0,-0.5, 0.25,0.5, 0.5,-0.5,];
gl.drawArrays(gl.TRIANGLES, 0, 6);
यह नीचे दिखाए गए अनुसार एक त्रिभुज त्रिभुज का उत्पादन करेगा।
drawElements ()
drawElements()वह विधि है जिसका उपयोग मॉडल को कोने और सूचकांक का उपयोग करने के लिए किया जाता है। इसका सिंटैक्स इस प्रकार है -
void drawElements(enum mode, long count, enum type, long offset)
यह विधि निम्नलिखित चार मापदंडों को लेती है -
mode- आदिम प्रकार का उपयोग करके WebGL मॉडल तैयार किए जाते हैं। मोड का उपयोग करते हुए, प्रोग्रामर को WebGL द्वारा प्रदान किए गए आदिम प्रकारों में से एक को चुनना होगा। इस विकल्प के संभावित मानों की सूची इस प्रकार है - gl.POINTS, gl.LINE_STRIP, gl.LINE_LOOP, gl.LINES, gl.TRIANGLE_STRIP, gl.TRIANGLE_FAN, और glTRIANGLES।
count - यह विकल्प प्रदान किए जाने वाले तत्वों की संख्या को निर्दिष्ट करता है।
type - यह विकल्प उन सूचकांकों के डेटा प्रकार को निर्दिष्ट करता है जो UNSIGNED_BYTE या UNSIGNED_SHORT होना चाहिए।
offset- यह विकल्प प्रतिपादन के लिए शुरुआती बिंदु को निर्दिष्ट करता है। यह आमतौर पर पहला तत्व (0) है।
यदि आप एक मॉडल का उपयोग करते हैं drawElements()विधि, फिर इंडेक्स बफर ऑब्जेक्ट को वर्टेक्स बफर ऑब्जेक्ट के साथ भी बनाया जाना चाहिए। यदि आप इस विधि का उपयोग करते हैं, तो वर्टेक्स डेटा को एक बार संसाधित किया जाएगा और सूचकांकों में वर्णित के रूप में कई बार उपयोग किया जाएगा।
उदाहरण
यदि आप सूचकांकों का उपयोग करके एक त्रिभुज बनाना चाहते हैं, तो आपको सूचकांकों को अनुलंबों के साथ पास करना होगा और कॉल करना होगा drawElements() तरीका नीचे दिखाया गया है।
var vertices = [ -0.5,-0.5,0.0, -0.25,0.5,0.0, 0.0,-0.5,0.0 ];
var indices = [0,1,2];
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
यदि आप संक्रामक त्रिकोण का उपयोग करना चाहते हैं drawElements() विधि, बस दूसरे कोने जोड़ें और शेष कोने के लिए सूचकांकों का उल्लेख करें।
var vertices = [
-0.5,-0.5,0.0,
-0.25,0.5,0.0,
0.0,-0.5,0.0,
0.25,0.5,0.0,
0.5,-0.5,0.0
];
var indices = [0,1,2,2,3,4];
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
आवश्यक संचालन
एक आदिम ड्राइंग करने से पहले, आपको कुछ ऑपरेशन करने की आवश्यकता है, जिन्हें नीचे समझाया गया है।
कैनवास साफ़ करें
सबसे पहले, आपको कैनवास का उपयोग करके साफ़ करना चाहिए clearColor()तरीका। आप इस विधि के पैरामीटर के रूप में वांछित रंग के RGBA मान पास कर सकते हैं। तब WebGL कैनवास को साफ करता है और इसे निर्दिष्ट रंग से भरता है। इसलिए, आप पृष्ठभूमि रंग सेट करने के लिए इस विधि का उपयोग कर सकते हैं।
निम्नलिखित उदाहरण पर एक नज़र डालें। यहां हम ग्रे रंग के RGBA मान को पास कर रहे हैं।
gl.clearColor(0.5, 0.5, .5, 1);
डेप्थ टेस्ट सक्षम करें
का उपयोग करके गहराई परीक्षण सक्षम करें enable() विधि, जैसा कि नीचे दिखाया गया है।
gl.enable(gl.DEPTH_TEST);
रंग बफ़र बिट साफ़ करें
रंग और साथ ही साथ बफर का उपयोग करके साफ़ करें clear() विधि, जैसा कि नीचे दिखाया गया है।
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
पोर्ट देखें
व्यू पोर्ट एक आयताकार देखने योग्य क्षेत्र का प्रतिनिधित्व करता है जिसमें ड्राइंग बफर के प्रतिपादन परिणाम होते हैं। आप दृश्य पोर्ट का उपयोग करके आयाम सेट कर सकते हैंviewport()तरीका। निम्नलिखित कोड में, दृश्य पोर्ट आयाम कैनवास आयामों पर सेट किए जाते हैं।
gl.viewport(0,0,canvas.width,canvas.height);
हमने पहले (अध्याय 5 में) एक आदिम को आकर्षित करने के लिए चरण-दर-चरण प्रक्रिया का पालन करने के बारे में चर्चा की। हमने पांच चरणों में प्रक्रिया को समझाया है। हर बार जब आप एक नया आकार बनाते हैं, तो आपको इन चरणों को दोहराने की आवश्यकता होती है। यह अध्याय बताता है कि वेबजीएल में 3 डी निर्देशांक के साथ अंक कैसे बनाएं। आगे बढ़ने से पहले, आइए हम पाँच चरणों पर ध्यान दें।
आवश्यक कदम
अंक बनाने के लिए WebGL एप्लिकेशन बनाने के लिए निम्न चरणों की आवश्यकता होती है।
Step 1 − Prepare the Canvas and Get the WebGL Rendering Context
इस चरण में, हम विधि का उपयोग करके WebGL प्रतिपादन संदर्भ वस्तु प्राप्त करते हैं getContext().
Step 2 − Define the Geometry and Store it in the Buffer Objects
चूंकि हम तीन बिंदुओं को आकर्षित कर रहे हैं, हम तीन दिशाओं को 3 डी निर्देशांक के साथ परिभाषित करते हैं और उन्हें बफ़र्स में संग्रहीत करते हैं।
var vertices = [
-0.5,0.5,0.0,
0.0,0.5,0.0,
-0.25,0.25,0.0,
];
Step 3 − Create and Compile the Shader Programs
इस चरण में, आपको वर्टेक्स शेडर और टुकड़ा शेडर प्रोग्राम लिखने की जरूरत है, उन्हें संकलित करें, और इन दो कार्यक्रमों को जोड़कर एक संयुक्त कार्यक्रम बनाएं।
Vertex Shader - दिए गए उदाहरण के शीर्ष में, हम 3D निर्देशांक को संग्रहीत करने के लिए एक वेक्टर विशेषता को परिभाषित करते हैं, और इसे असाइन करते हैं gl_position चर।
gl_pointsizeवह चर है जिसका उपयोग बिंदु को आकार देने के लिए किया जाता है। हम 10 के रूप में बिंदु आकार प्रदान करते हैं।
var vertCode = 'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'gl_PointSize = 10.0;'+
'}';
Fragment Shader - टुकड़ा शैडर में, हम केवल टुकड़े को टुकड़े का रंग प्रदान करते हैं gl_FragColor परिवर्तनशील
var fragCode = 'void main(void) {' +' gl_FragColor = vec4(1, 0.5, 0.0, 1);' +'}';
Step 4 − Associate the Shader Programs to Buffer Objects
इस चरण में, हम बफर ऑब्जेक्ट को shader प्रोग्राम के साथ जोड़ते हैं।
Step 5 − Drawing the Required Object
हम विधि का उपयोग करते हैं drawArrays()अंक निकालना। चूँकि हम जिन बिंदुओं को खींचना चाहते हैं, वे तीन हैं, गिनती मान 3 है।
gl.drawArrays(gl.POINTS, 0, 3)
उदाहरण - WebGL का उपयोग करके तीन बिंदुओं को ड्रा करें
यहां तीन बिंदुओं को खींचने के लिए पूरा वेबजीएल कार्यक्रम है -
<!doctype html>
<html>
<body>
<canvas width = "570" height = "570" id = "my_Canvas"></canvas>
<script>
/*================Creating a canvas=================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*==========Defining and storing the geometry=======*/
var vertices = [
-0.5,0.5,0.0,
0.0,0.5,0.0,
-0.25,0.25,0.0,
];
// Create an empty buffer object to store the vertex buffer
var vertex_buffer = gl.createBuffer();
//Bind appropriate array buffer to it
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Pass the vertex data to the buffer
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Unbind the buffer
gl.bindBuffer(gl.ARRAY_BUFFER, null);
/*=========================Shaders========================*/
// vertex shader source code
var vertCode =
'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'gl_PointSize = 10.0;'+
'}';
// Create a vertex shader object
var vertShader = gl.createShader(gl.VERTEX_SHADER);
// Attach vertex shader source code
gl.shaderSource(vertShader, vertCode);
// Compile the vertex shader
gl.compileShader(vertShader);
// fragment shader source code
var fragCode =
'void main(void) {' +
' gl_FragColor = vec4(0.0, 0.0, 0.0, 0.1);' +
'}';
// Create fragment shader object
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
// Attach fragment shader source code
gl.shaderSource(fragShader, fragCode);
// Compile the fragmentt shader
gl.compileShader(fragShader);
// Create a shader program object to store
// the combined shader program
var shaderProgram = gl.createProgram();
// Attach a vertex shader
gl.attachShader(shaderProgram, vertShader);
// Attach a fragment shader
gl.attachShader(shaderProgram, fragShader);
// Link both programs
gl.linkProgram(shaderProgram);
// Use the combined shader program object
gl.useProgram(shaderProgram);
/*======== Associating shaders to buffer objects ========*/
// Bind vertex buffer object
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Get the attribute location
var coord = gl.getAttribLocation(shaderProgram, "coordinates");
// Point an attribute to the currently bound VBO
gl.vertexAttribPointer(coord, 3, gl.FLOAT, false, 0, 0);
// Enable the attribute
gl.enableVertexAttribArray(coord);
/*============= Drawing the primitive ===============*/
// Clear the canvas
gl.clearColor(0.5, 0.5, 0.5, 0.9);
// Enable the depth test
gl.enable(gl.DEPTH_TEST);
// Clear the color buffer bit
gl.clear(gl.COLOR_BUFFER_BIT);
// Set the view port
gl.viewport(0,0,canvas.width,canvas.height);
// Draw the triangle
gl.drawArrays(gl.POINTS, 0, 3);
</script>
</body>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
पिछले अध्याय (अध्याय 11) में, हमने चर्चा की कि वेबजीएल का उपयोग करके तीन बिंदुओं को कैसे आकर्षित किया जाए। अध्याय 5 में, हमने एक त्रिकोण को कैसे आकर्षित किया जाए, यह प्रदर्शित करने के लिए नमूना आवेदन लिया। दोनों उदाहरणों में, हमने केवल कोने का उपयोग करके प्राइमिटिव्स को खींचा है।
अधिक जटिल आकृतियों / जालों को खींचने के लिए, हम रेखागणितों के साथ ज्यामिति के सूचकांकों को भी पास करते हैं। इस अध्याय में, हम देखेंगे कि सूचकांकों का उपयोग करके एक त्रिभुज कैसे बनाया जाए।
एक त्रिभुज ड्रा करने के लिए आवश्यक कदम
त्रिकोण बनाने के लिए WebGL एप्लिकेशन बनाने के लिए निम्न चरणों की आवश्यकता होती है।
Step 1 − Prepare the Canvas and Get WebGL Rendering Context
इस चरण में, हम WebGL रेंडरिंग संदर्भ ऑब्जेक्ट का उपयोग करके प्राप्त करते हैं getContext()।
Step 2 − Define the Geometry and Store it in Buffer Objects
चूँकि हम सूचकांकों का उपयोग करते हुए एक त्रिभुज खींच रहे हैं, इसलिए हमें त्रिभुज के तीन कोने, सूचकांकों को पास करना होगा और उन्हें बफ़र्स में संग्रहीत करना होगा।
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
];
indices = [0,1,2];
Step 3 − Create and Compile the Shader Programs
इस चरण में, आपको वर्टेक्स शेडर और टुकड़ा शेडर प्रोग्राम लिखने की जरूरत है, उन्हें संकलित करें, और इन दो कार्यक्रमों को जोड़कर एक संयुक्त कार्यक्रम बनाएं।
Vertex Shader - कार्यक्रम के शीर्ष में shader, हम 3D निर्देशांक को संग्रहीत करने और इसे असाइन करने के लिए वेक्टर विशेषता को परिभाषित करते हैं gl_position।
var vertCode =
'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'}';
Fragment Shader - टुकड़ा शैडर में, हम केवल टुकड़े को टुकड़े का रंग प्रदान करते हैं gl_FragColor चर।
var fragCode = 'void main(void) {' +
' gl_FragColor = vec4(1, 0.5, 0.0, 1);' +
'}';
Step 4 − Associate the Shader Programs to the Buffer Objects
इस चरण में, हम बफर ऑब्जेक्ट और शेडर प्रोग्राम को जोड़ते हैं।
Step 5 − Drawing the Required Object
चूँकि हम सूचकांक का उपयोग करते हुए एक त्रिकोण बना रहे हैं, हम उपयोग करेंगे drawElements()
। इस पद्धति के लिए, हमें सूचकांकों की संख्या को पास करना होगा। का मूल्यindices.length सूचकांकों की संख्या को दर्शाता है।
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
उदाहरण - त्रिभुज खींचना
निम्नलिखित प्रोग्राम कोड दिखाता है कि सूचकांक का उपयोग करके WebGL में एक त्रिकोण कैसे बनाया जाए -
<!doctype html>
<html>
<body>
<canvas width = "570" height = "570" id = "my_Canvas"></canvas>
<script>
/*============== Creating a canvas ====================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*======== Defining and storing the geometry ===========*/
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
];
indices = [0,1,2];
// Create an empty buffer object to store vertex buffer
var vertex_buffer = gl.createBuffer();
// Bind appropriate array buffer to it
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Pass the vertex data to the buffer
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Unbind the buffer
gl.bindBuffer(gl.ARRAY_BUFFER, null);
// Create an empty buffer object to store Index buffer
var Index_Buffer = gl.createBuffer();
// Bind appropriate array buffer to it
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);
// Pass the vertex data to the buffer
gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
// Unbind the buffer
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);
/*================ Shaders ====================*/
// Vertex shader source code
var vertCode =
'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'}';
// Create a vertex shader object
var vertShader = gl.createShader(gl.VERTEX_SHADER);
// Attach vertex shader source code
gl.shaderSource(vertShader, vertCode);
// Compile the vertex shader
gl.compileShader(vertShader);
//fragment shader source code
var fragCode =
'void main(void) {' +
' gl_FragColor = vec4(0.0, 0.0, 0.0, 0.1);' +
'}';
// Create fragment shader object
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
// Attach fragment shader source code
gl.shaderSource(fragShader, fragCode);
// Compile the fragmentt shader
gl.compileShader(fragShader);
// Create a shader program object to store
// the combined shader program
var shaderProgram = gl.createProgram();
// Attach a vertex shader
gl.attachShader(shaderProgram, vertShader);
// Attach a fragment shader
gl.attachShader(shaderProgram, fragShader);
// Link both the programs
gl.linkProgram(shaderProgram);
// Use the combined shader program object
gl.useProgram(shaderProgram);
/*======= Associating shaders to buffer objects =======*/
// Bind vertex buffer object
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Bind index buffer object
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);
// Get the attribute location
var coord = gl.getAttribLocation(shaderProgram, "coordinates");
// Point an attribute to the currently bound VBO
gl.vertexAttribPointer(coord, 3, gl.FLOAT, false, 0, 0);
// Enable the attribute
gl.enableVertexAttribArray(coord);
/*=========Drawing the triangle===========*/
// Clear the canvas
gl.clearColor(0.5, 0.5, 0.5, 0.9);
// Enable the depth test
gl.enable(gl.DEPTH_TEST);
// Clear the color buffer bit
gl.clear(gl.COLOR_BUFFER_BIT);
// Set the view port
gl.viewport(0,0,canvas.width,canvas.height);
// Draw the triangle
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
पिछले अध्याय (अध्याय 12) में, हमने चर्चा की कि वेबजीएल का उपयोग करके एक त्रिकोण कैसे बनाया जाए। त्रिकोण के अतिरिक्त, WebGL विभिन्न अन्य ड्राइंग मोड का समर्थन करता है। यह अध्याय WebGL द्वारा समर्थित ड्राइंग मोड्स की व्याख्या करता है।
मोड पैरामीटर
आइए एक नज़र डालते हैं, सिंटैक्स के तरीकों पर - drawElements() और बनाओ Arrays()।
void drawElements(enum mode, long count, enum type, long offset);
void drawArrays(enum mode, int first, long count);
यदि आप स्पष्ट रूप से निरीक्षण करते हैं, तो दोनों विधियां एक पैरामीटर को स्वीकार करती हैं mode। इस पैरामीटर का उपयोग करके, प्रोग्रामर WebGL में ड्राइंग मोड का चयन कर सकते हैं।
वेबजीएल द्वारा प्रदान किए गए ड्राइंग मोड निम्न तालिका में सूचीबद्ध हैं।
अनु क्रमांक। | मोड और विवरण |
---|---|
1 | gl.POINTS अंकों की एक श्रृंखला बनाने के लिए। |
2 | gl.LINES असंबद्ध लाइन सेगमेंट (व्यक्तिगत लाइनें) की एक श्रृंखला खींचने के लिए। |
3 | gl.LINE_STRIP कनेक्टेड लाइन सेगमेंट की एक श्रृंखला खींचने के लिए। |
4 | gl.LINE_LOOP कनेक्टेड लाइन सेगमेंट की एक श्रृंखला खींचने के लिए। यह लूप बनाने के लिए पहले और अंतिम कोने से भी जुड़ता है। |
5 | gl.TRIANGLES अलग त्रिकोण की एक श्रृंखला बनाने के लिए। |
6 | gl.TRIANGLE_STRIP स्ट्रिप फैशन में जुड़े त्रिकोणों की एक श्रृंखला बनाने के लिए। |
7 | gl.TRIANGLE_FAN जुड़े हुए त्रिकोणों की एक श्रृंखला को आकर्षित करने के लिए पंखे की तरह फैशन में पहला शीर्ष साझा करना। |
उदाहरण - तीन समानांतर रेखाएँ खींचना
निम्नलिखित उदाहरण दिखाता है कि कैसे तीन समानांतर रेखाओं का उपयोग किया जाए gl.LINES।
<!doctype html>
<html>
<body>
<canvas width = "300" height = "300" id = "my_Canvas"></canvas>
<script>
/*======= Creating a canvas =========*/
var canvas = document.getElementById('my_Canvas');
var gl = canvas.getContext('experimental-webgl');
/*======= Defining and storing the geometry ======*/
var vertices = [
-0.7,-0.1,0,
-0.3,0.6,0,
-0.3,-0.3,0,
0.2,0.6,0,
0.3,-0.3,0,
0.7,0.6,0
]
// Create an empty buffer object
var vertex_buffer = gl.createBuffer();
// Bind appropriate array buffer to it
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Pass the vertex data to the buffer
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Unbind the buffer
gl.bindBuffer(gl.ARRAY_BUFFER, null);
/*=================== Shaders ====================*/
// Vertex shader source code
var vertCode =
'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'}';
// Create a vertex shader object
var vertShader = gl.createShader(gl.VERTEX_SHADER);
// Attach vertex shader source code
gl.shaderSource(vertShader, vertCode);
// Compile the vertex shader
gl.compileShader(vertShader);
// Fragment shader source code
var fragCode =
'void main(void) {' +
'gl_FragColor = vec4(0.0, 0.0, 0.0, 0.1);' +
'}';
// Create fragment shader object
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
// Attach fragment shader source code
gl.shaderSource(fragShader, fragCode);
// Compile the fragmentt shader
gl.compileShader(fragShader);
// Create a shader program object to store
// the combined shader program
var shaderProgram = gl.createProgram();
// Attach a vertex shader
gl.attachShader(shaderProgram, vertShader);
// Attach a fragment shader
gl.attachShader(shaderProgram, fragShader);
// Link both the programs
gl.linkProgram(shaderProgram);
// Use the combined shader program object
gl.useProgram(shaderProgram);
/*======= Associating shaders to buffer objects ======*/
// Bind vertex buffer object
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Get the attribute location
var coord = gl.getAttribLocation(shaderProgram, "coordinates");
// Point an attribute to the currently bound VBO
gl.vertexAttribPointer(coord, 3, gl.FLOAT, false, 0, 0);
// Enable the attribute
gl.enableVertexAttribArray(coord);
/*============ Drawing the triangle =============*/
// Clear the canvas
gl.clearColor(0.5, 0.5, 0.5, 0.9);
// Enable the depth test
gl.enable(gl.DEPTH_TEST);
// Clear the color and depth buffer
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
// Set the view port
gl.viewport(0,0,canvas.width,canvas.height);
// Draw the triangle
gl.drawArrays(gl.LINES, 0, 6);
// POINTS, LINE_STRIP, LINE_LOOP, LINES,
// TRIANGLE_STRIP,TRIANGLE_FAN, TRIANGLES
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
रेखाचित्र बनाना
उपरोक्त कार्यक्रम में, यदि आप के मोड को प्रतिस्थापित करते हैं drawArrays() निम्नलिखित ड्राइंग मोड में से एक के साथ, यह हर बार अलग-अलग आउटपुट का उत्पादन करेगा।
रेखाचित्र बनाना | आउटपुट |
---|---|
LINE_STRIP |
|
LINE_LOOP |
|
TRIANGLE_STRIP |
|
TRIANGLE_FAN |
|
त्रिभुज |
|
पिछले अध्याय में, हमने WebGL द्वारा प्रदान किए गए विभिन्न ड्राइंग मोड्स पर चर्चा की। हम इनमें से किसी एक मोड का उपयोग करके प्रिमिटिव निकालने के लिए सूचकांकों का भी उपयोग कर सकते हैं। WebGL में मॉडल तैयार करने के लिए, हमें इनमें से एक आदिम चुनना होगा और आवश्यक जाल (यानी, एक या एक से अधिक प्राथमिकताओं का उपयोग करके बनाया गया मॉडल) आकर्षित करना होगा।
इस अध्याय में, हम उदाहरण के लिए वेबलॉग का उपयोग करके एक चतुर्भुज को आकर्षित करने का एक उदाहरण लेंगे।
एक चतुर्भुज आकर्षित करने के लिए कदम
एक चतुर्भुज बनाने के लिए WebGL एप्लिकेशन बनाने के लिए निम्न चरणों की आवश्यकता होती है।
Step 1 − Prepare the Canvas and Get the WebGL Rendering Context
इस चरण में, हम WebGL रेंडरिंग संदर्भ ऑब्जेक्ट का उपयोग करके प्राप्त करते हैं getContext()।
Step 2 − Define the Geometry and Store it in the Buffer Objects
दो त्रिकोणों का उपयोग करके एक वर्ग तैयार किया जा सकता है। इस उदाहरण में, हम दो त्रिकोण (एक सामान्य किनारे के साथ) और सूचक के लिए कोने प्रदान करते हैं।
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
0.5,0.5,0.0
];
indices = [3,2,1,3,1,0];
Step 3 − Create and Compile the Shader Programs
इस चरण में, आपको वर्टेक्स शेडर और टुकड़ा शेडर प्रोग्राम लिखने की जरूरत है, उन्हें संकलित करें, और इन दो कार्यक्रमों को जोड़कर एक संयुक्त प्रोग्राम बनाएं।
Vertex Shader - कार्यक्रम के शीर्ष में shader, हम 3D निर्देशांक को संग्रहीत करने और इसे असाइन करने के लिए वेक्टर विशेषता को परिभाषित करते हैं gl_position।
var vertCode =
'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'}';
Fragment Shader - टुकड़ा शैडर में, हम केवल टुकड़े को टुकड़े का रंग प्रदान करते हैं gl_FragColor चर।
var fragCode = 'void main(void) {' +' gl_FragColor = vec4(0.5, 0.3, 0.0, 7.5);' +'}';
Step 4 − Associate the Shader Programs to Buffer Objects
इस चरण में, हम बफर ऑब्जेक्ट को shader प्रोग्राम के साथ जोड़ते हैं।
Step 5 − Drawing the Required Object
चूँकि हम क्वाड बनाने के लिए दो त्रिकोण बना रहे हैं, सूचकांकों का उपयोग करते हुए, हम विधि का उपयोग करेंगे drawElements()। इस पद्धति के लिए, हमें सूचकांकों की संख्या को पास करना होगा। का मूल्यindices.length सूचकांकों की संख्या देता है।
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
उदाहरण - एक चतुर्भुज ड्रा करें
निम्न प्रोग्राम दिखाता है कि एक चतुर्भुज को आकर्षित करने के लिए एक WebGL एप्लिकेशन कैसे बनाया जाए।
<!doctype html>
<html>
<body>
<canvas width = "570" height = "570" id = "my_Canvas"></canvas>
<script>
/*============ Creating a canvas =================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*========== Defining and storing the geometry =========*/
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
0.5,0.5,0.0
];
indices = [3,2,1,3,1,0];
// Create an empty buffer object to store vertex buffer
var vertex_buffer = gl.createBuffer();
// Bind appropriate array buffer to it
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Pass the vertex data to the buffer
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Unbind the buffer
gl.bindBuffer(gl.ARRAY_BUFFER, null);
// Create an empty buffer object to store Index buffer
var Index_Buffer = gl.createBuffer();
// Bind appropriate array buffer to it
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);
// Pass the vertex data to the buffer
gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
// Unbind the buffer
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);
/*====================== Shaders =======================*/
// Vertex shader source code
var vertCode =
'attribute vec3 coordinates;' +
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'}';
// Create a vertex shader object
var vertShader = gl.createShader(gl.VERTEX_SHADER);
// Attach vertex shader source code
gl.shaderSource(vertShader, vertCode);
// Compile the vertex shader
gl.compileShader(vertShader);
// Fragment shader source code
var fragCode =
'void main(void) {' +
' gl_FragColor = vec4(0.0, 0.0, 0.0, 0.1);' +
'}';
// Create fragment shader object
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
// Attach fragment shader source code
gl.shaderSource(fragShader, fragCode);
// Compile the fragmentt shader
gl.compileShader(fragShader);
// Create a shader program object to
// store the combined shader program
var shaderProgram = gl.createProgram();
// Attach a vertex shader
gl.attachShader(shaderProgram, vertShader);
// Attach a fragment shader
gl.attachShader(shaderProgram, fragShader);
// Link both the programs
gl.linkProgram(shaderProgram);
// Use the combined shader program object
gl.useProgram(shaderProgram);
/* ======= Associating shaders to buffer objects =======*/
// Bind vertex buffer object
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Bind index buffer object
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);
// Get the attribute location
var coord = gl.getAttribLocation(shaderProgram, "coordinates");
// Point an attribute to the currently bound VBO
gl.vertexAttribPointer(coord, 3, gl.FLOAT, false, 0, 0);
// Enable the attribute
gl.enableVertexAttribArray(coord);
/*============= Drawing the Quad ================*/
// Clear the canvas
gl.clearColor(0.5, 0.5, 0.5, 0.9);
// Enable the depth test
gl.enable(gl.DEPTH_TEST);
// Clear the color buffer bit
gl.clear(gl.COLOR_BUFFER_BIT);
// Set the view port
gl.viewport(0,0,canvas.width,canvas.height);
// Draw the triangle
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
हमारे पिछले सभी उदाहरणों में, हमने इच्छित रंग मान को निर्दिष्ट करके ऑब्जेक्ट पर रंग लागू किया gl_FragColorचर। इसके अलावा, हम प्रत्येक शीर्ष के लिए रंगों को परिभाषित कर सकते हैं - जैसे कि वर्टेक्स निर्देशांक और सूचकांक। यह अध्याय वेबगेल का उपयोग करके चतुर्भुज पर रंगों को कैसे प्रदर्शित किया जाए, यह दिखाने के लिए एक उदाहरण लेता है।
रंग लगाना
रंगों को लागू करने के लिए, आपको आरजीबी मूल्यों का उपयोग करके प्रत्येक शीर्ष के लिए रंगों को परिभाषित करना होगा, जावास्क्रिप्ट सरणी में। आप ऑब्जेक्ट के लिए एक अद्वितीय रंग होने के लिए सभी वर्टिस को समान मान असाइन कर सकते हैं। रंगों को परिभाषित करने के बाद, आपको एक रंगीन बफर बनाना होगा और उसमें इन मूल्यों को संग्रहित करना होगा, और इसे वर्टेक्स शेडर विशेषताओं से जोड़ना होगा।
निर्देशांक विशेषता के साथ शीर्ष की छाया में, (जो कोने की स्थिति रखता है), हम एक परिभाषित करते हैं attribute और एक varying रंगों को संभालने के लिए।
color विशेषता रंग मूल्य प्रति शीर्ष पर रखती है, और varyingवह चर है, जो टुकड़े टुकड़े करने वाले के इनपुट के रूप में पारित किया जाता है। इसलिए, हमें असाइन करना होगाcolor के लिए मूल्य varying।
टुकड़े टुकड़े में, varying वह रंग मान रखता है जिसे सौंपा गया है gl_FragColor, जो वस्तु का अंतिम रंग रखता है।
रंग लागू करने के लिए कदम
एक क्वाड को आकर्षित करने और उस पर रंग लगाने के लिए वेबजीएल एप्लिकेशन बनाने के लिए निम्न चरणों की आवश्यकता होती है।
Step 1 − Prepare the Canvas and Get the WebGL Rendering Context
इस चरण में, हम WebGL रेंडरिंग संदर्भ ऑब्जेक्ट का उपयोग करके प्राप्त करते हैं getContext()।
Step 2 − Define the Geometry and Store it in the Buffer Objects
दो त्रिकोणों का उपयोग करके एक वर्ग तैयार किया जा सकता है। इसलिए, इस उदाहरण में, हम दो त्रिकोण (एक सामान्य किनारे के साथ) और सूचक के लिए कोने प्रदान करते हैं। चूंकि हम इस पर रंग लागू करना चाहते हैं, रंग मान रखने वाले एक चर को भी परिभाषित किया गया है और प्रत्येक के लिए रंग मान (लाल, नीला, हरा और गुलाबी) इसे सौंपा गया है।
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
0.5,0.5,0.0
];
var colors = [ 0,0,1, 1,0,0, 0,1,0, 1,0,1,];
indices = [3,2,1,3,1,0];
Step 3 − Create and Compile the Shader Programs
इस चरण में, आपको वर्टेक्स शेडर और टुकड़ा शेडर प्रोग्राम लिखने की जरूरत है, उन्हें संकलित करें, और इन दो कार्यक्रमों को जोड़कर एक संयुक्त प्रोग्राम बनाएं।
Vertex Shader- कार्यक्रम के शीर्ष शायर में, हम 3 डी निर्देशांक (स्थिति), और प्रत्येक शीर्ष के रंग को संग्रहीत करने के लिए वेक्टर विशेषताओं को परिभाषित करते हैं। एvaringचर को शीर्ष के शेअर से टुकड़े के टुकड़े तक रंग मानों को पारित करने के लिए घोषित किया जाता है। और अंत में, रंग विशेषता में संग्रहीत मूल्य को सौंपा गया हैvarying।
var vertCode = 'attribute vec3 coordinates;'+
'attribute vec3 color;'+
'varying vec3 vColor;'+
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'vColor = color;'+
'}';
Fragment Shader - टुकड़े टुकड़े में, हम असाइन करते हैं varying को gl_FragColor चर।
var fragCode = 'precision mediump float;'+
'varying vec3 vColor;'+
'void main(void) {'+
'gl_FragColor = vec4(vColor, 1.);'+
'}';
Step 4 − Associate the Shader Programs with the Buffer Objects
इस चरण में, हम बफर ऑब्जेक्ट और शेडर प्रोग्राम को जोड़ते हैं।
Step 5 − Drawing the Required Object
चूँकि हम दो त्रिभुज बना रहे हैं जो कि एक क्वाड बनाएंगे, जो सूचकांकों का उपयोग करते हुए, हम विधि का उपयोग करेंगे drawElements()। इस पद्धति के लिए, हमें सूचकांकों की संख्या को पास करना होगा। का मूल्यindices.length सूचकांकों की संख्या को इंगित करता है।
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
उदाहरण - रंग लगाना
निम्न प्रोग्राम दर्शाता है कि वेबजीएल एप्लिकेशन का उपयोग करके एक क्वाड कैसे खींचना है और उस पर रंग लागू करना है।
<!doctype html>
<html>
<body>
<canvas width = "300" height = "300" id = "my_Canvas"></canvas>
<script>
/*============= Creating a canvas ==================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*========== Defining and storing the geometry ==========*/
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
0.5,0.5,0.0
];
var colors = [0,0,1, 1,0,0, 0,1,0, 1,0,1,];
indices = [3,2,1,3,1,0];
// Create an empty buffer object and store vertex data
var vertex_buffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
gl.bindBuffer(gl.ARRAY_BUFFER, null);
// Create an empty buffer object and store Index data
var Index_Buffer = gl.createBuffer();
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);
gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);
// Create an empty buffer object and store color data
var color_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(colors), gl.STATIC_DRAW);
/*======================= Shaders =======================*/
// vertex shader source code
var vertCode = 'attribute vec3 coordinates;'+
'attribute vec3 color;'+
'varying vec3 vColor;'+
'void main(void) {' +
' gl_Position = vec4(coordinates, 1.0);' +
'vColor = color;'+
'}';
// Create a vertex shader object
var vertShader = gl.createShader(gl.VERTEX_SHADER);
// Attach vertex shader source code
gl.shaderSource(vertShader, vertCode);
// Compile the vertex shader
gl.compileShader(vertShader);
// fragment shader source code
var fragCode = 'precision mediump float;'+
'varying vec3 vColor;'+
'void main(void) {'+
'gl_FragColor = vec4(vColor, 1.);'+
'}';
// Create fragment shader object
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
// Attach fragment shader source code
gl.shaderSource(fragShader, fragCode);
// Compile the fragmentt shader
gl.compileShader(fragShader);
// Create a shader program object to
// store the combined shader program
var shaderProgram = gl.createProgram();
// Attach a vertex shader
gl.attachShader(shaderProgram, vertShader);
// Attach a fragment shader
gl.attachShader(shaderProgram, fragShader);
// Link both the programs
gl.linkProgram(shaderProgram);
// Use the combined shader program object
gl.useProgram(shaderProgram);
/* ======== Associating shaders to buffer objects =======*/
// Bind vertex buffer object
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
// Bind index buffer object
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);
// Get the attribute location
var coord = gl.getAttribLocation(shaderProgram, "coordinates");
// point an attribute to the currently bound VBO
gl.vertexAttribPointer(coord, 3, gl.FLOAT, false, 0, 0);
// Enable the attribute
gl.enableVertexAttribArray(coord);
// bind the color buffer
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
// get the attribute location
var color = gl.getAttribLocation(shaderProgram, "color");
// point attribute to the volor buffer object
gl.vertexAttribPointer(color, 3, gl.FLOAT, false,0,0) ;
// enable the color attribute
gl.enableVertexAttribArray(color);
/*============Drawing the Quad====================*/
// Clear the canvas
gl.clearColor(0.5, 0.5, 0.5, 0.9);
// Enable the depth test
gl.enable(gl.DEPTH_TEST);
// Clear the color buffer bit
gl.clear(gl.COLOR_BUFFER_BIT);
// Set the view port
gl.viewport(0,0,canvas.width,canvas.height);
//Draw the triangle
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
अब तक, हमने चर्चा की कि विभिन्न आकारों को कैसे आकर्षित किया जाए और उनमें वेबगेल का उपयोग करके रंगों को लागू किया जाए। यहाँ, इस अध्याय में, हम एक उदाहरण देंगे कि कैसे एक त्रिकोण का अनुवाद किया जाए।
अनुवाद
अनुवाद में से एक है affine transformationsWebGL द्वारा प्रदान किया गया। अनुवाद का उपयोग करते हुए, हम xyz विमान पर एक त्रिकोण (किसी भी वस्तु) को स्थानांतरित कर सकते हैं। मान लें कि हमारे पास एक त्रिभुज है [a, b, c] और हम त्रिभुज को एक स्थिति में ले जाना चाहते हैं जो कि सकारात्मक X- अक्ष की ओर 5 इकाई है और धनात्मक Y- अक्ष की ओर 3 इकाई है। तब नए कोने [5 +, बी + 3, सी + 0] होंगे। इसका मतलब है, त्रिभुज का अनुवाद करने के लिए, हमें प्रत्येक दूरस्थ स्थान पर अनुवाद की दूरी, कहना, tx, ty, tz जोड़ना होगा।
चूंकि यह ए per-vertex operation, हम इसे शीर्ष shader कार्यक्रम में ले जा सकते हैं।
विशेषता के साथ, शीर्ष की छाया में, coordinates(जो शीर्ष पदों को पकड़ते हैं), हम एक समान चर को परिभाषित करते हैं जो अनुवाद की दूरी (x, y, z) रखता है। बाद में, हम इस समरूप चर को निर्देशांक चर में जोड़ते हैं और परिणाम को असाइन करते हैंgl_Position चर।
Note - चूंकि प्रत्येक शीर्ष पर शीर्ष shader चलाया जाएगा, त्रिकोण के सभी कोने का अनुवाद किया जाएगा।
एक त्रिभुज का अनुवाद करने के लिए कदम
त्रिकोण बनाने के लिए वेबजीएल एप्लिकेशन बनाने के लिए निम्न चरणों की आवश्यकता होती है और फिर इसे एक नए स्थान पर अनुवाद करना होता है।
Step 1 − Prepare the Canvas and Get the WebGL Rendering Context
इस चरण में, हम WebGL रेंडरिंग संदर्भ ऑब्जेक्ट का उपयोग करके प्राप्त करते हैं getContext()।
Step 2 − Define the Geometry and Store it in the Buffer Objects
चूँकि हम एक त्रिभुज खींच रहे हैं, हमें त्रिभुज के तीन कोने पास करने होंगे, और उन्हें बफ़र्स में संग्रहित करना होगा।
var vertices = [ -0.5,0.5,0.0, -0.5,-0.5,0.0, 0.5,-0.5,0.0, ];
Step 3 − Create and Compile the Shader Programs
इस चरण में, आपको वर्टेक्स शेडर और टुकड़ा शेडर प्रोग्राम लिखने की जरूरत है, उन्हें संकलित करें, और इन दो कार्यक्रमों को जोड़कर एक संयुक्त प्रोग्राम बनाएं।
Vertex Shader- कार्यक्रम के शीर्ष में shader, हम 3D निर्देशांक को संग्रहीत करने के लिए एक वेक्टर विशेषता को परिभाषित करते हैं। इसके साथ, हम अनुवाद दूरी को संग्रहीत करने के लिए एक समान चर को परिभाषित करते हैं, और अंत में, हम इन दो मूल्यों को जोड़ते हैं और इसे असाइन करते हैंgl_position जो कोने की अंतिम स्थिति रखता है।
var vertCode =
'attribute vec4 coordinates;' +
'uniform vec4 translation;'+
'void main(void) {' +
' gl_Position = coordinates + translation;' +
'}';
Fragment Shader - टुकड़ा shader में, हम बस gl_FragColor चर को टुकड़ा रंग असाइन करते हैं।
var fragCode = 'void main(void) {' +' gl_FragColor = vec4(1, 0.5, 0.0, 1);' +'}';
Step 4 − Associate the Shader Programs to the Buffer Objects
इस चरण में, हम बफर ऑब्जेक्ट को shader प्रोग्राम के साथ जोड़ते हैं।
Step 5 − Drawing the Required Object
चूँकि हम सूचकांकों का उपयोग करते हुए त्रिभुज खींच रहे हैं, इसलिए हम विधि का उपयोग करेंगे drawArrays()। इस पद्धति के लिए, हमें विचार किए जाने वाले शीर्षकों / तत्वों की संख्या को पास करना होगा। चूंकि हम एक त्रिकोण खींच रहे हैं, हम एक पैरामीटर के रूप में 3 पास करेंगे।
gl.drawArrays(gl.TRIANGLES, 0, 3);
उदाहरण - अनुवाद एक त्रिभुज
निम्न उदाहरण दिखाता है कि xyz विमान पर एक त्रिकोण का अनुवाद कैसे करें।
<!doctype html>
<html>
<body>
<canvas width = "300" height = "300" id = "my_Canvas"></canvas>
<script>
/*=================Creating a canvas=========================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*===========Defining and storing the geometry==============*/
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
];
//Create an empty buffer object and store vertex data
var vertex_buffer = gl.createBuffer();
//Create a new buffer
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
//bind it to the current buffer
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Pass the buffer data
gl.bindBuffer(gl.ARRAY_BUFFER, null);
/*========================Shaders============================*/
//vertex shader source code
var vertCode =
'attribute vec4 coordinates;' +
'uniform vec4 translation;'+
'void main(void) {' +
' gl_Position = coordinates + translation;' +
'}';
//Create a vertex shader program object and compile it
var vertShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertShader, vertCode);
gl.compileShader(vertShader);
//fragment shader source code
var fragCode =
'void main(void) {' +
' gl_FragColor = vec4(0.0, 0.0, 0.0, 0.1);' +
'}';
//Create a fragment shader program object and compile it
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragShader, fragCode);
gl.compileShader(fragShader);
//Create and use combiened shader program
var shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertShader);
gl.attachShader(shaderProgram, fragShader);
gl.linkProgram(shaderProgram);
gl.useProgram(shaderProgram);
/* ===========Associating shaders to buffer objects============*/
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
var coordinatesVar = gl.getAttribLocation(shaderProgram, "coordinates");
gl.vertexAttribPointer(coordinatesVar, 3, gl.FLOAT, false, 0, 0);
gl.enableVertexAttribArray(coordinatesVar);
/* ==========translation======================================*/
var Tx = 0.5, Ty = 0.5, Tz = 0.0;
var translation = gl.getUniformLocation(shaderProgram, 'translation');
gl.uniform4f(translation, Tx, Ty, Tz, 0.0);
/*=================Drawing the riangle and transforming it========================*/
gl.clearColor(0.5, 0.5, 0.5, 0.9);
gl.enable(gl.DEPTH_TEST);
gl.clear(gl.COLOR_BUFFER_BIT);
gl.viewport(0,0,canvas.width,canvas.height);
gl.drawArrays(gl.TRIANGLES, 0, 3);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
इस अध्याय में, हम यह दिखाने के लिए एक उदाहरण लेंगे कि वेबजीएल का उपयोग करके त्रिकोण के पैमाने को कैसे संशोधित किया जाए।
स्केलिंग
स्केलिंग एक वस्तु के आकार को बढ़ाने या घटाने के अलावा और कुछ नहीं है। उदाहरण के लिए, यदि किसी त्रिभुज के आकार [, a, b, c] के कोने हैं, तो त्रिभुज [2a, 2b, 2c] के साथ इसका आकार दोगुना होगा। इसलिए, एक त्रिभुज को मापने के लिए, आपको स्केलिंग कारक के साथ प्रत्येक कोने को गुणा करना होगा। आप किसी विशेष शीर्ष को भी माप सकते हैं।
एक त्रिभुज को स्केल करने के लिए, प्रोग्राम के वर्टेक्स शेडर में, हम एक समान मैट्रिक्स बनाते हैं और इस मैट्रिक्स के साथ समन्वय मूल्यों को गुणा करते हैं। बाद में, हम एक 4 × 4 विकर्ण मैट्रिक्स पास करते हैं जिसमें विकर्ण पदों (अंतिम विकर्ण स्थिति 1) में x, y, z निर्देशांक के स्केलिंग कारक होते हैं।
आवश्यक कदम
त्रिकोण को स्केल करने के लिए WebGL एप्लिकेशन बनाने के लिए निम्न चरणों की आवश्यकता होती है।
Step 1 − Prepare the Canvas and Get the WebGL Rendering Context
इस चरण में, हम WebGL रेंडरिंग संदर्भ ऑब्जेक्ट का उपयोग करके प्राप्त करते हैं getContext()।
Step 2 − Define the Geometry and Store it in the Buffer Objects
चूँकि हम एक त्रिभुज खींच रहे हैं, हमें त्रिभुज के तीन कोने पास करने होंगे, और उन्हें बफ़र्स में संग्रहित करना होगा।
var vertices = [ -0.5,0.5,0.0, -0.5,-0.5,0.0, 0.5,-0.5,0.0, ];
Step 3 − Create and Compile the Shader Programs
इस चरण में, आपको वर्टेक्स शेडर और टुकड़ा शेडर प्रोग्राम लिखने की जरूरत है, उन्हें संकलित करें, और इन दो कार्यक्रमों को जोड़कर एक संयुक्त प्रोग्राम बनाएं।
Vertex Shader- कार्यक्रम के शीर्ष में shader, हम 3D निर्देशांक को संग्रहीत करने के लिए एक वेक्टर विशेषता को परिभाषित करते हैं। इसके साथ, हम स्केलिंग कारकों को संग्रहीत करने के लिए एक समान मैट्रिक्स को परिभाषित करते हैं, और अंत में, हम इन दो मूल्यों को गुणा करते हैं और इसे असाइन करते हैंgl_position जो कोने की अंतिम स्थिति रखता है।
var vertCode =
'attribute vec4 coordinates;' +
'uniform mat4 u_xformMatrix;' +
'void main(void) {' +
' gl_Position = u_xformMatrix * coordinates;' +
'}';
Fragment Shader - टुकड़ा शैडर में, हम केवल टुकड़े को टुकड़े का रंग प्रदान करते हैं gl_FragColor चर।
var fragCode = 'void main(void) {' +' gl_FragColor = vec4(1, 0.5, 0.0, 1);' +'}';
Step 4 − Associate the Shader Programs with the Buffer Objects
इस चरण में, हम बफर ऑब्जेक्ट को shader प्रोग्राम के साथ जोड़ते हैं।
Step 5 − Drawing the Required Object
चूँकि हम सूचकांकों का उपयोग करते हुए त्रिभुज खींच रहे हैं, इसलिए हम इसका उपयोग करते हैं drawArrays()तरीका। इस पद्धति के लिए, हमें विचार किए जाने वाले शीर्षकों / तत्वों की संख्या को पास करना होगा। चूंकि हम एक त्रिकोण खींच रहे हैं, हम एक पैरामीटर के रूप में 3 पास करेंगे।
gl.drawArrays(gl.TRIANGLES, 0, 3);
उदाहरण - स्केल ए ट्रायंगल
निम्नलिखित उदाहरण से पता चलता है कि एक त्रिभुज को कैसे स्केल किया जाता है -
<!doctype html>
<html>
<body>
<canvas width = "300" height = "300" id = "my_Canvas"></canvas>
<script>
/*=================Creating a canvas=========================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*===========Defining and storing the geometry==============*/
var vertices = [
-0.5,0.5,0.0,
-0.5,-0.5,0.0,
0.5,-0.5,0.0,
];
//Create an empty buffer object and store vertex data
var vertex_buffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
gl.bindBuffer(gl.ARRAY_BUFFER, null);
/*========================Shaders============================*/
//Vertex shader source code
var vertCode =
'attribute vec4 coordinates;' +
'uniform mat4 u_xformMatrix;' +
'void main(void) {' +
' gl_Position = u_xformMatrix * coordinates;' +
'}';
//Create a vertex shader program object and compile it
var vertShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertShader, vertCode);
gl.compileShader(vertShader);
//fragment shader source code
var fragCode =
'void main(void) {' +
' gl_FragColor = vec4(0.0, 0.0, 0.0, 0.1);' +
'}';
//Create a fragment shader program object and compile it
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragShader, fragCode);
gl.compileShader(fragShader);
//Create and use combiened shader program
var shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertShader);
gl.attachShader(shaderProgram, fragShader);
gl.linkProgram(shaderProgram);
gl.useProgram(shaderProgram);
/*===================scaling==========================*/
var Sx = 1.0, Sy = 1.5, Sz = 1.0;
var xformMatrix = new Float32Array([
Sx, 0.0, 0.0, 0.0,
0.0, Sy, 0.0, 0.0,
0.0, 0.0, Sz, 0.0,
0.0, 0.0, 0.0, 1.0
]);
var u_xformMatrix = gl.getUniformLocation(shaderProgram, 'u_xformMatrix');
gl.uniformMatrix4fv(u_xformMatrix, false, xformMatrix);
/* ===========Associating shaders to buffer objects============*/
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
var coordinatesVar = gl.getAttribLocation(shaderProgram, "coordinates");
gl.vertexAttribPointer(coordinatesVar, 3, gl.FLOAT, false, 0, 0);
gl.enableVertexAttribArray(coordinatesVar);
/*=================Drawing the Quad========================*/
gl.clearColor(0.5, 0.5, 0.5, 0.9);
gl.enable(gl.DEPTH_TEST);
gl.clear(gl.COLOR_BUFFER_BIT);
gl.viewport(0,0,canvas.width,canvas.height);
gl.drawArrays(gl.TRIANGLES, 0, 3);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
इस अध्याय में, हम यह दिखाने के लिए एक उदाहरण लेंगे कि वेबलॉग का उपयोग करके त्रिकोण को कैसे घुमाया जाए।
उदाहरण - एक त्रिभुज को घुमाएं
निम्न प्रोग्राम दिखाता है कि WebGL का उपयोग करके एक त्रिकोण को कैसे घुमाया जाए।
<!doctype html>
<html>
<body>
<canvas width = "400" height = "400" id = "my_Canvas"></canvas>
<script>
/*=================Creating a canvas=========================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*===========Defining and storing the geometry==============*/
var vertices = [ -1,-1,-1, 1,-1,-1, 1, 1,-1 ];
var colors = [ 1,1,1, 1,1,1, 1,1,1 ];
var indices = [ 0,1,2 ];
//Create and store data into vertex buffer
var vertex_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
//Create and store data into color buffer
var color_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(colors), gl.STATIC_DRAW);
//Create and store data into index buffer
var index_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, index_buffer);
gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
/*==========================Shaders=========================*/
var vertCode = 'attribute vec3 position;'+
'uniform mat4 Pmatrix;'+
'uniform mat4 Vmatrix;'+
'uniform mat4 Mmatrix;'+
'attribute vec3 color;'+//the color of the point
'varying vec3 vColor;'+
'void main(void) { '+//pre-built function
'gl_Position = Pmatrix*Vmatrix*Mmatrix*vec4(position, 1.);'+
'vColor = color;'+
'}';
var fragCode = 'precision mediump float;'+
'varying vec3 vColor;'+
'void main(void) {'+
'gl_FragColor = vec4(vColor, 1.);'+
'}';
var vertShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertShader, vertCode);
gl.compileShader(vertShader);
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragShader, fragCode);
gl.compileShader(fragShader);
var shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertShader);
gl.attachShader(shaderProgram, fragShader);
gl.linkProgram(shaderProgram);
/*===========associating attributes to vertex shader ============*/
var Pmatrix = gl.getUniformLocation(shaderProgram, "Pmatrix");
var Vmatrix = gl.getUniformLocation(shaderProgram, "Vmatrix");
var Mmatrix = gl.getUniformLocation(shaderProgram, "Mmatrix");
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
var position = gl.getAttribLocation(shaderProgram, "position");
gl.vertexAttribPointer(position, 3, gl.FLOAT, false,0,0) ; //position
gl.enableVertexAttribArray(position);
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
var color = gl.getAttribLocation(shaderProgram, "color");
gl.vertexAttribPointer(color, 3, gl.FLOAT, false,0,0) ; //color
gl.enableVertexAttribArray(color);
gl.useProgram(shaderProgram);
/*========================= MATRIX ========================= */
function get_projection(angle, a, zMin, zMax) {
var ang = Math.tan((angle*.5)*Math.PI/180);//angle*.5
return [
0.5/ang, 0 , 0, 0,
0, 0.5*a/ang, 0, 0,
0, 0, -(zMax+zMin)/(zMax-zMin), -1,
0, 0, (-2*zMax*zMin)/(zMax-zMin), 0
];
}
var proj_matrix = get_projection(40, canvas.width/canvas.height, 1, 100);
var mov_matrix = [1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1];
var view_matrix = [1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1];
//translating z
view_matrix[14] = view_matrix[14]-6; //zoom
/*=======================rotation========================*/
function rotateZ(m, angle) {
var c = Math.cos(angle);
var s = Math.sin(angle);
var mv0 = m[0], mv4 = m[4], mv8 = m[8];
m[0] = c*m[0]-s*m[1];
m[4] = c*m[4]-s*m[5];
m[8] = c*m[8]-s*m[9];
m[1] = c*m[1]+s*mv0;
m[5] = c*m[5]+s*mv4;
m[9] = c*m[9]+s*mv8;
}
/*=================Drawing===========================*/
var time_old = 0;
var animate = function(time) {
var dt = time-time_old;
rotateZ(mov_matrix, dt*0.002);
time_old = time;
gl.enable(gl.DEPTH_TEST);
gl.depthFunc(gl.LEQUAL);
gl.clearColor(0.5, 0.5, 0.5, 0.9);
gl.clearDepth(1.0);
gl.viewport(0.0, 0.0, canvas.width, canvas.height);
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
gl.uniformMatrix4fv(Pmatrix, false, proj_matrix);
gl.uniformMatrix4fv(Vmatrix, false, view_matrix);
gl.uniformMatrix4fv(Mmatrix, false, mov_matrix);
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, index_buffer);
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT, 0);
window.requestAnimationFrame(animate);
}
animate(0);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
इस अध्याय में, हम उदाहरण के लिए वेबलॉग का उपयोग करके एक घूर्णन 3 डी क्यूब आकर्षित करने के लिए एक उदाहरण लेंगे।
उदाहरण - एक घूर्णन 3 डी घन खींचें
निम्नलिखित कार्यक्रम दिखाता है कि एक घूर्णन 3 डी क्यूब कैसे खींचना है -
<!doctype html>
<html>
<body>
<canvas width = "570" height = "570" id = "my_Canvas"></canvas>
<script>
/*============= Creating a canvas =================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*============ Defining and storing the geometry =========*/
var vertices = [
-1,-1,-1, 1,-1,-1, 1, 1,-1, -1, 1,-1,
-1,-1, 1, 1,-1, 1, 1, 1, 1, -1, 1, 1,
-1,-1,-1, -1, 1,-1, -1, 1, 1, -1,-1, 1,
1,-1,-1, 1, 1,-1, 1, 1, 1, 1,-1, 1,
-1,-1,-1, -1,-1, 1, 1,-1, 1, 1,-1,-1,
-1, 1,-1, -1, 1, 1, 1, 1, 1, 1, 1,-1,
];
var colors = [
5,3,7, 5,3,7, 5,3,7, 5,3,7,
1,1,3, 1,1,3, 1,1,3, 1,1,3,
0,0,1, 0,0,1, 0,0,1, 0,0,1,
1,0,0, 1,0,0, 1,0,0, 1,0,0,
1,1,0, 1,1,0, 1,1,0, 1,1,0,
0,1,0, 0,1,0, 0,1,0, 0,1,0
];
var indices = [
0,1,2, 0,2,3, 4,5,6, 4,6,7,
8,9,10, 8,10,11, 12,13,14, 12,14,15,
16,17,18, 16,18,19, 20,21,22, 20,22,23
];
// Create and store data into vertex buffer
var vertex_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Create and store data into color buffer
var color_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(colors), gl.STATIC_DRAW);
// Create and store data into index buffer
var index_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, index_buffer);
gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
/*=================== Shaders =========================*/
var vertCode = 'attribute vec3 position;'+
'uniform mat4 Pmatrix;'+
'uniform mat4 Vmatrix;'+
'uniform mat4 Mmatrix;'+
'attribute vec3 color;'+//the color of the point
'varying vec3 vColor;'+
'void main(void) { '+//pre-built function
'gl_Position = Pmatrix*Vmatrix*Mmatrix*vec4(position, 1.);'+
'vColor = color;'+
'}';
var fragCode = 'precision mediump float;'+
'varying vec3 vColor;'+
'void main(void) {'+
'gl_FragColor = vec4(vColor, 1.);'+
'}';
var vertShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertShader, vertCode);
gl.compileShader(vertShader);
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragShader, fragCode);
gl.compileShader(fragShader);
var shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertShader);
gl.attachShader(shaderProgram, fragShader);
gl.linkProgram(shaderProgram);
/* ====== Associating attributes to vertex shader =====*/
var Pmatrix = gl.getUniformLocation(shaderProgram, "Pmatrix");
var Vmatrix = gl.getUniformLocation(shaderProgram, "Vmatrix");
var Mmatrix = gl.getUniformLocation(shaderProgram, "Mmatrix");
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
var position = gl.getAttribLocation(shaderProgram, "position");
gl.vertexAttribPointer(position, 3, gl.FLOAT, false,0,0) ;
// Position
gl.enableVertexAttribArray(position);
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
var color = gl.getAttribLocation(shaderProgram, "color");
gl.vertexAttribPointer(color, 3, gl.FLOAT, false,0,0) ;
// Color
gl.enableVertexAttribArray(color);
gl.useProgram(shaderProgram);
/*==================== MATRIX =====================*/
function get_projection(angle, a, zMin, zMax) {
var ang = Math.tan((angle*.5)*Math.PI/180);//angle*.5
return [
0.5/ang, 0 , 0, 0,
0, 0.5*a/ang, 0, 0,
0, 0, -(zMax+zMin)/(zMax-zMin), -1,
0, 0, (-2*zMax*zMin)/(zMax-zMin), 0
];
}
var proj_matrix = get_projection(40, canvas.width/canvas.height, 1, 100);
var mov_matrix = [1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1];
var view_matrix = [1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1];
// translating z
view_matrix[14] = view_matrix[14]-6;//zoom
/*==================== Rotation ====================*/
function rotateZ(m, angle) {
var c = Math.cos(angle);
var s = Math.sin(angle);
var mv0 = m[0], mv4 = m[4], mv8 = m[8];
m[0] = c*m[0]-s*m[1];
m[4] = c*m[4]-s*m[5];
m[8] = c*m[8]-s*m[9];
m[1]=c*m[1]+s*mv0;
m[5]=c*m[5]+s*mv4;
m[9]=c*m[9]+s*mv8;
}
function rotateX(m, angle) {
var c = Math.cos(angle);
var s = Math.sin(angle);
var mv1 = m[1], mv5 = m[5], mv9 = m[9];
m[1] = m[1]*c-m[2]*s;
m[5] = m[5]*c-m[6]*s;
m[9] = m[9]*c-m[10]*s;
m[2] = m[2]*c+mv1*s;
m[6] = m[6]*c+mv5*s;
m[10] = m[10]*c+mv9*s;
}
function rotateY(m, angle) {
var c = Math.cos(angle);
var s = Math.sin(angle);
var mv0 = m[0], mv4 = m[4], mv8 = m[8];
m[0] = c*m[0]+s*m[2];
m[4] = c*m[4]+s*m[6];
m[8] = c*m[8]+s*m[10];
m[2] = c*m[2]-s*mv0;
m[6] = c*m[6]-s*mv4;
m[10] = c*m[10]-s*mv8;
}
/*================= Drawing ===========================*/
var time_old = 0;
var animate = function(time) {
var dt = time-time_old;
rotateZ(mov_matrix, dt*0.005);//time
rotateY(mov_matrix, dt*0.002);
rotateX(mov_matrix, dt*0.003);
time_old = time;
gl.enable(gl.DEPTH_TEST);
gl.depthFunc(gl.LEQUAL);
gl.clearColor(0.5, 0.5, 0.5, 0.9);
gl.clearDepth(1.0);
gl.viewport(0.0, 0.0, canvas.width, canvas.height);
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
gl.uniformMatrix4fv(Pmatrix, false, proj_matrix);
gl.uniformMatrix4fv(Vmatrix, false, view_matrix);
gl.uniformMatrix4fv(Mmatrix, false, mov_matrix);
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, index_buffer);
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT, 0);
window.requestAnimationFrame(animate);
}
animate(0);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
इस अध्याय में, हम एक 3 डी क्यूब खींचना प्रदर्शित करने के लिए एक उदाहरण लेंगे जो माउस नियंत्रण का उपयोग करके घुमाया जा सकता है।
उदाहरण - इंटरएक्टिव क्यूब ड्रा करें
निम्नलिखित कार्यक्रम से पता चलता है कि माउस नियंत्रण का उपयोग करके क्यूब को कैसे घुमाया जाए -
<!doctype html>
<html>
<body>
<canvas width = "570" height = "570" id = "my_Canvas"></canvas>
<script>
/*============= Creating a canvas ======================*/
var canvas = document.getElementById('my_Canvas');
gl = canvas.getContext('experimental-webgl');
/*========== Defining and storing the geometry ==========*/
var vertices = [
-1,-1,-1, 1,-1,-1, 1, 1,-1, -1, 1,-1,
-1,-1, 1, 1,-1, 1, 1, 1, 1, -1, 1, 1,
-1,-1,-1, -1, 1,-1, -1, 1, 1, -1,-1, 1,
1,-1,-1, 1, 1,-1, 1, 1, 1, 1,-1, 1,
-1,-1,-1, -1,-1, 1, 1,-1, 1, 1,-1,-1,
-1, 1,-1, -1, 1, 1, 1, 1, 1, 1, 1,-1,
];
var colors = [
5,3,7, 5,3,7, 5,3,7, 5,3,7,
1,1,3, 1,1,3, 1,1,3, 1,1,3,
0,0,1, 0,0,1, 0,0,1, 0,0,1,
1,0,0, 1,0,0, 1,0,0, 1,0,0,
1,1,0, 1,1,0, 1,1,0, 1,1,0,
0,1,0, 0,1,0, 0,1,0, 0,1,0
];
var indices = [
0,1,2, 0,2,3, 4,5,6, 4,6,7,
8,9,10, 8,10,11, 12,13,14, 12,14,15,
16,17,18, 16,18,19, 20,21,22, 20,22,23
];
// Create and store data into vertex buffer
var vertex_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);
// Create and store data into color buffer
var color_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(colors), gl.STATIC_DRAW);
// Create and store data into index buffer
var index_buffer = gl.createBuffer ();
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, index_buffer);
gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
/*=================== SHADERS =================== */
var vertCode = 'attribute vec3 position;'+
'uniform mat4 Pmatrix;'+
'uniform mat4 Vmatrix;'+
'uniform mat4 Mmatrix;'+
'attribute vec3 color;'+//the color of the point
'varying vec3 vColor;'+
'void main(void) { '+//pre-built function
'gl_Position = Pmatrix*Vmatrix*Mmatrix*vec4(position, 1.);'+
'vColor = color;'+
'}';
var fragCode = 'precision mediump float;'+
'varying vec3 vColor;'+
'void main(void) {'+
'gl_FragColor = vec4(vColor, 1.);'+
'}';
var vertShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertShader, vertCode);
gl.compileShader(vertShader);
var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragShader, fragCode);
gl.compileShader(fragShader);
var shaderprogram = gl.createProgram();
gl.attachShader(shaderprogram, vertShader);
gl.attachShader(shaderprogram, fragShader);
gl.linkProgram(shaderprogram);
/*======== Associating attributes to vertex shader =====*/
var _Pmatrix = gl.getUniformLocation(shaderprogram, "Pmatrix");
var _Vmatrix = gl.getUniformLocation(shaderprogram, "Vmatrix");
var _Mmatrix = gl.getUniformLocation(shaderprogram, "Mmatrix");
gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);
var _position = gl.getAttribLocation(shaderprogram, "position");
gl.vertexAttribPointer(_position, 3, gl.FLOAT, false,0,0);
gl.enableVertexAttribArray(_position);
gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
var _color = gl.getAttribLocation(shaderprogram, "color");
gl.vertexAttribPointer(_color, 3, gl.FLOAT, false,0,0) ;
gl.enableVertexAttribArray(_color);
gl.useProgram(shaderprogram);
/*==================== MATRIX ====================== */
function get_projection(angle, a, zMin, zMax) {
var ang = Math.tan((angle*.5)*Math.PI/180);//angle*.5
return [
0.5/ang, 0 , 0, 0,
0, 0.5*a/ang, 0, 0,
0, 0, -(zMax+zMin)/(zMax-zMin), -1,
0, 0, (-2*zMax*zMin)/(zMax-zMin), 0
];
}
var proj_matrix = get_projection(40, canvas.width/canvas.height, 1, 100);
var mo_matrix = [ 1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1 ];
var view_matrix = [ 1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1 ];
view_matrix[14] = view_matrix[14]-6;
/*================= Mouse events ======================*/
var AMORTIZATION = 0.95;
var drag = false;
var old_x, old_y;
var dX = 0, dY = 0;
var mouseDown = function(e) {
drag = true;
old_x = e.pageX, old_y = e.pageY;
e.preventDefault();
return false;
};
var mouseUp = function(e){
drag = false;
};
var mouseMove = function(e) {
if (!drag) return false;
dX = (e.pageX-old_x)*2*Math.PI/canvas.width,
dY = (e.pageY-old_y)*2*Math.PI/canvas.height;
THETA+= dX;
PHI+=dY;
old_x = e.pageX, old_y = e.pageY;
e.preventDefault();
};
canvas.addEventListener("mousedown", mouseDown, false);
canvas.addEventListener("mouseup", mouseUp, false);
canvas.addEventListener("mouseout", mouseUp, false);
canvas.addEventListener("mousemove", mouseMove, false);
/*=========================rotation================*/
function rotateX(m, angle) {
var c = Math.cos(angle);
var s = Math.sin(angle);
var mv1 = m[1], mv5 = m[5], mv9 = m[9];
m[1] = m[1]*c-m[2]*s;
m[5] = m[5]*c-m[6]*s;
m[9] = m[9]*c-m[10]*s;
m[2] = m[2]*c+mv1*s;
m[6] = m[6]*c+mv5*s;
m[10] = m[10]*c+mv9*s;
}
function rotateY(m, angle) {
var c = Math.cos(angle);
var s = Math.sin(angle);
var mv0 = m[0], mv4 = m[4], mv8 = m[8];
m[0] = c*m[0]+s*m[2];
m[4] = c*m[4]+s*m[6];
m[8] = c*m[8]+s*m[10];
m[2] = c*m[2]-s*mv0;
m[6] = c*m[6]-s*mv4;
m[10] = c*m[10]-s*mv8;
}
/*=================== Drawing =================== */
var THETA = 0,
PHI = 0;
var time_old = 0;
var animate = function(time) {
var dt = time-time_old;
if (!drag) {
dX *= AMORTIZATION, dY*=AMORTIZATION;
THETA+=dX, PHI+=dY;
}
//set model matrix to I4
mo_matrix[0] = 1, mo_matrix[1] = 0, mo_matrix[2] = 0,
mo_matrix[3] = 0,
mo_matrix[4] = 0, mo_matrix[5] = 1, mo_matrix[6] = 0,
mo_matrix[7] = 0,
mo_matrix[8] = 0, mo_matrix[9] = 0, mo_matrix[10] = 1,
mo_matrix[11] = 0,
mo_matrix[12] = 0, mo_matrix[13] = 0, mo_matrix[14] = 0,
mo_matrix[15] = 1;
rotateY(mo_matrix, THETA);
rotateX(mo_matrix, PHI);
time_old = time;
gl.enable(gl.DEPTH_TEST);
// gl.depthFunc(gl.LEQUAL);
gl.clearColor(0.5, 0.5, 0.5, 0.9);
gl.clearDepth(1.0);
gl.viewport(0.0, 0.0, canvas.width, canvas.height);
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
gl.uniformMatrix4fv(_Pmatrix, false, proj_matrix);
gl.uniformMatrix4fv(_Vmatrix, false, view_matrix);
gl.uniformMatrix4fv(_Mmatrix, false, mo_matrix);
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, index_buffer);
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT, 0);
window.requestAnimationFrame(animate);
}
animate(0);
</script>
</body>
</html>
यदि आप इस उदाहरण को चलाते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -