data:image/s3,"s3://crabby-images/c8c31/c8c313397333d3205d74a2ef7e364bfd73416e5b" alt="@thi.ng/webgl"
data:image/s3,"s3://crabby-images/0f868/0f86812acbe1896364aaa9cb8e55205fb553493c" alt="Twitter Follow"
This project is part of the
@thi.ng/umbrella monorepo.
About
WebGL & GLSL abstraction layer.
Largely declarative WebGL 1.0 / 2.0 abstraction layer, partially ported
& updated from Clojure/ClojureScript versions of
thi.ng/geom.
Features
- Extensive set of WebGL related types & interfaces
- Declarative shader definition
- option to fully define shaders in TypeScript and transpile to GLSL (via
@thi.ng/shader-ast)
- attribute, varying, uniform & output type declarations via a simple config object
- GLSL code generation of data type declarations
- automatic support for GLSL ES 1.0 & 3.0
- optional layout attrib layout support for GLES 3 (WebGL2)
- automatic & typed uniform setters
- pre-declared desired GL draw state flags / settings
- customizable shader presets
- Declarative geometry, attribute & index buffer specs
- Declarative instancing (always available in WebGL2, or via ANGLE ext in WebGL1)
- Texture wrapper, declarative config
- Comprehensive texture format info (channels, strides, renderable, filterable etc.)
- FBO support with multiple attachments & render buffers
- Multi-pass shader pipeline (e.g. for GPGPU tasks)
- Pixel reading from main color buffer and textures
- Geometry & texture generators
- WebGL extension helpers & semi-automatic extension enabling
- WebGL canvas creation / setup
Status
BETA - possibly breaking changes forthcoming
Support packages
Related packages
- @thi.ng/ecs - Entity Component System based around typed arrays & sparse sets
- @thi.ng/geom - Functional, polymorphic API for 2D geometry types & SVG generation
- @thi.ng/imgui - Immediate mode GUI with flexible state handling & data only shape output
- @thi.ng/matrices - Matrix & quaternion operations for 2D/3D geometry processing
- @thi.ng/shader-ast - DSL to define shader code in TypeScript and cross-compile to GLSL, JS and other targets
- @thi.ng/soa - SOA & AOS memory mapped structured views with optional & extensible serialization
- @thi.ng/vectors - Optimized 2d/3d/4d and arbitrary length vector operations
- @thi.ng/vector-pools - Data structures for managing & working with strided, memory mapped vectors
Installation
yarn add @thi.ng/webgl
Package sizes (gzipped): ESM: 11.0KB / CJS: 11.1KB / UMD: 10.9KB
Dependencies
Usage examples
Several demos in this repo's
/examples
directory are using this package.
A selection:
shader-ast-evo
data:image/s3,"s3://crabby-images/335c5/335c590db08551b3b7d718d183c9e611e7559b66" alt="screenshot"
Evolutionary shader generation using genetic programming
Live demo | Source
shader-ast-noise
data:image/s3,"s3://crabby-images/b7b4b/b7b4bd5f40371272431bfc975953e95b38cc5dbb" alt="screenshot"
HOF shader procedural noise function composition
Live demo | Source
shader-ast-raymarch
data:image/s3,"s3://crabby-images/d394e/d394e6d8a39630bdc89772bf3853539ab01fa6d0" alt="screenshot"
WebGL & JS canvas2D raymarch shader cross-compilation
Live demo | Source
shader-ast-sdf2d
data:image/s3,"s3://crabby-images/1b8c4/1b8c4f7d6806b130ab6bdc9822c62a38d72e36bf" alt="screenshot"
WebGL & JS canvas 2D SDF
Live demo | Source
shader-ast-tunnel
data:image/s3,"s3://crabby-images/3d420/3d42087459e8e93395acd51bb856f7197c3aeae8" alt="screenshot"
WebGL & Canvas2D textured tunnel shader
Live demo | Source
soa-ecs
data:image/s3,"s3://crabby-images/dac43/dac43d04e1f214fe3652711a03b1ebf96c29a807" alt="screenshot"
Entity Component System w/ 100k 3D particles
Live demo | Source
webgl-cube
data:image/s3,"s3://crabby-images/c9391/c93917696c4e567c17d453d27b1316ee4cd4f3f8" alt="screenshot"
WebGL multi-colored cube mesh
Live demo | Source
webgl-cubemap
data:image/s3,"s3://crabby-images/d5588/d5588bd2e71a8e0ef25934c0e8f2acec0f626fd7" alt="screenshot"
WebGL cube maps with async texture loading
Live demo | Source
webgl-grid
data:image/s3,"s3://crabby-images/1e22d/1e22d4b0c63daef97f397736e0c9ed1bfd7f9710" alt="screenshot"
WebGL instancing, animated grid
Live demo | Source
webgl-msdf
data:image/s3,"s3://crabby-images/a909f/a909fbd8ea9e4a9103c5812cacabecab9d2fc5c6" alt="screenshot"
WebGL MSDF text rendering & particle system
Live demo | Source
webgl-multipass
Minimal multi-pass / GPGPU example
Live demo | Source
webgl-shadertoy
data:image/s3,"s3://crabby-images/df784/df7840060c7c598ec1dd3428fb050b5706a6e177" alt="screenshot"
Shadertoy-like WebGL setup
Live demo | Source
webgl-ssao
data:image/s3,"s3://crabby-images/84f16/84f167bb8f1b130f1aef565a902b46f5b3218aeb" alt="screenshot"
WebGL screenspace ambient occlusion
Live demo | Source
API
Generated API docs
TODO
Authors
Karsten Schmidt
License
© 2014 - 2020 Karsten Schmidt // Apache Software License 2.0