वेबगेल - ग्राफिक्स पाइपलाइन
3 डी ग्राफिक्स रेंडर करने के लिए, हमें चरणों के अनुक्रम का पालन करना होगा। इन चरणों के रूप में जाना जाता हैgraphics pipeline या rendering pipeline। निम्न आरेख में WebGL ग्राफिक्स पाइपलाइन को दर्शाया गया है।
निम्नलिखित वर्गों में, हम पाइपलाइन में प्रत्येक चरण की एक-एक भूमिका पर चर्चा करेंगे।
जावास्क्रिप्ट
WebGL एप्लिकेशन विकसित करते समय, हम GPU के साथ संवाद करने के लिए Shader भाषा कोड लिखते हैं। जावास्क्रिप्ट का उपयोग कार्यक्रम के नियंत्रण कोड को लिखने के लिए किया जाता है, जिसमें निम्नलिखित क्रियाएं शामिल हैं -
Initialize WebGL - 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 रेंडरिंग पाइपलाइन का अंतिम गंतव्य है।
फ्रेम बफर
फ्रेम बफर ग्राफिक्स मेमोरी का एक हिस्सा है जो दृश्य डेटा को धारण करता है। इस बफ़र में सतह की चौड़ाई और ऊँचाई (पिक्सेल में), प्रत्येक पिक्सेल का रंग और गहराई और स्टेंसिल बफ़र्स जैसे विवरण होते हैं।