我正在使用用 JavaScript 编写的交叉淡入淡出播放列表。它依赖于 Web 音频 API。该代码使用一个名为 shared.js 的共享类来建立网络音频上下文。
我的问题是我的 VOLUME 功能仅在 ONE SONG 在播放列表缓冲区中时才有效。如果我添加两首或更多歌曲,音量功能没有响应。
为什么会这样?请查看我的代码。谢谢!!
/*
(1) Below is my script: 'js/crossfade-playlist-sample.js'
(2) I am also using 'shared.js' from (http://webaudioapi.com/static/js/shared.js)
My version of 'crossfade-playlist-sample.js' works.
It is the funciton changeVolume() which fails to work when MORE THAN ONE SONG is in the Buffer
created with loadSounds();
*/
function CrossfadePlaylistSample() {
this.FADE_TIME = 1; // Seconds
this.isPlaying = false;
loadSounds(this, {
song1: 'http://localhost:63329/js/song1.mp3',
song2: 'http://localhost:63329/js/song2.mp3'
});
};
var source, gainNode, wetGain, buffer, duration, info;
function play() {
playHelper([this.song1, this.song2], 1, 1);
function createSource(buffer) {
gainNode = context.createGain();
wetGain = context.createGain();
source = context.createBufferSource();
source.buffer = this.buffer;
source.connect(wetGain); // Connect source to gain nodes.
wetGain.connect(gainNode); // Connect source to gain nodes.
gainNode.connect(context.destination); // Connect gain to destination.
return {
source: source,
gainNode: gainNode,
wetGain: wetGain
};
}
function playHelper(buffers, iterations, fadeTime) {
var currTime = context.currentTime;
for (var i = 0; i < iterations; i++) {
// For each buffer, schedule its playback in the future.
for (var j = 0; j < buffers.length; j++) {
buffer = buffers[j];
duration = buffer.duration;
info = createSource(buffer);
source = info.source;
gainNode = info.gainNode;
// Fade it in.
gainNode.gain.linearRampToValueAtTime(0, currTime);
gainNode.gain.linearRampToValueAtTime(1, currTime + fadeTime);
// Then fade it out.
gainNode.gain.linearRampToValueAtTime(1, currTime + duration - fadeTime);
gainNode.gain.linearRampToValueAtTime(0, currTime + duration);
// Play the track now.
source[source.start ? 'start' : 'noteOn'](currTime);
// Increment time for the next iteration.
currTime += duration - fadeTime;
}
}
}
};
function changeVolume(element) {
var volume = element.value;
var fraction = parseInt(element.value) / parseInt(element.max);
wetGain.gain.value = fraction * fraction;
};
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script src="js/shared.js"></script>
<script src="js/crossfade-playlist-sample.js"></script>
<script>
CrossfadePlaylistSample();
</script>
</head>
<body style="color: navajowhite;">
<input type="button" onclick="play();" value="Play" />
<input type="range" min="0" max="100" value="100" oninput="changeVolume(this);" onchange="rangevalue.value=value;" />
</body>
</html>