From cbd26175878fc86b03e147c6f270d038874837de Mon Sep 17 00:00:00 2001 From: naourass Date: Sun, 3 Nov 2024 05:17:15 +0100 Subject: [PATCH 1/2] Fix: smooth 30 fps output --- playgrounds/app/src/components/Editor.tsx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/playgrounds/app/src/components/Editor.tsx b/playgrounds/app/src/components/Editor.tsx index 5cb3d80..aa3d620 100644 --- a/playgrounds/app/src/components/Editor.tsx +++ b/playgrounds/app/src/components/Editor.tsx @@ -53,7 +53,7 @@ import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '. import { Accordion, AccordionContent, AccordionItem, AccordionTrigger } from './ui/accordion' const animationSeconds = 1 -const animationFPS = 10 +const animationFPS = 30 const animationFrames = animationSeconds * animationFPS const supportedFontFamilies: { name: string }[] = [ @@ -208,7 +208,7 @@ export default function Editor(props: EditorProps) { middleFrames.push(i) } - const pauseFrameLength = 15 + const pauseFrameLength = 60 const firstFrames = new Array(pauseFrameLength).fill(0) const lastFrames = new Array(pauseFrameLength).fill(animationFrames) @@ -260,7 +260,7 @@ export default function Editor(props: EditorProps) { format: 'blob', width: canvasFrames[0].width, height: canvasFrames[0].height, - frames: canvasFrames, + frames: canvasFrames.map(el => ({ data: el.data.buffer, delay: (animationSeconds * 1000) / animationFPS})) }) const dataUrl = await blobToDataURL(blob) From bb82a48a633195ea4603c7645f403208d0ba79b7 Mon Sep 17 00:00:00 2001 From: cmgriffing Date: Sun, 3 Nov 2024 21:00:52 +0000 Subject: [PATCH 2/2] style: auto-format with action --- playgrounds/app/src/components/Editor.tsx | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/playgrounds/app/src/components/Editor.tsx b/playgrounds/app/src/components/Editor.tsx index aa3d620..dadbff5 100644 --- a/playgrounds/app/src/components/Editor.tsx +++ b/playgrounds/app/src/components/Editor.tsx @@ -260,7 +260,10 @@ export default function Editor(props: EditorProps) { format: 'blob', width: canvasFrames[0].width, height: canvasFrames[0].height, - frames: canvasFrames.map(el => ({ data: el.data.buffer, delay: (animationSeconds * 1000) / animationFPS})) + frames: canvasFrames.map(el => ({ + data: el.data.buffer, + delay: (animationSeconds * 1000) / animationFPS, + })), }) const dataUrl = await blobToDataURL(blob)