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- दूसरा चरण पिछले चरण में बनाई गई बफर ऑब्जेक्ट के लिए संदर्भ चर है। संदर्भ चर एक वर्टिकल बफर ऑब्जेक्ट या इंडेक्स बफर ऑब्जेक्ट का हो सकता है।

उदाहरण

निम्न कोड स्निपेट दिखाता है कि बिंदबफ़र () पद्धति का उपयोग कैसे किया जाए।

//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(एनम टारगेट , लॉन्ग ऑफ़सेट , ऑब्जेक्ट डेटा )

लक्ष्य - 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(ऑब्जेक्ट बफर )