Pixel-Composer/scripts/node_kuwahara/node_kuwahara.gml

126 lines
3.5 KiB
Text
Raw Normal View History

2024-02-09 14:43:03 +01:00
function Node_Kuwahara(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
name = "Kuwahara";
2024-08-18 06:16:20 +02:00
newInput(0, nodeValue_Surface("Surface in", self));
2024-02-09 14:43:03 +01:00
2024-08-18 06:16:20 +02:00
newInput(1, nodeValue_Bool("Active", self, true));
2024-02-09 14:43:03 +01:00
active_index = 1;
2024-08-18 09:13:41 +02:00
newInput(2, nodeValue_Int("Radius", self, 2))
.setValidator(VV_min(1));
2024-02-09 14:43:03 +01:00
2024-08-18 06:16:20 +02:00
newInput(3, nodeValue_Surface("Mask", self));
2024-08-18 09:13:41 +02:00
newInput(4, nodeValue_Float("Mix", self, 1))
.setDisplay(VALUE_DISPLAY.slider);
2024-08-18 06:16:20 +02:00
newInput(5, nodeValue_Bool("Active", self, true));
active_index = 5;
2024-08-18 06:16:20 +02:00
newInput(6, nodeValue_Toggle("Channel", self, 0b1111, { data: array_create(4, THEME.inspector_channel) }));
__init_mask_modifier(3); // inputs 7, 8
2024-12-12 05:48:59 +01:00
newInput(9, nodeValue_Enum_Scroll("Types", self, 0, [ "Basic", "Anisotropics", "Generalized" ]));
newInput(10, nodeValue_Float("Alpha", self, 1))
.setDisplay(VALUE_DISPLAY.slider);
newInput(11, nodeValue_Float("Zero crossing", self, 0.58))
.setDisplay(VALUE_DISPLAY.slider);
newInput(12, nodeValue_Float("Hardness", self, 8))
newInput(13, nodeValue_Float("Sharpness", self, 8))
2024-09-04 03:57:11 +02:00
newOutput(0, nodeValue_Output("Surface out", self, VALUE_TYPE.surface, noone));
2024-02-09 14:43:03 +01:00
input_display_list = [ 1,
2024-12-12 05:48:59 +01:00
["Surfaces", true], 0, 3, 4, 7, 8,
["Effects", false], 9, 2, 10, 11, 12, 13,
];
2024-02-09 14:43:03 +01:00
2024-12-30 09:37:33 +01:00
temp_surface = array_create(4);
2024-12-12 05:48:59 +01:00
2024-02-09 14:43:03 +01:00
attribute_surface_depth();
static step = function() {
__step_mask_modifier();
}
static processData = function(_outSurf, _data, _output_index, _array_index) {
2024-12-12 05:48:59 +01:00
var _surf = _data[0];
var _type = _data[9];
var _dim = surface_get_dimension(_surf);
2024-02-09 14:43:03 +01:00
2024-12-12 05:48:59 +01:00
inputs[10].setVisible(_type == 1);
inputs[11].setVisible(_type != 0);
inputs[12].setVisible(_type != 0);
inputs[13].setVisible(_type != 0);
switch(_type) {
case 0 :
surface_set_shader(_outSurf, sh_kuwahara);
shader_set_2("dimension", _dim);
shader_set_i("radius", _data[2]);
draw_surface_safe(_surf);
surface_reset_shader();
break;
case 1 :
2024-12-30 09:37:33 +01:00
for( var i = 0; i < 3; i++ ) temp_surface[i] = surface_verify(temp_surface[i], _dim[0], _dim[1]);
2024-12-12 05:48:59 +01:00
2024-12-30 09:37:33 +01:00
surface_set_shader(temp_surface[0], sh_kuwahara_ani_pass1);
2024-12-12 05:48:59 +01:00
shader_set_2("dimension", _dim);
draw_surface_safe(_surf);
surface_reset_shader();
2024-12-30 09:37:33 +01:00
surface_set_shader(temp_surface[1], sh_kuwahara_ani_pass2);
2024-12-12 05:48:59 +01:00
shader_set_2("dimension", _dim);
2024-12-30 09:37:33 +01:00
draw_surface_safe(temp_surface[0]);
2024-12-12 05:48:59 +01:00
surface_reset_shader();
2024-12-30 09:37:33 +01:00
surface_set_shader(temp_surface[2], sh_kuwahara_ani_pass3);
2024-12-12 05:48:59 +01:00
shader_set_2("dimension", _dim);
2024-12-30 09:37:33 +01:00
draw_surface_safe(temp_surface[1]);
2024-12-12 05:48:59 +01:00
surface_reset_shader();
surface_set_shader(_outSurf, sh_kuwahara_ani_pass4);
2024-12-30 09:37:33 +01:00
shader_set_surface("tfm", temp_surface[2]);
2024-12-12 05:48:59 +01:00
shader_set_2("dimension", _dim);
shader_set_f("alpha", _data[10]);
shader_set_i("kernelSize", _data[2]);
shader_set_f("zeroCrossing", _data[11]);
shader_set_f("hardness", _data[12]);
shader_set_f("sharpness", _data[13]);
draw_surface_safe(_surf);
surface_reset_shader();
break;
2024-02-09 14:43:03 +01:00
2024-12-12 05:48:59 +01:00
case 2 :
surface_set_shader(_outSurf, sh_kuwahara_gen);
shader_set_2("dimension", _dim);
shader_set_i("kernelSize", _data[2]);
shader_set_f("zeroCrossing", _data[11]);
shader_set_f("hardness", _data[12]);
shader_set_f("sharpness", _data[13]);
draw_surface_safe(_surf);
surface_reset_shader();
break;
}
2024-02-09 14:43:03 +01:00
__process_mask_modifier(_data);
2024-12-12 05:48:59 +01:00
_outSurf = mask_apply(_surf, _outSurf, _data[3], _data[4]);
_outSurf = channel_apply(_surf, _outSurf, _data[6]);
2024-02-09 14:43:03 +01:00
return _outSurf;
}
2024-02-09 14:43:03 +01:00
}