Pixel-Composer/scripts/node_threshold/node_threshold.gml

108 lines
3.1 KiB
Text
Raw Normal View History

2023-02-28 09:43:01 +01:00
function Node_Threshold(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
2023-01-01 02:06:02 +01:00
name = "Threshold";
2024-08-18 06:16:20 +02:00
newInput(0, nodeValue_Surface("Surface in", self));
2023-01-01 02:06:02 +01:00
2024-08-18 06:16:20 +02:00
newInput(1, nodeValue_Bool("Brightness", self, false));
2023-01-01 02:06:02 +01:00
2024-08-18 09:13:41 +02:00
newInput(2, nodeValue_Float("Brightness Threshold", self, 0.5))
2023-12-23 09:39:55 +01:00
.setDisplay(VALUE_DISPLAY.slider)
.setMappable(13);
2023-01-25 06:49:00 +01:00
2024-08-18 09:13:41 +02:00
newInput(3, nodeValue_Float("Brightness Smoothness", self, 0))
.setDisplay(VALUE_DISPLAY.slider);
2023-01-01 02:06:02 +01:00
2024-08-18 06:16:20 +02:00
newInput(4, nodeValue_Surface("Mask", self));
2023-01-01 02:06:02 +01:00
2024-08-18 09:13:41 +02:00
newInput(5, nodeValue_Float("Mix", self, 1))
.setDisplay(VALUE_DISPLAY.slider);
2023-02-14 05:32:32 +01:00
2024-08-18 06:16:20 +02:00
newInput(6, nodeValue_Bool("Active", self, true));
2023-02-14 05:32:32 +01:00
active_index = 6;
2024-08-18 06:16:20 +02:00
newInput(7, nodeValue_Bool("Alpha", self, false));
2024-08-18 09:13:41 +02:00
newInput(8, nodeValue_Float("Alpha Threshold", self, 0.5))
2023-12-23 09:39:55 +01:00
.setDisplay(VALUE_DISPLAY.slider)
.setMappable(14);
2024-08-18 09:13:41 +02:00
newInput(9, nodeValue_Float("Alpha Smoothness", self, 0))
.setDisplay(VALUE_DISPLAY.slider);
2024-08-18 06:16:20 +02:00
newInput(10, nodeValue_Toggle("Channel", self, 0b1111, { data: array_create(4, THEME.inspector_channel) }));
2023-11-24 10:41:53 +01:00
__init_mask_modifier(4); // inputs 11, 12
2023-12-23 09:39:55 +01:00
//////////////////////////////////////////////////////////////////////////////////////////////////
2024-08-18 06:16:20 +02:00
newInput(13, nodeValueMap("Brightness map", self));
2023-12-23 09:39:55 +01:00
2024-08-18 06:16:20 +02:00
newInput(14, nodeValueMap("Alpha map", self));
2023-12-23 09:39:55 +01:00
//////////////////////////////////////////////////////////////////////////////////////////////////
2025-01-03 09:08:28 +01:00
newInput(15, nodeValue_Enum_Scroll("Algorithm", self, 0, [ "Simple", "Adaptive mean" ]));
newInput(16, nodeValue_Int("Adaptive Radius", self, 4))
2024-09-04 03:57:11 +02:00
newOutput(0, nodeValue_Output("Surface out", self, VALUE_TYPE.surface, noone));
2023-02-14 05:32:32 +01:00
input_display_list = [ 6, 10,
2023-11-24 10:41:53 +01:00
["Surfaces", true], 0, 4, 5, 11, 12,
2025-01-03 09:08:28 +01:00
["Brightness", true, 1], 15, 2, 13, 3,16,
2024-01-09 03:39:40 +01:00
["Alpha", true, 7], 8, 14, 9,
2023-01-01 02:06:02 +01:00
];
2023-03-19 09:17:39 +01:00
attribute_surface_depth();
2025-01-03 09:08:28 +01:00
static step = function() {
2023-11-24 10:41:53 +01:00
__step_mask_modifier();
2023-12-23 09:39:55 +01:00
2024-08-08 06:57:51 +02:00
inputs[2].mappableStep();
inputs[8].mappableStep();
2025-01-03 09:08:28 +01:00
}
2025-01-03 09:08:28 +01:00
static processData = function(_outSurf, _data, _output_index, _array_index) {
var _surf = _data[0];
var _bright = _data[1];
var _brightThr = _data[2];
var _brightSmt = _data[3];
var _alph = _data[7];
var _alphThr = _data[8];
var _alphSmt = _data[9];
2025-01-03 09:08:28 +01:00
var _algo = _data[15];
var _adap_size = _data[16];
inputs[16].setVisible(_algo == 1);
var _shader = sh_threshold;
if(_algo == 1) _shader = sh_threshold_adaptive;
surface_set_shader(_outSurf, _shader);
shader_set_dim(, _surf);
shader_set_i("bright", _bright);
shader_set_f_map("brightThreshold", _brightThr, _data[13], inputs[2]);
shader_set_f("brightSmooth", _brightSmt);
shader_set_f("adaptiveRadius", _adap_size);
shader_set_f("gaussianCoeff", __gaussian_get_kernel(_adap_size));
2023-01-01 02:06:02 +01:00
2025-01-03 09:08:28 +01:00
shader_set_i("alpha", _alph);
shader_set_f_map("alphaThreshold", _alphThr, _data[14], inputs[8]);
shader_set_f("alphaSmooth", _alphSmt);
2025-01-03 09:08:28 +01:00
draw_surface_safe(_surf);
surface_reset_shader();
2023-01-01 02:06:02 +01:00
2023-11-24 10:41:53 +01:00
__process_mask_modifier(_data);
2023-02-14 05:32:32 +01:00
_outSurf = mask_apply(_data[0], _outSurf, _data[4], _data[5]);
_outSurf = channel_apply(_data[0], _outSurf, _data[10]);
2023-02-14 05:32:32 +01:00
2023-01-01 02:06:02 +01:00
return _outSurf;
2025-01-03 09:08:28 +01:00
}
2023-01-01 02:06:02 +01:00
}