WebGL class for rendering static indexed geometry
var shell = require("gl-now")()
var createMesh = require("gl-mesh")
var simple2DShader = require("simple-2d-shader")
var mesh, shader
shell.on("gl-init", function() {
shader = simple2DShader(shell.gl)
mesh = createMesh(shell.gl,
[[0, 1, 2],
[2, 1, 3]],
{ "position": [[-1,-1], [0, 1], [0, 0], [1, -1]],
"color": [[1, 0, 0], [0, 1, 0], [0, 0, 1], [1, 1, 1]] })
})
shell.on("gl-render", function(t) {
shader.bind()
mesh.bind(shader)
mesh.draw()
mesh.unbind()
})And here is what it should look like:
Use npm to install it locally:
npm install gl-mesh
Then you can build/run the client using any tool that compiles CommonJS modules, for example browserify or beefy.
var createMesh = require("gl-mesh")Creates a static mesh.
glis a webgl contextcellsis a list of representing indices into the geometryattributesis an object of attributes to pass to the mesh
Each of these objects can be encoded as either an array-of-native-arrays or as a typed array using ndarrays. The first dimension in the shape is interepreted as the number of vertices in the attribute while the second dimension is interpreted as the size. For example, to pass in a packed array of 3d vertices in a typed array you could do:
var mesh = createMesh(gl, cells, { "positions": ndarray(position_data, [numVertices, 3]) })The drawing mode for the mesh is determined by the shape of the cells according to the following rule:
cells.length == 0: empty meshcells[0].length == 1:gl.POINTScells[0].length == 2:gl.LINEScells[0].length == 3:gl.TRIANGLES
You can also skip the cells parameter, in which case the resulting mesh is drawn as a point cloud.
Also you can pass a single object with a cells field. For example, here is the quickest way to create a Stanford bunny test mesh:
var bunnyMesh = createMesh(gl, require("bunny"))Where the module comes from the bunny package
Returns A Mesh object
Each Mesh object has the following methods:
Binds the mesh to the given shader updating attributes accordingly.
shaderis an instance of a shader created usinggl-shader
Draws an instance of the mesh once it is bound to a shader
Unbinds the mesh releasing the current vertex attribute state
Destroys the mesh and releases all of its associated resources
(c) 2013 Mikola Lysenko. MIT License
