A spatial audio, synthesis, and game development toolkit.
This is experimental and under active development. Specifically, the API has changed significantly from previous versions. Many of these changes are yet to be documented. Please use at your own risk.
syngen provides a light wrapper around the Web Audio API for building sounds and positioning them on a three-dimensional binaural soundstage. Its event loop fires each frame to update sounds and core systems. Additional utilities provide tools for engineering custom systems that hook into its API to deliver rich experiences.
Please download or clone this repository, or install with your favorite package manager:
npm install syngenFrom there you might require('syngen') or include dist/syngen.min.js.
This library must be used within a browser environment so it can access the window object.
It can be imported or required as a UMD module, or accessed from the syngen global.
This example demonstrates how to define a prop and instantiate one on the soundstage:
const prototype = syngen.sound.invent({
onConstruct: function () {
this.synth = syngen.synth.simple({
frequency: syngen.fn.fromMidi(60),
gain: syngen.fn.fromDb(-6),
}).connect(this.output)
},
onDestroy: function () {
this.synth.stop()
},
})
const instance = sound.instantiate()Please browse the example directory or the projects below for more elaborate real-world examples.
- Fishyphus - Sisyphean fishing horror
- Lacus Opportunitas - Lunar lake trading simulator
- Project Ephemera - Forgotten demo disc of synths
- Periphery Synthetic EP – Extrasolar musical explorer
To get started, please clone this repository:
git clone https://github.com/nicross/syngen.gitThen use npm to install the required dependencies
npm installCommon tasks have been automated with Gulp:
gulp distgulp docsgulp buildgulp watch