Die Web Audio API fügt verschiedene AudioBuffers an / verkettet sie und spielt sie als einen Song ab

Ich habe mit der Web-Audio-API gespielt und habe versucht, mehrere Teile eines Songs zu laden und sie an einen neuen ArrayBuffer anzuhängen. Verwenden Sie dann diesen ArrayBuffer, um alle Teile als einen Song abzuspielen. Im folgenden Beispiel verwende ich dieselben Songdaten (das ist eine kleine Schleife) anstelle verschiedener Teile eines Songs.

Das Problem ist, dass es immer noch nur einmal statt zweimal abgespielt wird und ich nicht weiß warum.

Songs herunterladen

function init() {

  /**
   * Appends two ArrayBuffers into a new one.
   * 
   * @param {ArrayBuffer} buffer1 The first buffer.
   * @param {ArrayBuffer} buffer2 The second buffer.
   */
  function appendBuffer(buffer1, buffer2) {
    var tmp = new Uint8Array(buffer1.byteLength + buffer2.byteLength);
    tmp.set( new Uint8Array(buffer1), 0);
    tmp.set( new Uint8Array(buffer2), buffer1.byteLength);
    return tmp;
  }

  /**
   * Loads a song
   * 
   * @param {String} url The url of the song.
   */
  function loadSongWebAudioAPI(url) {
    var request = new XMLHttpRequest();
    var context = new webkitAudioContext();

    request.open('GET', url, true);
    request.responseType = 'arraybuffer';

    /**
     * Appends two ArrayBuffers into a new one.
     * 
     * @param {ArrayBuffer} data The ArrayBuffer that was loaded.
     */
    function play(data) {
      // Concatenate the two buffers into one.
      var a = appendBuffer(data, data);
      var buffer = a.buffer;
      var audioSource = context.createBufferSource();
      audioSource.connect(context.destination);

      //decode the loaded data
      context.decodeAudioData(buffer, function(buf) {
        console.log('The buffer', buf);
        audioSource.buffer = buf;
        audioSource.noteOn(0);
        audioSource.playbackRate.value = 1;
      });

    };

    // When the song is loaded asynchronously try to play it.
    request.onload = function() {
      play(request.response);
    }

    request.send();
  }


  loadSongWebAudioAPI('http://localhost:8282/loop.mp3');
}

window.addEventListener('load',init,false);

Antworten auf die Frage(2)

Ihre Antwort auf die Frage