From 2e725e8cd00cd0e3964cba2189ba8113a868a74e Mon Sep 17 00:00:00 2001 From: Jesse Date: Thu, 30 Sep 2021 11:23:57 -0400 Subject: [PATCH] Only step the queue of voicingManager is initialized, see https://github.com/phetsims/scenery/issues/1288 --- js/accessibility/voicing/voicingManager.js | 33 ++++++++++++---------- 1 file changed, 18 insertions(+), 15 deletions(-) diff --git a/js/accessibility/voicing/voicingManager.js b/js/accessibility/voicing/voicingManager.js index fc55d2a..185ca4e 100644 --- a/js/accessibility/voicing/voicingManager.js +++ b/js/accessibility/voicing/voicingManager.js @@ -248,23 +248,26 @@ class VoicingManager extends Announcer { */ stepQueue( dt ) { - // increase the time each element has spent in queue - for ( let i = 0; i < this.voicingQueue.length; i++ ) { - const voicingQueueElement = this.voicingQueue[ i ]; - voicingQueueElement.timeInQueue += dt * 1000; - } + if ( this.initialized ) { - // This manages the case where the 'end' event came from an utterance, but there was no next utterance ready to be - // spoken. Make sure that we support anytime that utterances are ready but there is no "end" callback that would - // trigger `alertNow()`. - if ( !this.getSynth().speaking && this.voicingQueue.length > 0 ) { - this.alertNow(); - } + // increase the time each element has spent in queue + for ( let i = 0; i < this.voicingQueue.length; i++ ) { + const voicingQueueElement = this.voicingQueue[ i ]; + voicingQueueElement.timeInQueue += dt * 1000; + } - // If our queue is empty and the synth isn't speaking, then clear safariWorkaroundUtterances to prevent memory leak. - // This handles any uncertain cases where the "end" callback on SpeechSynthUtterance isn't called. - if ( !this.getSynth().speaking && this.voicingQueue.length === 0 && this.safariWorkaroundUtterances.length > 0 ) { - this.safariWorkaroundUtterances = []; + // This manages the case where the 'end' event came from an utterance, but there was no next utterance ready to be + // spoken. Make sure that we support anytime that utterances are ready but there is no "end" callback that would + // trigger `alertNow()`. + if ( !this.getSynth().speaking && this.voicingQueue.length > 0 ) { + this.alertNow(); + } + + // If our queue is empty and the synth isn't speaking, then clear safariWorkaroundUtterances to prevent memory leak. + // This handles any uncertain cases where the "end" callback on SpeechSynthUtterance isn't called. + if ( !this.getSynth().speaking && this.voicingQueue.length === 0 && this.safariWorkaroundUtterances.length > 0 ) { + this.safariWorkaroundUtterances = []; + } } }