Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/adriancooney/node-sfx
Add some sound effects to your node programs.
https://github.com/adriancooney/node-sfx
Last synced: 17 days ago
JSON representation
Add some sound effects to your node programs.
- Host: GitHub
- URL: https://github.com/adriancooney/node-sfx
- Owner: adriancooney
- Created: 2014-01-07T18:32:26.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2017-01-02T22:36:53.000Z (about 8 years ago)
- Last Synced: 2024-10-29T14:42:19.425Z (2 months ago)
- Language: JavaScript
- Size: 805 KB
- Stars: 70
- Watchers: 4
- Forks: 10
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-sound - node-sfx
README
# sfx.js
### Add some sound to your node programs.
Want a notification when your node program has finished executing? Want a beep whenever your program has encountered an error? Ever just wanted your error messages read out? `node-sfx` is for you.### Install
Install `sfx` via npm.npm install sfx
And require it in your program.
```js
var sfx = require("sfx");
```### API
`sfx` aims to provide a simple, consistent, cross-platformish API for your sound effects in your node programs.#### `sfx.play( sound [, volume, rate, callback] )`
Play a sound. `sound` is a path to a sound file or a name of sound file in the `sounds/` directory (without the extension). Specifiying "random" for the `sound` parameter plays a random sound from the library. `volume` is a number between 1-100. `rate` is the speed the sound effect is played at (experimental). And finally, `callback` is called on complete.```js
sfx.play("/System/Library/Sounds/Ping.aiff");
sfx.play("ping");
sfx.play("ping", 100);
```#### `sfx.say( string [, voice, callback] )` (OSX only for now)
Use text-to-speech to hear a string spoke aloud. `string` is the string to speak. `voice` is to specify a voice to speak with. Available voices (OSX only) are: Agnes, Albert, Alex, Bad News, Bahh, Bells, Boing, Bruce, Bubbles, Cellos, Deranged, Fred, Good News, Hysterical, Junior, Kathy, Pipe Organ, Princess, Ralph, Trinoids, Vicki, Victoria, Whisper, Zarvox and "random" to use a random voice.```js
sfx.say("The human torch was denied a bank loan.");
sfx.say("The arsonist has oddly shaped feet.", "Hysterical");
sfx.say("The skeleton ran out of shampoo in the shower.", "random");
```#### `sfx.[sound]( [volume, rate] )`
Sounds in the library (without their extension) can also be called directly from the `sfx` for easy access. `sound` is the name of sound within the `sound/` library.```js
sfx.ping();
sfx.hero();
sfx.random(); // Play a random sound
```### Example uses
Use `sfx` to read out your logs (but it's probably a bad idea).```js
var _log = console.log;
console.log = function() { sfx.say(Array.prototype.join.call(arguments, ". ")); _log.apply(console, arguments); }
```Make `sfx` dunk on an error.
```js
db.on("error", function(err) {
sfx.funk(function() {
throw err;
});
});
```Have a nice alert when your script is finished running.
```js
operation.on("complete", function() {
sfx.pop(function() {
process.exit();
})
});
```Your website's traffic is fading and every request is a good request so it should have a happy sound.
```js
app.get("/", function(req, res) {
sfx.hero();
});
```Got any cool examples? Submit a pull request and I'd be happy to put it here.
### Contributing
Have a cool sound to contribute? Make sure it's less than 250kb, stick it in the `sounds/` directory and submit a pull request.### TODO
* Add a little sound package manager hosted on Github so you can selectively retrieve sounds. `sfx add hooray` which adds the `hooray` sound to the global sfx sound directory. Sound files could get large and ain't nobody got time for that.### Licensing
MITThe sounds within the `sounds/` directory are the factory sounds provided in `/System/Library/Sounds` in OSX. I have no idea what the licensing on these sounds. If anyone can inform me of the license, it would be greatly appreciated.