This commit is contained in:
syuilo 2025-05-29 18:19:31 +09:00
parent c8f0833da1
commit 0ead9c0877
5 changed files with 156 additions and 0 deletions

8
locales/index.d.ts vendored
View File

@ -12112,6 +12112,14 @@ export interface Locale extends ILocale {
*
*/
"distort": string;
/**
*
*/
"threshold": string;
/**
*
*/
"zoomLines": string;
};
};
}

View File

@ -3246,3 +3246,5 @@ _imageEffector:
colorClamp: "色の圧縮"
colorClampAdvanced: "色の圧縮(高度)"
distort: "歪み"
threshold: "二値化"
zoomLines: "集中線"

View File

@ -11,7 +11,9 @@ import { FX_glitch } from './fxs/glitch.js';
import { FX_grayscale } from './fxs/grayscale.js';
import { FX_invert } from './fxs/invert.js';
import { FX_mirror } from './fxs/mirror.js';
import { FX_threshold } from './fxs/threshold.js';
import { FX_watermarkPlacement } from './fxs/watermarkPlacement.js';
import { FX_zoomLines } from './fxs/zoomLines.js';
import type { ImageEffectorFx } from './ImageEffector.js';
export const FXS = [
@ -24,4 +26,6 @@ export const FXS = [
FX_colorClamp,
FX_colorClampAdvanced,
FX_distort,
FX_threshold,
FX_zoomLines,
] as const satisfies ImageEffectorFx<string, any>[];

View File

@ -0,0 +1,71 @@
/*
* SPDX-FileCopyrightText: syuilo and misskey-project
* SPDX-License-Identifier: AGPL-3.0-only
*/
import { defineImageEffectorFx } from '../ImageEffector.js';
import { i18n } from '@/i18n.js';
const shader = `#version 300 es
precision mediump float;
in vec2 in_uv;
uniform sampler2D u_texture;
uniform vec2 u_resolution;
uniform float u_r;
uniform float u_g;
uniform float u_b;
out vec4 out_color;
void main() {
vec4 in_color = texture(u_texture, in_uv);
float r = in_color.r < u_r ? 0.0 : 1.0;
float g = in_color.g < u_g ? 0.0 : 1.0;
float b = in_color.b < u_b ? 0.0 : 1.0;
out_color = vec4(r, g, b, in_color.a);
}
`;
export const FX_threshold = defineImageEffectorFx({
id: 'threshold' as const,
name: i18n.ts._imageEffector._fxs.threshold,
shader,
params: {
r: {
type: 'number' as const,
default: 0.5,
min: 0.0,
max: 1.0,
step: 0.01,
},
g: {
type: 'number' as const,
default: 0.5,
min: 0.0,
max: 1.0,
step: 0.01,
},
b: {
type: 'number' as const,
default: 0.5,
min: 0.0,
max: 1.0,
step: 0.01,
},
},
main: ({ gl, program, params, preTexture }) => {
gl.activeTexture(gl.TEXTURE0);
gl.bindTexture(gl.TEXTURE_2D, preTexture);
const u_texture = gl.getUniformLocation(program, 'u_texture');
gl.uniform1i(u_texture, 0);
const u_r = gl.getUniformLocation(program, 'u_r');
gl.uniform1f(u_r, params.r);
const u_g = gl.getUniformLocation(program, 'u_g');
gl.uniform1f(u_g, params.g);
const u_b = gl.getUniformLocation(program, 'u_b');
gl.uniform1f(u_b, params.b);
},
});

View File

@ -0,0 +1,71 @@
/*
* SPDX-FileCopyrightText: syuilo and misskey-project
* SPDX-License-Identifier: AGPL-3.0-only
*/
import { defineImageEffectorFx } from '../ImageEffector.js';
import { i18n } from '@/i18n.js';
const shader = `#version 300 es
precision mediump float;
in vec2 in_uv;
uniform sampler2D u_texture;
uniform vec2 u_resolution;
uniform vec2 u_pos;
uniform float frequency;
out vec4 out_color;
void main() {
vec4 in_color = texture(u_texture, in_uv);
float t = atan(u_pos.y + (in_uv.y - 0.5), u_pos.x + (in_uv.x - 0.5));
t = sin(t * frequency);
out_color = vec4(
mix(in_color.r, 1.0, t),
mix(in_color.g, 1.0, t),
mix(in_color.b, 1.0, t),
in_color.a
);
}
`;
export const FX_zoomLines = defineImageEffectorFx({
id: 'zoomLines' as const,
name: i18n.ts._imageEffector._fxs.zoomLines,
shader,
params: {
x: {
type: 'number' as const,
default: 0.0,
min: -1.0,
max: 1.0,
step: 0.01,
},
y: {
type: 'number' as const,
default: 0.0,
min: -1.0,
max: 1.0,
step: 0.01,
},
frequency: {
type: 'number' as const,
default: 30.0,
min: 1.0,
max: 200.0,
step: 0.1,
},
},
main: ({ gl, program, params, preTexture }) => {
gl.activeTexture(gl.TEXTURE0);
gl.bindTexture(gl.TEXTURE_2D, preTexture);
const u_texture = gl.getUniformLocation(program, 'u_texture');
gl.uniform1i(u_texture, 0);
const u_pos = gl.getUniformLocation(program, 'u_pos');
gl.uniform2f(u_pos, -(params.x / 2.0), -(params.y / 2.0));
const u_frequency = gl.getUniformLocation(program, 'frequency');
gl.uniform1f(u_frequency, params.frequency);
},
});