From 2160df0eac2820070e014fa21eb2955bccdd9d91 Mon Sep 17 00:00:00 2001 From: Evert-R Date: Sun, 8 Oct 2023 13:50:52 +0200 Subject: [PATCH] Move preload component to playback.js --- frontend/src/components/Playback/Autoplay.js | 134 +++++++------------ frontend/src/components/Playback/Playback.js | 70 +++++----- frontend/src/components/Preload/Preload.js | 49 +++++-- frontend/src/util/webAudio.js | 2 +- 4 files changed, 120 insertions(+), 135 deletions(-) diff --git a/frontend/src/components/Playback/Autoplay.js b/frontend/src/components/Playback/Autoplay.js index c5bead82c..f3bdf985b 100644 --- a/frontend/src/components/Playback/Autoplay.js +++ b/frontend/src/components/Playback/Autoplay.js @@ -2,24 +2,15 @@ import React, { useRef, useState, useEffect } from "react"; import * as audio from "../../util/audio"; import * as webAudio from "../../util/webAudio"; -import { MEDIA_ROOT } from "../../config"; import Circle from "../Circle/Circle"; import ListenCircle from "../ListenCircle/ListenCircle"; -import Preload from "../Preload/Preload"; - -const PRELOAD = "PRELOAD"; -const RECOGNIZE = "RECOGNIZE"; - const AutoPlay = ({instruction, preloadMessage, onPreloadReady, playConfig, sections, time, startedPlaying, finishedPlaying, responseTime, className=''}) => { // player state - const [state, setState] = useState({ view: RECOGNIZE }); + const running = useRef(playConfig.auto_play); - const setView = (view, data = {}) => { - setState({ view, ...data }); - } - + const section = sections[0]; const onCircleTimerTick = (t) => { @@ -27,90 +18,61 @@ const AutoPlay = ({instruction, preloadMessage, onPreloadReady, playConfig, sect }; // Handle view logic - useEffect(() => { - switch (state.view) { - case RECOGNIZE: - let latency = 0; - // Play audio at start time - if (!playConfig.mute) { - if (playConfig.play_method === 'BUFFER' && !playConfig.external_audio) { - console.log('Autoplay buffer'); - latency = webAudio.getTotalLatency(); - webAudio.playBufferFrom(section.id, 0, Math.max(0, playConfig.playhead)); - } else { - console.log('Autoplay HTML audio') - audio.playFrom(Math.max(0, playConfig.playhead)); - } - } - setTimeout(startedPlaying(), latency); - break; - default: - // nothing + useEffect(() => { + let latency = 0; + // Play audio at start time + if (!playConfig.mute) { + if (playConfig.play_method === 'BUFFER' && !playConfig.external_audio) { + console.log('Autoplay buffer'); + latency = webAudio.getTotalLatency(); + webAudio.playBufferFrom(section.id, 0, Math.max(0, playConfig.playhead)); + } else { + console.log('Autoplay HTML audio') + audio.playFrom(Math.max(0, playConfig.playhead)); + } + setTimeout(startedPlaying(), latency); } + }, [playConfig, startedPlaying]); - // Clean up - return () => { - audio.pause(); - }; - }, [state, playConfig, startedPlaying]); - - - // Render component based on view - switch (state.view) { - case PRELOAD: - return ( - { - setView(RECOGNIZE); - onPreloadReady(); + // Render component + return ( +
+
+ { + // Stop audio + finishedPlaying(); }} /> - ); - case RECOGNIZE: - return ( -
-
- + {playConfig.show_animation + ? { - // Stop audio - finishedPlaying(); - }} + histogramRunning={running} + countDownRunning={running} /> -
- {playConfig.show_animation - ? - :
- -
- } + :
+
-
-
- {/* Instruction */} - {instruction && (
-

{instruction}

-
)}
- ) - default: - return
Unknown view: {state.view}
; - } +
+ {/* Instruction */} + {instruction && (
+

{instruction}

+
)} +
+
+ ) } export default AutoPlay; diff --git a/frontend/src/components/Playback/Playback.js b/frontend/src/components/Playback/Playback.js index 4aa39c176..edd1028d1 100644 --- a/frontend/src/components/Playback/Playback.js +++ b/frontend/src/components/Playback/Playback.js @@ -9,13 +9,14 @@ import PlayButton from "../PlayButton/PlayButton"; import MultiPlayer from "./MultiPlayer"; import SpectrogramPlayer from "./SpectrogramPlayer"; import MatchingPairs from "./MatchingPairs"; -import Loading from "../Loading/Loading"; +import Preload from "../Preload/Preload"; export const AUTOPLAY = "AUTOPLAY"; export const BUTTON = "BUTTON"; export const MULTIPLAYER = "MULTIPLAYER"; export const SPECTROGRAM = "SPECTROGRAM"; export const MATCHINGPAIRS = "MATCHINGPAIRS"; +export const PRELOAD = "PRELOAD"; const Playback = ({ playerType, @@ -31,10 +32,13 @@ const Playback = ({ startedPlaying, finishedPlaying, }) => { - const [sectionsLoaded, setSectionsLoaded] = useState(null); const [playerIndex, setPlayerIndex] = useState(-1); const lastPlayerIndex = useRef(-1); const activeAudioEndedListener = useRef(null); + const [state, setState] = useState({ view: PRELOAD }); + const setView = (view, data = {}) => { + setState({ view, ...data }); + } // Keep track of which player has played, in a an array of player indices const [hasPlayed, setHasPlayed] = useState([]); @@ -50,31 +54,6 @@ const Playback = ({ prevPlayerIndex.current = parseInt(playerIndex); }, [playerIndex]); - - useEffect(() => { - if (playConfig.play_method === 'BUFFER' && !playConfig.external_audio) { - // Use Web-audio and preload sections in buffers - sections.map((section, index) => { - // Clear buffers if this is the first section - if (index === 0) { - webAudio.clearBuffers(); - } - return webAudio.loadBuffer(section.id, MEDIA_ROOT + section.url, () => { - if (index === (sections.length-1)) { - setSectionsLoaded(1); - } - }); - }) - } else { - if (playConfig.external_audio) { - webAudio.closeWebAudio(); - } - setSectionsLoaded(1); - // Preload first section - return audio.loadUntilAvailable(MEDIA_ROOT + sections[0].url, () => {}); - } - }, [sections]); - // Cancel events const cancelAudioListeners = useCallback(() => { activeAudioEndedListener.current && activeAudioEndedListener.current(); @@ -97,7 +76,6 @@ const Playback = ({ } else { finishedPlaying(); } - }, []); // Play audio @@ -106,42 +84,46 @@ const Playback = ({ let latency = 0; if (playConfig.play_method === 'BUFFER' && !playConfig.external_audio) { console.log('Play buffer (local)'); + // Determine latency for current audio device latency = webAudio.getTotalLatency(); + // Store player index setPlayerIndex(index); + // Determine if audio should be played if (playConfig.mute) { setPlayerIndex(-1); webAudio.stopBuffer(); return; } - // Volume 1 - // audio.setVolume(1); // Cancel active events cancelAudioListeners(); - - // Play audio - // audio.playFrom(Math.max(0, playConfig.playhead || 0)); + // Play audio webAudio.playBuffer(sections[index].id); + // listen for active audio events activeAudioEndedListener.current = webAudio.listenOnce("ended", onAudioEnded); } else { console.log('Play HTML audo') + // Only initialize webaudio if section is local if (!playConfig.external_audio) { latency = webAudio.initWebAudio(); } + // Store player index setPlayerIndex(index); + // Determine if audio should be played if (playConfig.mute) { setPlayerIndex(-1); audio.pause(); return; } + // Volume 1 audio.setVolume(1); @@ -178,6 +160,7 @@ const Playback = ({ playAudio(index); return; } + // Stop playback if (lastPlayerIndex.current === index) { webAudio.suspend(); @@ -191,6 +174,7 @@ const Playback = ({ if (playConfig.external_audio) { // webAudio.closeWebAudio(); } + // Play section from