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))
|
2023-10-02 08:57:44 +02:00
|
|
|
.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))
|
2023-10-02 08:57:44 +02:00
|
|
|
.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));
|
2023-08-03 20:01:58 +02:00
|
|
|
|
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);
|
2023-08-03 20:01:58 +02:00
|
|
|
|
2024-08-18 09:13:41 +02:00
|
|
|
newInput(9, nodeValue_Float("Alpha Smoothness", self, 0))
|
2023-10-02 08:57:44 +02:00
|
|
|
.setDisplay(VALUE_DISPLAY.slider);
|
2023-08-03 20:01:58 +02:00
|
|
|
|
2024-08-18 06:16:20 +02:00
|
|
|
newInput(10, nodeValue_Toggle("Channel", self, 0b1111, { data: array_create(4, THEME.inspector_channel) }));
|
2023-11-09 04:02:41 +01:00
|
|
|
|
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
|
|
|
|
2023-11-09 04:02:41 +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
|
|
|
}
|
2023-08-03 20:01:58 +02: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];
|
2023-11-08 13:05:24 +01:00
|
|
|
|
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);
|
2023-08-03 20:01:58 +02:00
|
|
|
|
2025-01-03 09:08:28 +01:00
|
|
|
draw_surface_safe(_surf);
|
2023-08-03 20:01:58 +02:00
|
|
|
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]);
|
2023-11-09 04:02:41 +01:00
|
|
|
_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
|
|
|
}
|