mirror of
https://github.com/doublespeakgames/adarkroom.git
synced 2026-05-28 00:01:54 +08:00
fix safari audio bug where error prevents leaving worldmap locations -- reveals another safari bug where decodeAudioData doesn't return a promise to start playing music immediately
This commit is contained in:
+20
-2
@@ -136,7 +136,9 @@ var AudioEngine = {
|
||||
var fadeTime = AudioEngine._audioContext.currentTime + AudioEngine.FADE_TIME * 2;
|
||||
|
||||
// fade out event music and stop
|
||||
if (AudioEngine._currentEventAudio) {
|
||||
if (AudioEngine._currentEventAudio &&
|
||||
AudioEngine._currentEventAudio.source &&
|
||||
AudioEngine._currentEventAudio.source.buffer) {
|
||||
var currentEventGainValue = AudioEngine._currentEventAudio.envelope.gain.value;
|
||||
AudioEngine._currentEventAudio.envelope.gain.cancelScheduledValues(AudioEngine._audioContext.currentTime);
|
||||
AudioEngine._currentEventAudio.envelope.gain.setValueAtTime(currentEventGainValue, AudioEngine._audioContext.currentTime);
|
||||
@@ -212,10 +214,26 @@ var AudioEngine = {
|
||||
return AudioEngine._getMissingAudioBuffer();
|
||||
}
|
||||
|
||||
return AudioEngine._audioContext.decodeAudioData(buffer, function (decodedData) {
|
||||
var decodeAudioDataPromise = AudioEngine._audioContext.decodeAudioData(buffer, function (decodedData) {
|
||||
AudioEngine.AUDIO_BUFFER_CACHE[src] = decodedData;
|
||||
return AudioEngine.AUDIO_BUFFER_CACHE[src];
|
||||
});
|
||||
|
||||
// Safari WebAudio does not return a promise based API for
|
||||
// decodeAudioData, so we need to fake it if we want to play
|
||||
// audio immediately on first fetch
|
||||
if (decodeAudioDataPromise) {
|
||||
return decodeAudioDataPromise;
|
||||
} else {
|
||||
return new Promise(function (resolve, reject) {
|
||||
var fakePromiseId = setInterval(function() {
|
||||
if (AudioEngine.AUDIO_BUFFER_CACHE[src]) {
|
||||
resolve(AudioEngine.AUDIO_BUFFER_CACHE[src]);
|
||||
clearInterval(fakePromiseId);
|
||||
}
|
||||
}, 20);
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
},
|
||||
|
||||
+9
-18
@@ -142,17 +142,10 @@
|
||||
});
|
||||
}
|
||||
|
||||
// Disable this for now
|
||||
// $('<span>')
|
||||
// .addClass('volume menuBtn')
|
||||
// .text(_('sound on.'))
|
||||
// .click(() => Engine.toggleVolume())
|
||||
// .appendTo(menu);
|
||||
|
||||
$('<span>')
|
||||
.addClass('volume menuBtn')
|
||||
.text(_('sound off.'))
|
||||
.click(Engine.toggleVolume)
|
||||
.text(_('sound on.'))
|
||||
.click(() => Engine.toggleVolume())
|
||||
.appendTo(menu);
|
||||
|
||||
$('<span>')
|
||||
@@ -222,7 +215,7 @@
|
||||
$.Dispatch('stateUpdate').subscribe(Engine.handleStateUpdates);
|
||||
|
||||
$SM.init();
|
||||
// AudioEngine.init(); Disable this for now
|
||||
AudioEngine.init();
|
||||
Notifications.init();
|
||||
Events.init();
|
||||
Room.init();
|
||||
@@ -246,24 +239,22 @@
|
||||
Engine.triggerHyperMode();
|
||||
}
|
||||
|
||||
// Disable this for now
|
||||
// Engine.toggleVolume(Boolean($SM.get('config.soundOn')));
|
||||
// if(!AudioEngine.isAudioContextRunning()){
|
||||
// document.addEventListener('click', Engine.resumeAudioContext, true);
|
||||
// }
|
||||
Engine.toggleVolume(Boolean($SM.get('config.soundOn')));
|
||||
if(!AudioEngine.isAudioContextRunning()){
|
||||
document.addEventListener('click', Engine.resumeAudioContext, true);
|
||||
}
|
||||
|
||||
Engine.saveLanguage();
|
||||
Engine.travelTo(Room);
|
||||
|
||||
// Disable this for now
|
||||
// setTimeout(notifyAboutSound, 3000);
|
||||
setTimeout(notifyAboutSound, 3000);
|
||||
|
||||
},
|
||||
resumeAudioContext: function () {
|
||||
AudioEngine.tryResumingAudioContext();
|
||||
|
||||
// turn on music!
|
||||
AudioEngine.setMasterVolume($SM.get('config.soundOn') ? 1.0 : 0.0, 0);
|
||||
AudioEngine.setMasterVolume($SM.get('config.soundOn') ? 1.0 : 0.0, 0);
|
||||
|
||||
document.removeEventListener('click', Engine.resumeAudioContext);
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user