Skip to content

Latest commit

 

History

History
93 lines (78 loc) · 2.52 KB

README.md

File metadata and controls

93 lines (78 loc) · 2.52 KB

webgl2D

2d webgl library

Features

Easy and fast drawing images with webGL
matrix functionality
colorable
optional custom shader programs

Use

basic

Add webgl2D.js to you files
get context with webGL2DStart

  let canvas = document.getElementById("canvas");

  //options for WebGL2D context
  obj = {
    antialias: false, //enable WebGL antialiasing
    smoothing: false, //enable linear image filtering
    blending:  true   //enable alpha blending
  }

  //create new WebGL context from canvas and optional options
  let gl2D = new WebGL2DContext(canvas, obj);

load a texture

  //you can create a texture from a file,
  texture = gl2D.textureFromFile("./assets/texture.png");

  //from image or canvas,
  texture = gl2D.textureFromImage(image);

  //or from Uint8Array 
  //whether it is RGB or RGBA is automatically determined
  //width and height must be a potency of 2 (32, 64, 128, etc)
  //parameter(pixelArray, width, height);
  texture = gl2D.textureFromPixelArray(new Uint8Array(pixelArray),64,64);

render the image

  //clear the buffer
  gl2D.startScene();
  
  //add image to render list //parameter(texture,src:[posX,posY,width,height],dst:[posX,posY,width,height],[color:[r,g,b,a]])
  gl2D.drawImage(texture,[0,0,64,64],[64,64,64,64],[255,255,255,255]);

  //bind buffers
  gl2D.endScene();
  
  //render images
  gl2D.renderScene();

advanced

use matrix

  //moves the center of coordinate system
  gl2D.matrix.translate(64,0);
  
  //scale the coordinate system
  gl2D.matrix.scale(1,1);

  //rotates around the center
  gl2D.matrix.rotate(10);

  //reset matrix to default
  gl2D.matrix.reset();

extended drawing functions

  //parameter(texture,src:[posX1,posY1,posX2,posY2,...],dst:[posX1,posY1,posX2,posY2,...],color:[r,g,b,a, r,g,b,a,...])

  //add triangle to render list (use 3 points)
  gl2D.drawTriangle(texture,[0,0, 64,0, 32,32],[0,0, 64,0, 32,32],[255,0,0,255, 0,255,0,255, 0,0,255,255]);

  //add square to render list (use 4 points)
  gl2D.drawSquare(texture,[0,0, 64,0, 64,64, 0,64],[0,0, 64,0, 64,64, 0,64],[255,255,255,255, 255,255,255,255, 255,255,255,255, 255,255,255,255]);

custom shaders

  //shader attributes
    vec2 aVertexPosition;
    vec2 aTextureCoord;
    vec4 aVertexColor;

  //shader uniforms
    sampler2D uSampler;

  //compile shader and return a shader program
  shaderProgram = gl2D.compileShader(vertexShaderCode,fragmentShaderCode)

  //use this shader program 
  gl2D.useShader(shaderProgram)