WebGL - स्केलिंग

इस अध्याय में, हम यह दिखाने के लिए एक उदाहरण लेंगे कि वेबजीएल का उपयोग करके त्रिकोण के पैमाने को कैसे संशोधित किया जाए।

स्केलिंग

स्केलिंग और कुछ नहीं बल्कि एक वस्तु के आकार को बढ़ाना या घटाना है। उदाहरण के लिए, यदि किसी त्रिभुज के आकार [, 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>

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