From 45718b17d91544bd653eab475acc1902b6185f85 Mon Sep 17 00:00:00 2001 From: rupel <23055682+rupel190@users.noreply.github.com> Date: Fri, 2 Aug 2024 03:00:35 +0200 Subject: [PATCH] Recorder resumes if start() is called in paused state --- Tone/component/channel/Recorder.test.ts | 13 +++++++++++++ Tone/component/channel/Recorder.ts | 9 ++++++--- 2 files changed, 19 insertions(+), 3 deletions(-) diff --git a/Tone/component/channel/Recorder.test.ts b/Tone/component/channel/Recorder.test.ts index df2e025d..157e4d52 100644 --- a/Tone/component/channel/Recorder.test.ts +++ b/Tone/component/channel/Recorder.test.ts @@ -68,6 +68,19 @@ describe("Recorder", () => { rec.dispose(); }); + it("can be resumed after pausing", async () => { + const rec = new Recorder(); + rec.start(); + expect(rec.state).to.equal("started"); + await wait(100); + rec.pause(); + expect(rec.state).to.equal("paused"); + await wait(100); + rec.start(); + expect(rec.state).to.equal("started"); + rec.dispose(); + }); + it("can be stopped after starting", async () => { const rec = new Recorder(); rec.start(); diff --git a/Tone/component/channel/Recorder.ts b/Tone/component/channel/Recorder.ts index 103d0503..19fef6c5 100644 --- a/Tone/component/channel/Recorder.ts +++ b/Tone/component/channel/Recorder.ts @@ -107,7 +107,7 @@ export class Recorder extends ToneAudioNode { } /** - * Start the Recorder. Returns a promise which resolves + * Start/Resume the Recorder. Returns a promise which resolves * when the recorder has started. */ async start() { @@ -121,8 +121,11 @@ export class Recorder extends ToneAudioNode { this._recorder.addEventListener("start", handleStart, false); }); - - this._recorder.start(); + if(this.state === "stopped") { + this._recorder.start(); + } else { + this._recorder.resume(); + } return await startPromise; }