WebGL JavaScript

Applying a Base64 Image Texture

This JavaScript program demonstrates how to apply a base64 image texture in a WebGL program.

ApplyBase64Texture.html

<!DOCTYPE html>
<html>
  <head>
    <title>XoaX.net's WebGL</title>

    <script  id="idVertexShader" type="c">
      // The attributes receives data from the buffers
      attribute vec2 afVertexCoordinates;
      varying vec2 afTextureCoordinates;
      void main() {
        afTextureCoordinates = afVertexCoordinates;
        gl_Position = vec4(afVertexCoordinates, 0.0, 1.0);
      }
    </script>

    <script  id="idFragmantShader" type="c">
      precision mediump float;
      varying vec2 afTextureCoordinates;
      uniform sampler2D qUniformSampler;
      void main() {
        gl_FragColor = texture2D(qUniformSampler, afTextureCoordinates);
      }
    </script>

    <script type="text/javascript">
    function Render() {
      // Get the WebGL Context
      var qCanvas = document.querySelector("#idCanvasWebGL");
      var qGL = qCanvas.getContext("webgl");

      // Compile the vertex shader
      var sVertexShaderCode = document.querySelector("#idVertexShader").text;
      var qVertexShader = qGL.createShader(qGL.VERTEX_SHADER);
      qGL.shaderSource(qVertexShader, sVertexShaderCode);
      qGL.compileShader(qVertexShader);

      // Compile the fragment shader
      var sFragmentShaderCode = document.querySelector("#idFragmantShader").text;
      var qFragmentShader = qGL.createShader(qGL.FRAGMENT_SHADER);
      qGL.shaderSource(qFragmentShader, sFragmentShaderCode);
      qGL.compileShader(qFragmentShader);

      // Compile and link the program
      var qProgram = qGL.createProgram();
      qGL.attachShader(qProgram, qVertexShader);
      qGL.attachShader(qProgram, qFragmentShader);
      qGL.linkProgram(qProgram);
      qGL.useProgram(qProgram);

      var afVertices = [-1, -1, 1, -1, -1, 1, 1, 1];
      var qVertexBuffer = qGL.createBuffer();
      qGL.bindBuffer(qGL.ARRAY_BUFFER, qVertexBuffer);
      qGL.bufferData(qGL.ARRAY_BUFFER, new Float32Array(afVertices), qGL.STATIC_DRAW);
      var iCoordinatesPerPoint = 2;
      var qVertexAttribute = qGL.getAttribLocation(qProgram, 'afVertexCoordinates');
      qGL.enableVertexAttribArray(qVertexAttribute);
      qGL.vertexAttribPointer(qVertexAttribute, iCoordinatesPerPoint, qGL.FLOAT, false, 0, 0);

      var qTexture = qGL.createTexture();
      var qImage = document.getElementById("idTexture");
      qUniformSampler = qGL.getUniformLocation(qProgram, 'qUniformSampler');
      qGL.activeTexture(qGL.TEXTURE0);
      qGL.bindTexture(qGL.TEXTURE_2D, qTexture);
      qGL.pixelStorei(qGL.UNPACK_FLIP_Y_WEBGL, true);
      qGL.texImage2D(qGL.TEXTURE_2D, 0, qGL.RGBA, qGL.RGBA, qGL.UNSIGNED_BYTE, qImage);
      qGL.texParameteri(qGL.TEXTURE_2D, qGL.TEXTURE_MAG_FILTER, qGL.LINEAR);
      qGL.texParameteri(qGL.TEXTURE_2D, qGL.TEXTURE_MIN_FILTER, qGL.LINEAR);
      qGL.texParameteri(qGL.TEXTURE_2D, qGL.TEXTURE_WRAP_S, qGL.MIRRORED_REPEAT);
      qGL.texParameteri(qGL.TEXTURE_2D, qGL.TEXTURE_WRAP_T, qGL.MIRRORED_REPEAT);
      qGL.uniform1i(qUniformSampler, 0);

      var iNumberOfItems = 4;
      qGL.drawArrays(qGL.TRIANGLE_STRIP, 0, iNumberOfItems);
    }
    </script>
  </head>
  <body onload="Render()">
    <canvas id="idCanvasWebGL" width="512" height="512" style="background-color:white;border:1px solid red;"></canvas>
    <img hidden id="idTexture" src="" />
  </body>
</html>
 

Output

 
 

© 2007–2024 XoaX.net LLC. All rights reserved.