Files
omni-tools/src/pages/tools/video/flip/service.ts
2025-05-22 16:58:42 +02:00

44 lines
1.1 KiB
TypeScript

import { FFmpeg } from '@ffmpeg/ffmpeg';
import { fetchFile } from '@ffmpeg/util';
import { FlipOrientation } from './types';
const ffmpeg = new FFmpeg();
export async function flipVideo(
input: File,
orientation: FlipOrientation
): Promise<File> {
if (!ffmpeg.loaded) {
await ffmpeg.load({
wasmURL:
'https://cdn.jsdelivr.net/npm/@ffmpeg/core@0.12.9/dist/esm/ffmpeg-core.wasm'
});
}
const inputName = 'input.mp4';
const outputName = 'output.mp4';
await ffmpeg.writeFile(inputName, await fetchFile(input));
const flipMap: Record<FlipOrientation, string> = {
horizontal: 'hflip',
vertical: 'vflip'
};
const flipFilter = flipMap[orientation];
const args = ['-i', inputName];
if (flipFilter) {
args.push('-vf', flipFilter);
}
args.push('-c:v', 'libx264', '-preset', 'ultrafast', outputName);
await ffmpeg.exec(args);
const flippedData = await ffmpeg.readFile(outputName);
return new File(
[new Blob([flippedData], { type: 'video/mp4' })],
`${input.name.replace(/\.[^/.]+$/, '')}_flipped.mp4`,
{ type: 'video/mp4' }
);
}