Skip to content

Commit

Permalink
Dubbing: Support space key to play/pause. v5.15.21
Browse files Browse the repository at this point in the history
  • Loading branch information
winlinvip committed Jul 28, 2024
1 parent 369c53c commit 77e6ee8
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 3 deletions.
1 change: 1 addition & 0 deletions DEVELOPER.md
Original file line number Diff line number Diff line change
Expand Up @@ -1284,6 +1284,7 @@ The following are the update records for the Oryx server.
* Dubbing: Support disable asr or translation. v5.15.19
* Dubbing: Fix bug when changing ASR segment size. v5.15.20
* Dubbing: Refine the window of text. [v5.15.20](https://github.com/ossrs/oryx/releases/tag/v5.15.20)
* Dubbing: Support space key to play/pause. v5.15.21
* v5.14:
* Merge features and bugfix from releases. v5.14.1
* Dubbing: Support VoD dubbing for multiple languages. [v5.14.2](https://github.com/ossrs/oryx/releases/tag/v5.14.2)
Expand Down
36 changes: 33 additions & 3 deletions ui/src/pages/ScenarioDubbing.js
Original file line number Diff line number Diff line change
Expand Up @@ -650,6 +650,27 @@ function DubbingUIControls({task, isFullscreen, setIsFullscreen, showHeader, set
function DubbingUISubtitles({task, playerRef, isFullscreen, showHeader, showASR, showTranslation, requesting, activeGroup, isPlayingAudio, playSegment, replaySegment, playGroup, rephraseGroup, mergeToGroup}) {
const {t} = useTranslation();

// Handle keydown event.
const userEventRef = React.useRef(null);
React.useEffect(() => {
const handleKeyDown = (e) => {
e.preventDefault();
if (e.code !== 'Space') return;
if (!e.target || !e.target.id || !e.target.id.startsWith('asr-group-')) return;
const index = e.target.id.split('-')[2];

const segment = task?.asr_response?.groups[index];
if (segment) playSegment(e, segment);
console.log(`user press code ${e.code},div is ${e.target.id}, index is ${index}, segment is ${segment?.id}`);
};

const container = userEventRef.current;
if (container) container.addEventListener('keydown', handleKeyDown);
return () => {
container && container.removeEventListener('keydown', handleKeyDown);
};
}, [userEventRef, task, playSegment]);

// How many groups to show when in the fullscreen.
const [historySegments, setHistorySegments] = React.useState(4);
React.useEffect(() => {
Expand Down Expand Up @@ -690,12 +711,21 @@ function DubbingUISubtitles({task, playerRef, isFullscreen, showHeader, showASR,
if (!isFullscreen) return;
if (!playerRef?.current) return;
if (!task?.asr_response?.groups?.length) return;
if (playerRef.current.paused) return;

let index = task?.asr_response?.groups?.findIndex(s => {
return s.start <= playerRef.current.currentTime && playerRef.current.currentTime <= s.end;
});
if (index === -1) return;

// Focus on the current playing group.
if (true) {
const divId = `asr-group-${index}`;
const target = document.querySelector(`div#${divId}`);
if (target) target.focus();
}

// Scroll to the appropriate group view.
let availableSegments = historySegments;
for (let i = index - 1; i >= 0 && availableSegments > 0; i--) {
availableSegments -= task?.asr_response?.groups[i]?.segments?.length;
Expand All @@ -711,10 +741,10 @@ function DubbingUISubtitles({task, playerRef, isFullscreen, showHeader, showASR,
return () => clearInterval(timer);
}, [playerRef, task, isPlayingAudio, isFullscreen, historySegments]);

return <>
return <div ref={userEventRef}>
{task?.asr_response?.groups?.map((g, index) => {
return (
<div id={`asr-group-${index}`} key={g.uuid}>
<div id={`asr-group-${index}`} key={g.uuid} tabIndex='0'>
<Card className='ai-dubbing-group'>
{showHeader && <>
<Card.Header
Expand Down Expand Up @@ -805,7 +835,7 @@ function DubbingUISubtitles({task, playerRef, isFullscreen, showHeader, showASR,
</div>
);
})}
</>;
</div>;
}

function DubbingStudioEditor({project, isFullscreen, setIsFullscreen}) {
Expand Down

0 comments on commit 77e6ee8

Please sign in to comment.