1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2025-01-20 02:21:25 +01:00

Add blurred backgroud for subtitles

This commit is contained in:
ssssobek 2024-03-10 20:14:48 +01:00
parent 9409922efd
commit e09c04b57b
6 changed files with 39 additions and 0 deletions

View file

@ -533,6 +533,7 @@
}, },
"subtitles": { "subtitles": {
"backgroundLabel": "Background opacity", "backgroundLabel": "Background opacity",
"backgroundBlurLabel": "Background blur",
"colorLabel": "Color", "colorLabel": "Color",
"previewQuote": "I must not fear. Fear is the mind-killer.", "previewQuote": "I must not fear. Fear is the mind-killer.",
"textSizeLabel": "Text size", "textSizeLabel": "Text size",

View file

@ -525,6 +525,7 @@
}, },
"subtitles": { "subtitles": {
"backgroundLabel": "Krycie tła", "backgroundLabel": "Krycie tła",
"backgroundBlurLabel": "Rozmycie tła",
"colorLabel": "Kolor", "colorLabel": "Kolor",
"previewQuote": "Nie wolno mi się bać. Strach zabija myślenie.", "previewQuote": "Nie wolno mi się bać. Strach zabija myślenie.",
"textSizeLabel": "Rozmiar czcionki", "textSizeLabel": "Rozmiar czcionki",

View file

@ -262,6 +262,18 @@ export function CaptionSettingsView({ id }: { id: string }) {
value={styling.backgroundOpacity * 100} value={styling.backgroundOpacity * 100}
textTransformer={(s) => `${s}%`} textTransformer={(s) => `${s}%`}
/> />
<CaptionSetting
label={t("settings.subtitles.backgroundBlurLabel")}
max={64}
min={0}
onChange={(v) =>
updateStyling({
backgroundBlur: Math.round(v / 4) * 4,
})
}
value={styling.backgroundBlur}
textTransformer={(s) => `${s}px`}
/>
<CaptionSetting <CaptionSetting
label={t("settings.subtitles.textSizeLabel")} label={t("settings.subtitles.textSizeLabel")}
max={200} max={200}

View file

@ -55,6 +55,10 @@ export function CaptionCue({
color: styling.color, color: styling.color,
fontSize: `${(1.5 * styling.size).toFixed(2)}em`, fontSize: `${(1.5 * styling.size).toFixed(2)}em`,
backgroundColor: `rgba(0,0,0,${styling.backgroundOpacity.toFixed(2)})`, backgroundColor: `rgba(0,0,0,${styling.backgroundOpacity.toFixed(2)})`,
backdropFilter:
styling.backgroundBlur !== 0
? `blur(${styling.backgroundBlur}px)`
: "none",
}} }}
> >
<span <span

View file

@ -92,6 +92,19 @@ export function CaptionsPart(props: {
value={props.styling.backgroundOpacity * 100} value={props.styling.backgroundOpacity * 100}
textTransformer={(s) => `${s}%`} textTransformer={(s) => `${s}%`}
/> />
<CaptionSetting
label={t("settings.subtitles.backgroundBlurLabel")}
max={64}
min={0}
onChange={(v) =>
props.setStyling({
...props.styling,
backgroundBlur: Math.round(v / 4) * 4,
})
}
value={props.styling.backgroundBlur}
textTransformer={(s) => `${s}px`}
/>
<CaptionSetting <CaptionSetting
label={t("settings.subtitles.textSizeLabel")} label={t("settings.subtitles.textSizeLabel")}
max={200} max={200}

View file

@ -17,6 +17,11 @@ export interface SubtitleStyling {
* background opacity, ranges between 0 and 1 * background opacity, ranges between 0 and 1
*/ */
backgroundOpacity: number; backgroundOpacity: number;
/**
* background blur, ranges between 0 and 64
*/
backgroundBlur: number;
} }
export interface SubtitleStore { export interface SubtitleStore {
@ -51,6 +56,7 @@ export const useSubtitleStore = create(
color: "#ffffff", color: "#ffffff",
backgroundOpacity: 0.5, backgroundOpacity: 0.5,
size: 1, size: 1,
backgroundBlur: 0,
}, },
resetSubtitleSpecificSettings() { resetSubtitleSpecificSettings() {
set((s) => { set((s) => {
@ -62,6 +68,8 @@ export const useSubtitleStore = create(
set((s) => { set((s) => {
if (newStyling.backgroundOpacity !== undefined) if (newStyling.backgroundOpacity !== undefined)
s.styling.backgroundOpacity = newStyling.backgroundOpacity; s.styling.backgroundOpacity = newStyling.backgroundOpacity;
if (newStyling.backgroundBlur !== undefined)
s.styling.backgroundBlur = newStyling.backgroundBlur;
if (newStyling.color !== undefined) if (newStyling.color !== undefined)
s.styling.color = newStyling.color.toLowerCase(); s.styling.color = newStyling.color.toLowerCase();
if (newStyling.size !== undefined) if (newStyling.size !== undefined)