feat: Sampler can be loaded with ToneAudioBuffers

This commit is contained in:
Yotam Mann 2020-05-11 15:37:14 -04:00
parent 49c6c79e46
commit 368a7f43cb
2 changed files with 53 additions and 21 deletions

View file

@ -6,6 +6,7 @@ import { InstrumentTest } from "test/helper/InstrumentTests";
import { atTime, Offline } from "test/helper/Offline";
import { ToneAudioBuffer } from "Tone/core/context/ToneAudioBuffer";
import { Sampler } from "Tone/instrument/Sampler";
import { ToneAudioBuffers } from "Tone/core/context/ToneAudioBuffers";
describe("Sampler", () => {
@ -144,6 +145,33 @@ describe("Sampler", () => {
}, 0.3);
});
it("can be constructed with a ToneAudioBuffers in an object", () => {
const sampler = new Sampler({
urls: new ToneAudioBuffers({
A4: A4_buffer
})
});
sampler.dispose();
});
it("can be constructed with unloaded a ToneAudioBuffers", (done) => {
const sampler = new Sampler({
urls: new ToneAudioBuffers({
A4: "./audio/sine.wav",
}, () => {
sampler.dispose();
done();
})
});
});
it("can be constructed with ToneAudioBuffers", () => {
const sampler = new Sampler(new ToneAudioBuffers({
A4: A4_buffer,
}));
sampler.dispose();
});
});
context("Makes sound", () => {

View file

@ -23,7 +23,7 @@ export interface SamplerOptions extends InstrumentOptions {
onerror: (error: Error) => void;
baseUrl: string;
curve: ToneBufferSourceCurve;
urls: SamplesMap;
urls: SamplesMap | ToneAudioBuffers;
}
/**
@ -102,6 +102,9 @@ export class Sampler extends Instrument<SamplerOptions> {
super(optionsFromArguments(Sampler.getDefaults(), arguments, ["urls", "onload", "baseUrl"], "urls"));
const options = optionsFromArguments(Sampler.getDefaults(), arguments, ["urls", "onload", "baseUrl"], "urls");
if (options.urls instanceof ToneAudioBuffers) {
this._buffers = options.urls;
} else {
const urlMap = {};
Object.keys(options.urls).forEach((note) => {
const noteNumber = parseInt(note, 10);
@ -123,6 +126,7 @@ export class Sampler extends Instrument<SamplerOptions> {
baseUrl: options.baseUrl,
onerror: options.onerror,
});
}
this.attack = options.attack;
this.release = options.release;
this.curve = options.curve;