Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vanruesc/three-demo
A compact demo framework for three.js.
https://github.com/vanruesc/three-demo
boilerplate demo framework scaffold threejs
Last synced: 3 months ago
JSON representation
A compact demo framework for three.js.
- Host: GitHub
- URL: https://github.com/vanruesc/three-demo
- Owner: vanruesc
- License: zlib
- Archived: true
- Created: 2017-12-16T13:20:25.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2023-07-20T20:04:52.000Z (over 1 year ago)
- Last Synced: 2024-09-05T18:50:27.603Z (4 months ago)
- Topics: boilerplate, demo, framework, scaffold, threejs
- Language: TypeScript
- Homepage:
- Size: 4.8 MB
- Stars: 14
- Watchers: 2
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Three Demo
[![CI](https://github.com/vanruesc/three-demo/actions/workflows/ci.yml/badge.svg)](https://github.com/vanruesc/three-demo/actions/workflows/ci.yml)
[![Version](https://badgen.net/npm/v/three-demo?color=green)](https://www.npmjs.com/package/three-demo)A compact demo framework for [three.js](https://threejs.org/).
*[Demo](https://vanruesc.github.io/three-demo/demo) · [Documentation](https://vanruesc.github.io/three-demo/docs)*
## Installation
This library requires the peer dependencies [three](https://github.com/mrdoob/three.js/) and [dat.gui](https://github.com/dataarts/dat.gui).
```sh
npm install dat.gui three three-demo
```## Usage
```js
import { DemoManager } from "three-demo";
import { MyDemo } from "./MyDemo";const manager = new DemoManager(document.getElementById("viewport"), {
aside: document.getElementById("aside"),
renderer
});manager.addEventListener("change", (event) => console.log(event));
manager.addEventListener("load", (event) => console.log(event));manager.addDemo(new MyDemo());
requestAnimationFrame(function render(timestamp) {
requestAnimationFrame(render);
manager.render(timestamp);});
```## Custom Demos
You can create custom demos by extending the `Demo` class. For details, take a look at the [ExampleDemo](https://github.com/vanruesc/three-demo/blob/main/demo/src/demos/ExampleDemo.ts).
## Contributing
Please refer to the [contribution guidelines](https://github.com/vanruesc/three-demo/blob/main/.github/CONTRIBUTING.md) for details.