add GreenPlayer.isStarting promise

Self-resolving promise removes itself once it resolves. While it is on
a player the player may consider itself to not yet have the time to
actually start sound playback. While playback has not started, the
player can shortcut out of starting playback.
This commit is contained in:
Michael "Z" Goddard 2018-06-18 14:47:38 -04:00
parent 961749815c
commit 331f083f5a
No known key found for this signature in database
GPG key ID: 762CD40DD5349872

View file

@ -31,6 +31,7 @@ class SoundPlayer extends EventEmitter {
this.initialized = false; this.initialized = false;
this.isPlaying = false; this.isPlaying = false;
this.isStarting = null;
this.playbackRate = 1; this.playbackRate = 1;
} }
@ -146,6 +147,7 @@ class SoundPlayer extends EventEmitter {
const taken = new SoundPlayer(this.audioEngine, this); const taken = new SoundPlayer(this.audioEngine, this);
taken.playbackRate = this.playbackRate; taken.playbackRate = this.playbackRate;
if (this.isPlaying) { if (this.isPlaying) {
taken.isStarting = this.isStarting;
taken.isPlaying = this.isPlaying; taken.isPlaying = this.isPlaying;
taken.initialize(); taken.initialize();
taken.outputNode.disconnect(); taken.outputNode.disconnect();
@ -168,6 +170,7 @@ class SoundPlayer extends EventEmitter {
} }
this.volumeEffect = null; this.volumeEffect = null;
this.initialized = false; this.initialized = false;
this.isStarting = null;
this.isPlaying = false; this.isPlaying = false;
return taken; return taken;
@ -180,6 +183,10 @@ class SoundPlayer extends EventEmitter {
* out. * out.
*/ */
play () { play () {
if (this.isStarting) {
return;
}
if (this.isPlaying) { if (this.isPlaying) {
// Spawn a Player with the current buffer source, and play for a // Spawn a Player with the current buffer source, and play for a
// short period until its volume is 0 and release it to be // short period until its volume is 0 and release it to be
@ -198,6 +205,13 @@ class SoundPlayer extends EventEmitter {
this.isPlaying = true; this.isPlaying = true;
const isStarting = this.isStarting = Promise.resolve()
.then(() => {
if (this.isStarting === isStarting) {
this.isStarting = null;
}
});
this.emit('play'); this.emit('play');
} }
@ -213,6 +227,7 @@ class SoundPlayer extends EventEmitter {
this.outputNode.stop(this.audioEngine.audioContext.currentTime + this.audioEngine.DECAY_TIME); this.outputNode.stop(this.audioEngine.audioContext.currentTime + this.audioEngine.DECAY_TIME);
this.isPlaying = false; this.isPlaying = false;
this.isStarting = null;
this.emit('stop'); this.emit('stop');
} }
@ -228,6 +243,7 @@ class SoundPlayer extends EventEmitter {
this.outputNode.stop(); this.outputNode.stop();
this.isPlaying = false; this.isPlaying = false;
this.isStarting = null;
this.emit('stop'); this.emit('stop');
} }