This commit is contained in:
2025-02-07 17:04:43 -06:00
parent 33fd7ddf72
commit 8eec81c7f4
2249 changed files with 75331 additions and 685 deletions

View File

@@ -0,0 +1,41 @@
// [COMBO] {"material":"ui_editor_properties_blend_mode","combo":"BLENDMODE","type":"imageblending","default":0}
#include "common.h"
#include "common_blending.h"
varying vec2 v_TexCoordKernel[9];
uniform sampler2D g_Texture0; // {"hidden":true}
uniform float g_BlendAlpha; // {"material":"alpha","label":"ui_editor_properties_alpha","default":1,"range":[0.01,1]}
uniform float g_BlendBrightness; // {"material":"brightness","label":"ui_editor_properties_brightness","default":1,"range":[0,2]}
uniform vec3 g_OutlineColor1; // {"material":"outlinecolor","label":"ui_editor_properties_outline_color","default":"0 0 0","type":"color"}
uniform vec3 g_OutlineColor2; // {"material":"outlinecolorbg","label":"ui_editor_properties_outline_background","default":"1 1 1","type":"color"}
uniform float g_DetectionThreshold; // {"material":"detectthreshold","label":"ui_editor_properties_detection_threshold","default":0.5,"range":[0,5]}
uniform float g_DetectionMultiply; // {"material":"detectmultiply","label":"ui_editor_properties_detection_multiply","default":1,"range":[0,5]}
void main() {
vec4 albedo = texSample2D(g_Texture0, v_TexCoordKernel[4]);
vec3 sample00 = texSample2D(g_Texture0, v_TexCoordKernel[0]).rgb;
vec3 sample10 = texSample2D(g_Texture0, v_TexCoordKernel[1]).rgb;
vec3 sample20 = texSample2D(g_Texture0, v_TexCoordKernel[2]).rgb;
vec3 sample01 = texSample2D(g_Texture0, v_TexCoordKernel[3]).rgb;
vec3 sample21 = texSample2D(g_Texture0, v_TexCoordKernel[5]).rgb;
vec3 sample02 = texSample2D(g_Texture0, v_TexCoordKernel[6]).rgb;
vec3 sample12 = texSample2D(g_Texture0, v_TexCoordKernel[7]).rgb;
vec3 sample22 = texSample2D(g_Texture0, v_TexCoordKernel[8]).rgb;
vec3 gx = sample20 - sample00 + (sample21 - sample01) * 2 + sample22 - sample02;
vec3 gy = sample00 - sample02 + (sample10 - sample12) * 2 + sample20 - sample22;
float g = abs(greyscale(gx)) + abs(greyscale(gy));
vec3 combinedColor = mix(g_OutlineColor2, g_OutlineColor1,
min(1.0, max(0.0, g - g_DetectionThreshold) * g_DetectionMultiply)) * g_BlendBrightness;
gl_FragColor.a = albedo.a;
gl_FragColor.rgb = ApplyBlending(BLENDMODE, albedo.rgb, combinedColor, g_BlendAlpha);
}

View File

@@ -0,0 +1,26 @@
uniform mat4 g_ModelViewProjectionMatrix;
uniform vec4 g_Texture0Resolution;
uniform float g_DetectionSize; // {"material":"size","label":"ui_editor_properties_detection_size","default":1,"range":[0,5]}
attribute vec3 a_Position;
attribute vec2 a_TexCoord;
varying vec2 v_TexCoordKernel[9];
void main() {
gl_Position = mul(vec4(a_Position, 1.0), g_ModelViewProjectionMatrix);
vec2 texelSize = vec2(1.0 / g_Texture0Resolution.z, 1.0 / g_Texture0Resolution.w) * g_DetectionSize;
v_TexCoordKernel[0] = a_TexCoord - texelSize;
v_TexCoordKernel[1] = a_TexCoord - vec2(0.0, texelSize.y);
v_TexCoordKernel[2] = a_TexCoord + vec2(texelSize.x, -texelSize.y);
v_TexCoordKernel[3] = a_TexCoord - vec2(texelSize.x, 0.0);
v_TexCoordKernel[4] = a_TexCoord;
v_TexCoordKernel[5] = a_TexCoord + vec2(texelSize.x, 0.0);
v_TexCoordKernel[6] = a_TexCoord + vec2(-texelSize.x, texelSize.y);
v_TexCoordKernel[7] = a_TexCoord + vec2(0.0, texelSize.y);
v_TexCoordKernel[8] = a_TexCoord + texelSize;
}