createOscillator noteOn 不工作
createOscillator noteOn not working
我从一个网站(目前不记得是从哪里)得到这段代码的,但它已经停止工作了。
我用它来播放音调。
是我做错了什么还是最近 Chrome 发生了变化?
Play = (function () {
var ctx = new(window.audioContext || window.webkitAudioContext);
return function (duration, freq, finishedCallback) {
duration = +duration;
if (typeof finishedCallback != "function") {
finishedCallback = function () {};
}
var osc = ctx.createOscillator();
osc.type = 0;
osc.connect(ctx.destination);
osc.frequency.value = freq;
osc.noteOn(0);
setTimeout(
function () {
osc.noteOff(0);
finishedCallback();
}
,duration
);
};
})();
Play(50,500)
这里有两个问题 - 没有 audioContext
(小 "a",但目前不影响 Chrome)。只需将其更改为:
var ctx = new (window.AudioContext || window.webkitAudioContext);
添加对 start() 的支持,这是更新的方法。有几种方法可以做到这一点,这里是一个基本的例子:
if (osc.start) {
osc.start(0);
}
else {
osc.noteOn(0);
}
(当然还有 osc.noteOff(0)
➜ osc.stop(0)
)
Play = (function() {
var ctx = new(AudioContext || webkitAudioContext);
return function(duration, freq, finishedCallback) {
duration = +duration;
if (typeof finishedCallback != "function") {
finishedCallback = function() {};
}
var osc = ctx.createOscillator();
osc.type = 0;
osc.connect(ctx.destination);
osc.frequency.value = freq;
if (osc.start) osc.start();
else osc.noteOn(0);
setTimeout(
function() {
if (osc.stop) osc.stop(0);
else osc.noteOff(0);
finishedCallback();
}, duration
);
};
})();
Play(50, 500)
我从一个网站(目前不记得是从哪里)得到这段代码的,但它已经停止工作了。
我用它来播放音调。
是我做错了什么还是最近 Chrome 发生了变化?
Play = (function () {
var ctx = new(window.audioContext || window.webkitAudioContext);
return function (duration, freq, finishedCallback) {
duration = +duration;
if (typeof finishedCallback != "function") {
finishedCallback = function () {};
}
var osc = ctx.createOscillator();
osc.type = 0;
osc.connect(ctx.destination);
osc.frequency.value = freq;
osc.noteOn(0);
setTimeout(
function () {
osc.noteOff(0);
finishedCallback();
}
,duration
);
};
})();
Play(50,500)
这里有两个问题 - 没有 audioContext
(小 "a",但目前不影响 Chrome)。只需将其更改为:
var ctx = new (window.AudioContext || window.webkitAudioContext);
添加对 start() 的支持,这是更新的方法。有几种方法可以做到这一点,这里是一个基本的例子:
if (osc.start) {
osc.start(0);
}
else {
osc.noteOn(0);
}
(当然还有 osc.noteOff(0)
➜ osc.stop(0)
)
Play = (function() {
var ctx = new(AudioContext || webkitAudioContext);
return function(duration, freq, finishedCallback) {
duration = +duration;
if (typeof finishedCallback != "function") {
finishedCallback = function() {};
}
var osc = ctx.createOscillator();
osc.type = 0;
osc.connect(ctx.destination);
osc.frequency.value = freq;
if (osc.start) osc.start();
else osc.noteOn(0);
setTimeout(
function() {
if (osc.stop) osc.stop(0);
else osc.noteOff(0);
finishedCallback();
}, duration
);
};
})();
Play(50, 500)