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)