AudioContext: suspend() 方法
AudioContext 接口的 suspend() 方法会暂停音频上下文中的时间进程,暂时停止音频硬件访问,并在此过程中减少 CPU/电池使用量——如果你希望应用程序在一段时间内不使用音频上下文时关闭音频硬件,这将非常有用。
如果对 OfflineAudioContext 调用此方法,将抛出 INVALID_STATE_ERR 异常。
语法
js
suspend()
参数
无。
返回值
示例
以下代码片段取自我们的 AudioContext 状态演示(在线查看)。当点击 suspend/resume 按钮时,会查询 AudioContext.state——如果状态是 running,则调用 suspend();如果状态是 suspended,则调用 resume()。在每种情况下,一旦 Promise 解析,按钮的文本标签都会相应更新。
js
susResBtn.onclick = () => {
if (audioCtx.state === "running") {
audioCtx.suspend().then(() => {
susResBtn.textContent = "Resume context";
});
} else if (audioCtx.state === "suspended") {
audioCtx.resume().then(() => {
susResBtn.textContent = "Suspend context";
});
}
};
规范
| 规范 |
|---|
| Web Audio API # dom-audiocontext-suspend |
浏览器兼容性
加载中…