WebGL - एक मॉडल खींचना
बफ़र्स को शेड्स के साथ जोड़ने के बाद, अंतिम कदम आवश्यक प्राइमेटिव्स को आकर्षित करना है। 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);