WebGL - Warna

Dalam semua contoh kami sebelumnya, kami menerapkan warna pada objek dengan menetapkan nilai warna yang diinginkan ke gl_FragColorvariabel. Selain itu, kita dapat mendefinisikan warna untuk setiap simpul - seperti koordinat dan indeks simpul. Bab ini mengambil contoh untuk mendemonstrasikan bagaimana menerapkan warna ke segiempat menggunakan WebGL.

Menerapkan Warna

Untuk menerapkan warna, Anda harus menentukan warna untuk setiap simpul menggunakan nilai RGB, dalam larik JavaScript. Anda dapat menetapkan nilai yang sama ke semua simpul agar memiliki warna unik pada objek. Setelah menentukan warna, Anda harus membuat buffer warna dan menyimpan nilai-nilai ini di dalamnya, dan mengaitkannya dengan atribut shader vertex.

Dalam shader simpul, bersama dengan atribut koordinat (yang memegang posisi simpul), kita mendefinisikan sebuah attribute dan a varying untuk menangani warna.

Itu color atribut memegang nilai warna per simpul, dan varyingadalah variabel yang diteruskan sebagai masukan ke shader fragmen. Oleh karena itu, kami harus menetapkancolor nilai untuk varying.

Di shader fragmen, file varying yang memegang nilai warna yang ditetapkan gl_FragColor, yang menahan warna akhir objek.

Langkah-langkah untuk Menerapkan Warna

Langkah-langkah berikut diperlukan untuk membuat aplikasi WebGL untuk menggambar Quad dan menerapkan warna padanya.

Step 1 − Prepare the Canvas and Get the WebGL Rendering Context

Pada langkah ini, kita mendapatkan objek konteks Rendering WebGL menggunakan getContext().

Step 2 − Define the Geometry and Store it in the Buffer Objects

Sebuah persegi dapat digambar menggunakan dua segitiga. Oleh karena itu, dalam contoh ini, kami menyediakan simpul untuk dua segitiga (dengan satu sisi yang sama) dan indeks. Karena kita ingin menerapkan warna padanya, variabel yang menahan nilai warna juga ditentukan dan nilai warna untuk masing-masing (Merah, Biru, Hijau, dan Merah Muda) ditetapkan padanya.

var vertices = [
   -0.5,0.5,0.0,
   -0.5,-0.5,0.0, 
   0.5,-0.5,0.0,
   0.5,0.5,0.0 
];

var colors = [ 0,0,1, 1,0,0, 0,1,0, 1,0,1,];
indices = [3,2,1,3,1,0];

Step 3 − Create and Compile the Shader Programs

Pada langkah ini, Anda perlu menulis program shader vertex dan shader fragmen, mengompilasinya, dan membuat program gabungan dengan menautkan kedua program ini.

  • Vertex Shader- Pada vertex shader program, kita mendefinisikan atribut vektor untuk menyimpan koordinat 3D (posisi), dan warna setiap simpul. SEBUAHvaringvariabel dideklarasikan untuk meneruskan nilai warna dari shader vertex ke shader fragmen. Dan terakhir, nilai yang disimpan dalam atribut color ditetapkan kevarying.

var vertCode = 'attribute vec3 coordinates;'+
   'attribute vec3 color;'+
   'varying vec3 vColor;'+
	
   'void main(void) {' +
      ' gl_Position = vec4(coordinates, 1.0);' +
      'vColor = color;'+
   '}';
  • Fragment Shader - Di shader fragmen, kami menetapkan varying ke gl_FragColor variabel.

var fragCode = 'precision mediump float;'+
   'varying vec3 vColor;'+
   'void main(void) {'+
      'gl_FragColor = vec4(vColor, 1.);'+
   '}';

Step 4 − Associate the Shader Programs with the Buffer Objects

Pada langkah ini, kami mengaitkan objek buffer dan program shader.

Step 5 − Drawing the Required Object

Karena kita menggambar dua segitiga yang akan membentuk segi empat, menggunakan indeks, kita akan menggunakan metode ini drawElements(). Untuk metode ini, kita harus melewatkan jumlah indeks. Nilai dariindices.length menunjukkan jumlah indeks.

gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);

Contoh - Menerapkan Warna

Program berikut mendemonstrasikan cara menggambar quad menggunakan aplikasi WebGL dan menerapkan warna padanya.

<!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,
            0.5,0.5,0.0
         ];

         var colors = [0,0,1, 1,0,0, 0,1,0, 1,0,1,];
         
         indices = [3,2,1,3,1,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);

         // Create an empty buffer object and store Index data
         var Index_Buffer = gl.createBuffer();
         gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);
         gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), gl.STATIC_DRAW);
         gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);

         // Create an empty buffer object and store color data
         var color_buffer = gl.createBuffer ();
         gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
         gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(colors), gl.STATIC_DRAW);

         /*======================= Shaders =======================*/
         
         // vertex shader source code
         var vertCode = 'attribute vec3 coordinates;'+
            'attribute vec3 color;'+
            'varying vec3 vColor;'+
            'void main(void) {' +
               ' gl_Position = vec4(coordinates, 1.0);' +
               'vColor = color;'+
            '}';
            
         // Create a vertex shader object
         var vertShader = gl.createShader(gl.VERTEX_SHADER);

         // Attach vertex shader source code
         gl.shaderSource(vertShader, vertCode);

         // Compile the vertex shader
         gl.compileShader(vertShader);


         // fragment shader source code
         var fragCode = 'precision mediump float;'+
            'varying vec3 vColor;'+
            'void main(void) {'+
               'gl_FragColor = vec4(vColor, 1.);'+
            '}';
            
         // Create fragment shader object
         var fragShader = gl.createShader(gl.FRAGMENT_SHADER);

         // Attach fragment shader source code
         gl.shaderSource(fragShader, fragCode);

         // Compile the fragmentt shader
         gl.compileShader(fragShader);

         // Create a shader program object to
         // store the combined shader program
         var shaderProgram = gl.createProgram();

         // Attach a vertex shader
         gl.attachShader(shaderProgram, vertShader);

         // Attach a fragment shader
         gl.attachShader(shaderProgram, fragShader);

         // Link both the programs
         gl.linkProgram(shaderProgram);

         // Use the combined shader program object
         gl.useProgram(shaderProgram);

         /* ======== Associating shaders to buffer objects =======*/

         // Bind vertex buffer object
         gl.bindBuffer(gl.ARRAY_BUFFER, vertex_buffer);

         // Bind index buffer object
         gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, Index_Buffer);

         // Get the attribute location
         var coord = gl.getAttribLocation(shaderProgram, "coordinates");

         // point an attribute to the currently bound VBO
         gl.vertexAttribPointer(coord, 3, gl.FLOAT, false, 0, 0);

         // Enable the attribute
         gl.enableVertexAttribArray(coord);

         // bind the color buffer
         gl.bindBuffer(gl.ARRAY_BUFFER, color_buffer);
         
         // get the attribute location
         var color = gl.getAttribLocation(shaderProgram, "color");
 
         // point attribute to the volor buffer object
         gl.vertexAttribPointer(color, 3, gl.FLOAT, false,0,0) ;
 
         // enable the color attribute
         gl.enableVertexAttribArray(color);

         /*============Drawing the Quad====================*/

         // Clear the canvas
         gl.clearColor(0.5, 0.5, 0.5, 0.9);

         // Enable the depth test
         gl.enable(gl.DEPTH_TEST);

         // Clear the color buffer bit
         gl.clear(gl.COLOR_BUFFER_BIT);

         // Set the view port
         gl.viewport(0,0,canvas.width,canvas.height);

         //Draw the triangle
         gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
      </script>
   </body>
</html>

Jika Anda menjalankan contoh ini, itu akan menghasilkan keluaran berikut -