WebGL - अनुवाद

अब तक, हमने चर्चा की कि विभिन्न आकारों को कैसे आकर्षित किया जाए और उनमें वेबगेल का उपयोग करके रंगों को लागू किया जाए। यहाँ, इस अध्याय में, हम एक उदाहरण देंगे कि कैसे एक त्रिकोण का अनुवाद किया जाए।

अनुवाद

अनुवाद इनमें से एक है affine transformationsWebGL द्वारा प्रदान किया गया। अनुवाद का उपयोग करके, हम xyz विमान पर एक त्रिभुज (किसी भी वस्तु) को स्थानांतरित कर सकते हैं। मान लीजिए कि हमारे पास एक त्रिभुज है [a, b, c] और हम त्रिभुज को उस स्थिति में ले जाना चाहते हैं जो धनात्मक X- अक्ष की ओर 5 इकाई है और धनात्मक Y- अक्ष की ओर 3 इकाई है। फिर नए कोने [5 +, b + 3, c + 0] होंगे। इसका मतलब है, त्रिभुज का अनुवाद करने के लिए, हमें प्रत्येक दूरस्थ स्थान पर अनुवाद की दूरी, कहना, tx, ty, tz जोड़ना होगा।

चूंकि यह ए per-vertex operation, हम इसे वर्टेक्स शेडर प्रोग्राम में ले जा सकते हैं।

विशेषता के साथ, शीर्ष की छाया में, 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>

यदि आप इस उदाहरण को चलाते हैं, तो यह निम्न आउटपुट का उत्पादन करेगा -