var context = new window.AudioContext()
var request = cc.loader.getXMLHttpRequest();
request.open("GET", 'res/raw-assets/resources/audio/bgm.mp3', true);
request.responseType = "arraybuffer";
request.onload = function () {
context["decodeAudioData"](request.response, function(buffer){
//success
cc.log('success')
window.buffer = buffer
playBgm()
}, function(){
//error
});
};
request.onerror = function(){
//error
};
request.send();
function playBgm(){
var audio = context["createBufferSource"]();
audio.buffer = buffer;
var _volume = context['createGain']();
_volume['gain'].value = 1;
_volume['connect'](context['destination']);
audio["connect"](_volume);
audio.start(0)
}
在我的代码中,我加载了一个 mp3 文件并将其解码为 AudioBuffer(window.buffer) 然后我成功播放
但是它消耗了大约100MB的大量内存如何释放它们?我试过这样
audio.stop()
audio = null
window.buffer = null
//context.close()
//context = null
在 chrome 内存视图中
有时内存在大约 10 秒内释放
有时会在大约 1 分钟内释放
有时似乎永远不会释放
我想知道我的代码是否是释放音频缓冲区的正确方法?
我需要关闭 AudioContext 吗?