AudioBufferSourceNode: loop 屬性
AudioBufferSourceNode 介面的 loop 屬性是一個布林值,指示在到達 AudioBuffer 結尾時是否必須重新播放音訊資源。
loop 屬性的預設值為 false。
值
如果啟用了迴圈,則返回 true;否則返回 false。
啟用迴圈後,當呼叫 start() 時,聲音將從指定的開始時間開始播放。當到達 loopEnd 屬性指定的到達時間時,播放將從 loopStart 指定的時間繼續。
示例
設定 loop
在此示例中,當用戶按下“播放”按鈕時,我們將載入一個音軌,對其進行解碼,然後將其放入 AudioBufferSourceNode 中。
然後,該示例將 loop 屬性設定為 true,以便音軌迴圈播放。
使用者可以使用 range 控制元件 來設定 loopStart 和 loopEnd 屬性。
js
let audioCtx;
let buffer;
let source;
const play = document.getElementById("play");
const stop = document.getElementById("stop");
const loopstartControl = document.getElementById("loopstart-control");
const loopstartValue = document.getElementById("loopstart-value");
const loopendControl = document.getElementById("loopend-control");
const loopendValue = document.getElementById("loopend-value");
async function loadAudio() {
try {
// Load an audio file
const response = await fetch("rnb-lofi-melody-loop.wav");
// Decode it
buffer = await audioCtx.decodeAudioData(await response.arrayBuffer());
const max = Math.floor(buffer.duration);
loopstartControl.setAttribute("max", max);
loopendControl.setAttribute("max", max);
} catch (err) {
console.error(`Unable to fetch the audio file. Error: ${err.message}`);
}
}
play.addEventListener("click", async () => {
if (!audioCtx) {
audioCtx = new AudioContext();
await loadAudio();
}
source = audioCtx.createBufferSource();
source.buffer = buffer;
source.connect(audioCtx.destination);
source.loop = true;
source.loopStart = loopstartControl.value;
source.loopEnd = loopendControl.value;
source.start();
play.disabled = true;
stop.disabled = false;
loopstartControl.disabled = false;
loopendControl.disabled = false;
});
stop.addEventListener("click", () => {
source.stop();
play.disabled = false;
stop.disabled = true;
loopstartControl.disabled = true;
loopendControl.disabled = true;
});
loopstartControl.addEventListener("input", () => {
source.loopStart = loopstartControl.value;
loopstartValue.textContent = loopstartControl.value;
});
loopendControl.addEventListener("input", () => {
source.loopEnd = loopendControl.value;
loopendValue.textContent = loopendControl.value;
});
規範
| 規範 |
|---|
| Web Audio API # dom-audiobuffersourcenode-loop |
瀏覽器相容性
載入中…