Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/loov/jsfx

Javascript Sound Effect Generator
https://github.com/loov/jsfx

game-development javascript sound sound-effects

Last synced: 19 days ago
JSON representation

Javascript Sound Effect Generator

Awesome Lists containing this project

README

        

![](https://raw.githubusercontent.com/loov/jsfx/master/jsfx.png)

This is a JavaScript library for sound effect generation and is supported on
[most current browsers](http://caniuse.com/#feat=audio).

Generation speed is approximately 1s audio = 10ms processing. Of course that
value can vary a lot, depending on the settings or browser that you use.

### How to use it?

Open [index.html](http://loov.github.io/jsfx/) - this helps to pick out your samples.

Try clicking the presets and tweaking all the options. Once you are satisified
with your result click add button at top-right.

Enter a name for the sound e.g. "select", repeat that as many times as you like. Tip: You can save your settings by making a bookmark of the page.

At the bottom of the page there is a Library section. There you can relisten
or remove sounds that you do not like.

Once you are satisfied with your selection copy the JSON description
(it's inside the input box).

It will look something like:

{"select":{"Volume":{"Sustain":0.1,"Decay":0.15,"Punch":0.55}}}

To use that library, you need to include `jsfx.js` in your code and use `jsfx.Sounds(libarry)` to initialize it. For example:

```html

var library = {
"select": {"Volume":{"Sustain":0.1,"Decay":0.15,"Punch":0.55}},
"long": {"Volume":{"Sustain":0.1,"Decay":0.5,"Punch":1}}
};
var sfx = jsfx.Sounds(library);

Select
Long
```

Note that it will load with a delay to avoid blocking the page load for too
long, so calling those function immediately may result in silence.

### Using with AudioContext (experimental)

You can use AudioContext to procedurally generate the sounds, for example:

```html

var library = {
"static": {"Volume":{"Sustain":0.1,"Decay":0.15,"Punch":0.55}},
"dynamic": function(){
return {"Frequency": { "Start": Math.random()*440 + 220 }};
},
"coin": jsfx.Preset.Coin
};
var sfx = jsfx.Live(library);

Static
Dynamic
Coin
```

### Few notes...

It's recommended to copy the jsfx.js to your own project instead of
automatically downloading the latest version. Since every slight adjustment
to the audio generation code can affect the resulting audio significantly.

The stable API is what is described in the README, everything else is
subject to change.

### Thanks to

This project was inspired by [sfxr](http://www.drpetter.se/project_sfxr.html)
and was used as a reference for some algorithms and modes.