2023-07-18 17:51:40 +02:00
|
|
|
function Node_Region_Fill(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
|
|
|
name = "Region Fill";
|
|
|
|
|
|
|
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone );
|
|
|
|
|
|
|
|
inputs[| 1] = nodeValue("Mask", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
inputs[| 2] = nodeValue("Fill Colors", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, DEF_PALETTE )
|
2023-07-18 17:51:40 +02:00
|
|
|
.setDisplay(VALUE_DISPLAY.palette);
|
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
inputs[| 3] = nodeValue("Fill", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true);
|
2023-07-18 17:51:40 +02:00
|
|
|
|
|
|
|
inputs[| 4] = nodeValue("Seed", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, irandom_range(10000, 99999));
|
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
inputs[| 5] = nodeValue("Target Color", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, cola(c_black, 0));
|
|
|
|
|
|
|
|
inputs[| 6] = nodeValue("Inner only", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false, "Only fill regions with surrounding pixels.");
|
|
|
|
|
|
|
|
inputs[| 7] = nodeValue("Draw original", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
|
|
|
|
|
|
|
|
inputs[| 8] = nodeValue("Fill type", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
|
|
|
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Random", "Color map" ]);
|
|
|
|
|
|
|
|
inputs[| 9] = nodeValue("Color map", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
|
|
|
|
2023-07-18 17:51:40 +02:00
|
|
|
outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
|
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
input_display_list = [ 4,
|
2023-11-08 14:37:51 +01:00
|
|
|
["Surfaces", false], 0, 1,
|
2024-01-30 15:04:56 +01:00
|
|
|
["Fill", false, 3], 5, 8, 2, 9, 6,
|
|
|
|
["Render", false], 7,
|
2023-07-18 17:51:40 +02:00
|
|
|
];
|
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
temp_surface = array_create(3);
|
2023-07-18 17:51:40 +02:00
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
static step = function() {
|
|
|
|
var _filt = getInputData(8);
|
|
|
|
|
|
|
|
inputs[| 2].setVisible(_filt == 0);
|
|
|
|
inputs[| 9].setVisible(_filt == 1, _filt == 1);
|
|
|
|
}
|
2023-07-18 17:51:40 +02:00
|
|
|
|
2023-08-17 16:56:54 +02:00
|
|
|
static processData = function(_outSurf, _data, _output_index, _array_index) {
|
2023-07-18 17:51:40 +02:00
|
|
|
var _surf = _data[0];
|
|
|
|
var _mask = _data[1];
|
|
|
|
|
|
|
|
var _colr = _data[2];
|
|
|
|
var _fill = _data[3];
|
|
|
|
var _seed = _data[4];
|
2024-01-30 15:04:56 +01:00
|
|
|
var _targ = _data[5];
|
|
|
|
var _innr = _data[6];
|
|
|
|
var _rnbg = _data[7];
|
|
|
|
var _filt = _data[8];
|
|
|
|
var _cmap = _data[9];
|
2023-07-18 17:51:40 +02:00
|
|
|
|
2023-09-08 21:37:36 +02:00
|
|
|
var _sw = surface_get_width_safe(_surf);
|
|
|
|
var _sh = surface_get_height_safe(_surf)
|
2023-07-18 17:51:40 +02:00
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
for( var i = 0, n = array_length(temp_surface); i < n; i++ ) {
|
|
|
|
temp_surface[i] = surface_verify(temp_surface[i], _sw, _sh);
|
|
|
|
surface_clear(temp_surface[i]);
|
|
|
|
}
|
2023-07-18 17:51:40 +02:00
|
|
|
|
2023-08-03 20:01:58 +02:00
|
|
|
surface_set_shader(temp_surface[1], sh_region_fill_init);
|
2024-01-30 15:04:56 +01:00
|
|
|
shader_set_color("targetColor", _targ);
|
|
|
|
|
|
|
|
draw_surface_safe(_surf);
|
2023-08-03 20:01:58 +02:00
|
|
|
surface_reset_shader();
|
2023-07-18 17:51:40 +02:00
|
|
|
|
|
|
|
var base = 0;
|
2024-01-30 15:04:56 +01:00
|
|
|
var amo = _sw;
|
|
|
|
|
|
|
|
if(_innr) {
|
|
|
|
repeat( amo ) {
|
|
|
|
surface_set_shader(temp_surface[base], sh_region_fill_inner);
|
|
|
|
shader_set_f("dimension", _sw, _sh);
|
|
|
|
|
|
|
|
draw_surface_safe(temp_surface[!base]);
|
|
|
|
surface_reset_shader();
|
|
|
|
|
|
|
|
base = !base;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-03 20:01:58 +02:00
|
|
|
var amo = _sw + _sh;
|
2023-07-18 17:51:40 +02:00
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
repeat( amo ) {
|
2023-07-18 17:51:40 +02:00
|
|
|
surface_set_shader(temp_surface[base], sh_region_fill_coordinate);
|
|
|
|
shader_set_f("dimension", _sw, _sh);
|
2023-08-03 20:01:58 +02:00
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
draw_surface_safe(temp_surface[!base]);
|
2023-07-18 17:51:40 +02:00
|
|
|
surface_reset_shader();
|
|
|
|
|
|
|
|
base = !base;
|
|
|
|
}
|
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
surface_set_shader(temp_surface[base], sh_region_fill_border);
|
|
|
|
shader_set_f("dimension", _sw, _sh);
|
|
|
|
shader_set_surface("original", _surf);
|
|
|
|
|
|
|
|
draw_surface_safe(temp_surface[!base]);
|
|
|
|
surface_reset_shader();
|
|
|
|
|
2023-07-18 17:51:40 +02:00
|
|
|
if(_fill) {
|
|
|
|
var _pal = [];
|
2023-07-25 20:12:40 +02:00
|
|
|
for( var i = 0, n = array_length(_colr); i < n; i++ )
|
2023-07-18 17:51:40 +02:00
|
|
|
array_append(_pal, colToVec4(_colr[i]));
|
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
surface_set_shader(_outSurf);
|
|
|
|
switch(_filt) {
|
|
|
|
case 0 :
|
|
|
|
shader_set(sh_region_fill_color);
|
|
|
|
|
|
|
|
shader_set_f("colors", _pal);
|
|
|
|
shader_set_f("seed", _seed);
|
|
|
|
shader_set_f("colorAmount", array_length(_colr));
|
|
|
|
|
|
|
|
draw_surface_safe(temp_surface[base]);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 1 :
|
|
|
|
shader_set(sh_region_fill_map);
|
|
|
|
|
|
|
|
shader_set_surface("colorMap", _cmap);
|
|
|
|
|
|
|
|
draw_surface_safe(temp_surface[base]);
|
|
|
|
break;
|
|
|
|
}
|
2023-07-18 17:51:40 +02:00
|
|
|
|
2024-01-30 15:04:56 +01:00
|
|
|
if(_rnbg) {
|
|
|
|
shader_reset();
|
|
|
|
shader_set(sh_sample);
|
|
|
|
draw_surface_safe(_surf);
|
|
|
|
}
|
2023-07-18 17:51:40 +02:00
|
|
|
surface_reset_shader();
|
|
|
|
} else {
|
|
|
|
surface_set_shader(_outSurf);
|
2024-01-30 15:04:56 +01:00
|
|
|
draw_surface_safe(temp_surface[base]);
|
|
|
|
if(_rnbg)
|
|
|
|
draw_surface_safe(_surf);
|
2023-07-18 17:51:40 +02:00
|
|
|
surface_reset_shader();
|
|
|
|
}
|
|
|
|
|
|
|
|
return _outSurf;
|
|
|
|
}
|
|
|
|
}
|