Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/node-3d/webgl-raub
OpenGL/WebGL for Node.js
https://github.com/node-3d/webgl-raub
addon bindings cpp gl graphics javascript native node-3d opengl webgl
Last synced: 5 days ago
JSON representation
OpenGL/WebGL for Node.js
- Host: GitHub
- URL: https://github.com/node-3d/webgl-raub
- Owner: node-3d
- License: mit
- Created: 2017-01-22T19:18:33.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-11-03T12:26:39.000Z (2 months ago)
- Last Synced: 2025-01-04T02:20:38.346Z (12 days ago)
- Topics: addon, bindings, cpp, gl, graphics, javascript, native, node-3d, opengl, webgl
- Language: C++
- Homepage: https://github.com/node-3d/node-3d
- Size: 7.76 MB
- Stars: 85
- Watchers: 4
- Forks: 12
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# WebGL for Node.js
This is a part of [Node3D](https://github.com/node-3d) project.
[![NPM](https://badge.fury.io/js/webgl-raub.svg)](https://badge.fury.io/js/webgl-raub)
[![ESLint](https://github.com/node-3d/webgl-raub/actions/workflows/eslint.yml/badge.svg)](https://github.com/node-3d/webgl-raub/actions/workflows/eslint.yml)
[![Test](https://github.com/node-3d/webgl-raub/actions/workflows/test.yml/badge.svg)](https://github.com/node-3d/webgl-raub/actions/workflows/test.yml)
[![Cpplint](https://github.com/node-3d/webgl-raub/actions/workflows/cpplint.yml/badge.svg)](https://github.com/node-3d/webgl-raub/actions/workflows/cpplint.yml)```console
npm i -s webgl-raub
```![Example](examples/screenshot.jpg)
**WebGL**/**OpenGL** bindings. The addon **does not provide** a window control system, and it
**can not set up an OpenGL context** on its own. This API simply maps the
native OpenGL function calls to their JS counterparts.**TL;DR**: For a quick start, use [3d-core-raub](https://github.com/node-3d/3d-core-raub)
or try the [Examples](/examples) (and note [package.json](/examples/package.json)).> Note: this **addon uses N-API**, and therefore is ABI-compatible across different
Node.js versions. Addon binaries are precompiled and **there is no compilation**
step during the `npm i` command.## Details
```js
const webgl = require('webgl-raub');
```Here `webgl` contains the **WebGL** API, like a `WebGLRenderingContext` instance would. See
[WebGLRenderingContext docs](https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext)
for reference, and [TypeScript definitions](/index.d.ts) for the full list of exports.
There are also numerous non-WebGL methods exported in case you want to use advanced OpenGL functions.To use browser **WebGL** libs, like [three.js](https://threejs.org/),
several additional interfaces must also be provided to mimic the browser.* Package [glfw-raub](https://github.com/node-3d/glfw-raub) provides window/context handling
and additional browser-like interfaces.
* Package [image-raub](https://github.com/node-3d/glfw-raub) loads and serves the image data as web
[Image](https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement#example) would.Those two are bundled into
the [3d-core-raub](https://github.com/node-3d/3d-core-raub) in a following manner:```js
import Image from 'image-raub';
import webgl from 'webgl-raub';
import glfw from 'glfw-raub';
const { Document } = glfw;Document.setImage(image); // plug this Image impl into the Document
Document.setWebgl(webgl); // plug this WebGL impl into the Documentconst doc = new Document();
global.document = global.window = doc;const canvas = document.createElement('canvas'); // === doc
const gl = canvas.getContext('webgl'); // === webgl
```You can optionally call `webgl.init()` after the GL context becomes available - this translates
into a `glewInit()` call. See [GLEW docs](https://glew.sourceforge.net/basic.html) for what
it does and if you need it (probably "yes"?).> OSX Note: some features may depend on OpenGL profile being used. Core profile
is necessary for VAO and other OpenGL 3.2+ features. Depending on your windowing
backend, set the OpenGL profile of your preference.
In case [glfw-raub](https://github.com/node-3d/glfw-raub) is used,
the profile can be set through the `Window`/`Document`
[constructor](https://github.com/node-3d/glfw-raub#class-window) or with
`glfw.windowHint` calls.---
## WebGL Libs
* [three.js](https://threejs.org/) - known to work well on **Node.js** with this
implementation of **WebGL**.
* [PixiJS](https://pixijs.com/) - seems to work with some minor hacks, as proven by this
[example](https://github.com/node-3d/3d-core-raub/blob/master/examples/pixi/index.js).Using [node-3d-core](https://github.com/node-3d/3d-core-raub), you can skip setting up
most environment features for those libs.