2022-01-13 05:24:03 +01:00
|
|
|
enum NODE_SHAPE_TYPE {
|
|
|
|
rectangle,
|
|
|
|
elipse,
|
|
|
|
regular,
|
|
|
|
star,
|
2023-01-17 08:11:55 +01:00
|
|
|
arc,
|
|
|
|
teardrop,
|
|
|
|
cross,
|
|
|
|
leaf
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|
|
|
|
|
2022-12-13 09:20:36 +01:00
|
|
|
function Node_Shape(_x, _y, _group = -1) : Node_Processor(_x, _y, _group) constructor {
|
2022-01-13 05:24:03 +01:00
|
|
|
name = "Shape";
|
|
|
|
|
|
|
|
shader = sh_shape;
|
|
|
|
uniform_shape = shader_get_uniform(shader, "shape");
|
|
|
|
uniform_cent = shader_get_uniform(shader, "center");
|
|
|
|
uniform_scal = shader_get_uniform(shader, "scale");
|
|
|
|
uniform_side = shader_get_uniform(shader, "sides");
|
|
|
|
uniform_angle = shader_get_uniform(shader, "angle");
|
|
|
|
uniform_inner = shader_get_uniform(shader, "inner");
|
2023-01-17 08:11:55 +01:00
|
|
|
uniform_outer = shader_get_uniform(shader, "outer");
|
2022-01-13 05:24:03 +01:00
|
|
|
uniform_corner = shader_get_uniform(shader, "corner");
|
|
|
|
uniform_arange = shader_get_uniform(shader, "angle_range");
|
|
|
|
uniform_aa = shader_get_uniform(shader, "aa");
|
|
|
|
uniform_dim = shader_get_uniform(shader, "dimension");
|
2022-08-30 07:36:37 +02:00
|
|
|
uniform_bgCol = shader_get_uniform(shader, "bgColor");
|
2022-12-12 09:08:03 +01:00
|
|
|
uniform_drawDF = shader_get_uniform(shader, "drawDF");
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2023-01-17 08:11:55 +01:00
|
|
|
uniform_stRad = shader_get_uniform(shader, "stRad");
|
|
|
|
uniform_edRad = shader_get_uniform(shader, "edRad");
|
|
|
|
|
2022-11-21 06:38:44 +01:00
|
|
|
inputs[| 0] = nodeValue(0, "Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, def_surf_size2 )
|
2022-01-13 05:24:03 +01:00
|
|
|
.setDisplay(VALUE_DISPLAY.vector);
|
|
|
|
|
|
|
|
inputs[| 1] = nodeValue(1, "Backgroud", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
|
|
|
|
|
|
|
|
inputs[| 2] = nodeValue(2, "Shape", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
2023-01-17 08:11:55 +01:00
|
|
|
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Rectangle", "Ellipse", "Regular polygon", "Star", "Arc", "Teardrop", "Cross", "Leaf" ]);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
inputs[| 3] = nodeValue(3, "Position", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ def_surf_size / 2, def_surf_size / 2, def_surf_size / 2, def_surf_size / 2, AREA_SHAPE.rectangle ])
|
|
|
|
.setDisplay(VALUE_DISPLAY.area, function() { return inputs[| 0].getValue(); });
|
|
|
|
|
|
|
|
inputs[| 4] = nodeValue(4, "Sides", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 3)
|
2022-01-19 03:05:13 +01:00
|
|
|
.setVisible(false);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
inputs[| 5] = nodeValue(5, "Inner radius", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0.5)
|
|
|
|
.setDisplay(VALUE_DISPLAY.slider, [0, 1, 0.01])
|
|
|
|
.setVisible(false);
|
|
|
|
|
2022-01-19 03:05:13 +01:00
|
|
|
inputs[| 6] = nodeValue(6, "Anti alising", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
inputs[| 7] = nodeValue(7, "Rotation", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
|
|
|
.setDisplay(VALUE_DISPLAY.rotation);
|
|
|
|
|
2023-01-17 08:11:55 +01:00
|
|
|
inputs[| 8] = nodeValue(8, "Angle range", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 0, 180 ])
|
2022-01-13 05:24:03 +01:00
|
|
|
.setDisplay(VALUE_DISPLAY.rotation_range);
|
|
|
|
|
|
|
|
inputs[| 9] = nodeValue(9, "Corner radius", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0)
|
|
|
|
.setDisplay(VALUE_DISPLAY.slider, [0, 0.5, 0.01]);
|
|
|
|
|
2022-08-30 07:36:37 +02:00
|
|
|
inputs[| 10] = nodeValue(10, "Shape color", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_white);
|
|
|
|
|
|
|
|
inputs[| 11] = nodeValue(11, "Background color", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_black);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2022-12-13 09:20:36 +01:00
|
|
|
inputs[| 12] = nodeValue(12, "Height", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
|
2022-12-12 09:08:03 +01:00
|
|
|
|
2023-01-17 08:11:55 +01:00
|
|
|
inputs[| 13] = nodeValue(13, "Start radius", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0.1)
|
|
|
|
.setDisplay(VALUE_DISPLAY.slider, [0, 1, 0.01])
|
|
|
|
.setVisible(false);
|
|
|
|
|
2022-09-21 06:09:40 +02:00
|
|
|
outputs[| 0] = nodeValue(0, "Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, PIXEL_SURFACE);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
input_display_list = [
|
|
|
|
["Surface", false], 0, 6,
|
2023-01-17 08:11:55 +01:00
|
|
|
["Shape", false], 2, 3, 9, 4, 13, 5, 7, 8,
|
2022-12-12 09:08:03 +01:00
|
|
|
["Render", true], 10, 1, 11, 12
|
2022-01-13 05:24:03 +01:00
|
|
|
];
|
|
|
|
|
2022-12-19 13:35:30 +01:00
|
|
|
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
|
|
|
inputs[| 3].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|
|
|
|
|
2023-01-01 02:06:02 +01:00
|
|
|
static process_data = function(_outSurf, _data, _output_index, _array_index) {
|
2022-01-13 05:24:03 +01:00
|
|
|
var _dim = _data[0];
|
|
|
|
var _bg = _data[1];
|
|
|
|
var _shape = _data[2];
|
|
|
|
var _posit = _data[3];
|
|
|
|
var _aa = _data[6];
|
|
|
|
var _corner = _data[9];
|
2022-08-30 07:36:37 +02:00
|
|
|
var _color = _data[10];
|
2022-12-12 09:08:03 +01:00
|
|
|
var _df = _data[12];
|
2022-08-30 07:36:37 +02:00
|
|
|
var _bgcol = _bg? colToVec4(_data[11]) : [0, 0, 0, 0];
|
|
|
|
|
|
|
|
inputs[| 11].setVisible(_bg);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2022-12-27 04:00:50 +01:00
|
|
|
_outSurf = surface_verify(_outSurf, _dim[0], _dim[1]);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
surface_set_target(_outSurf);
|
|
|
|
if(_bg) draw_clear_alpha(0, 1);
|
|
|
|
else draw_clear_alpha(0, 0);
|
|
|
|
|
|
|
|
shader_set(shader);
|
|
|
|
|
2023-01-17 08:11:55 +01:00
|
|
|
inputs[| 4].setVisible(false);
|
|
|
|
inputs[| 5].setVisible(false);
|
|
|
|
inputs[| 7].setVisible(false);
|
|
|
|
inputs[| 8].setVisible(false);
|
|
|
|
inputs[| 9].setVisible(false);
|
|
|
|
inputs[| 13].setVisible(false);
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
switch(_shape) {
|
2023-01-17 08:11:55 +01:00
|
|
|
case NODE_SHAPE_TYPE.rectangle :
|
|
|
|
inputs[| 9].setVisible(true);
|
|
|
|
break;
|
2022-01-13 05:24:03 +01:00
|
|
|
case NODE_SHAPE_TYPE.elipse :
|
|
|
|
break;
|
|
|
|
case NODE_SHAPE_TYPE.regular :
|
2022-01-19 06:11:17 +01:00
|
|
|
inputs[| 4].setVisible(true);
|
|
|
|
inputs[| 7].setVisible(true);
|
|
|
|
inputs[| 9].setVisible(true);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
shader_set_uniform_i(uniform_side, _data[4]);
|
|
|
|
shader_set_uniform_f(uniform_angle, degtorad(_data[7]));
|
|
|
|
break;
|
|
|
|
case NODE_SHAPE_TYPE.star :
|
2022-01-19 06:11:17 +01:00
|
|
|
inputs[| 4].setVisible(true);
|
|
|
|
inputs[| 5].setVisible(true);
|
|
|
|
inputs[| 7].setVisible(true);
|
|
|
|
inputs[| 9].setVisible(true);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2023-01-17 08:11:55 +01:00
|
|
|
inputs[| 5].name = "Inner radius";
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
shader_set_uniform_i(uniform_side, _data[4]);
|
|
|
|
shader_set_uniform_f(uniform_angle, degtorad(_data[7]));
|
|
|
|
shader_set_uniform_f(uniform_inner, _data[5]);
|
|
|
|
break;
|
|
|
|
case NODE_SHAPE_TYPE.arc :
|
2022-01-19 06:11:17 +01:00
|
|
|
inputs[| 5].setVisible(true);
|
|
|
|
inputs[| 8].setVisible(true);
|
2023-01-17 08:11:55 +01:00
|
|
|
|
|
|
|
inputs[| 5].name = "Inner radius";
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
var ar = _data[8];
|
|
|
|
var center = degtorad(ar[0] + ar[1]) / 2;
|
|
|
|
var range = degtorad(ar[0] - ar[1]) / 2;
|
|
|
|
shader_set_uniform_f(uniform_angle, center);
|
|
|
|
shader_set_uniform_f_array(uniform_arange, [ sin(range), cos(range) ] );
|
|
|
|
shader_set_uniform_f(uniform_inner, _data[5] / 2);
|
|
|
|
break;
|
2023-01-17 08:11:55 +01:00
|
|
|
case NODE_SHAPE_TYPE.teardrop :
|
|
|
|
inputs[| 5].setVisible(true);
|
|
|
|
inputs[| 13].setVisible(true);
|
|
|
|
|
|
|
|
inputs[| 5].name = "End radius";
|
|
|
|
inputs[| 13].name = "Start radius";
|
|
|
|
|
|
|
|
shader_set_uniform_f(uniform_edRad, _data[5]);
|
|
|
|
shader_set_uniform_f(uniform_stRad, _data[13]);
|
|
|
|
break;
|
|
|
|
case NODE_SHAPE_TYPE.cross :
|
2022-01-19 06:11:17 +01:00
|
|
|
inputs[| 9].setVisible(true);
|
2023-01-17 08:11:55 +01:00
|
|
|
inputs[| 13].setVisible(true);
|
|
|
|
|
|
|
|
inputs[| 13].name = "Outer radius";
|
|
|
|
|
|
|
|
shader_set_uniform_f(uniform_outer, _data[13]);
|
|
|
|
break;
|
|
|
|
case NODE_SHAPE_TYPE.leaf :
|
|
|
|
inputs[| 5].setVisible(true);
|
|
|
|
inputs[| 13].setVisible(true);
|
|
|
|
|
|
|
|
inputs[| 5].name = "Inner radius";
|
|
|
|
inputs[| 13].name = "Outer radius";
|
|
|
|
|
|
|
|
shader_set_uniform_f(uniform_inner, _data[5]);
|
|
|
|
shader_set_uniform_f(uniform_outer, _data[13]);
|
2022-01-13 05:24:03 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
shader_set_uniform_f_array(uniform_dim, _dim);
|
|
|
|
shader_set_uniform_i(uniform_shape, _shape);
|
2022-08-30 07:36:37 +02:00
|
|
|
shader_set_uniform_f_array(uniform_bgCol, _bgcol);
|
2022-01-13 05:24:03 +01:00
|
|
|
shader_set_uniform_i(uniform_aa, _aa);
|
2022-12-12 09:08:03 +01:00
|
|
|
shader_set_uniform_i(uniform_drawDF, _df);
|
2022-01-13 05:24:03 +01:00
|
|
|
shader_set_uniform_f(uniform_corner, _corner);
|
|
|
|
|
|
|
|
shader_set_uniform_f_array(uniform_cent, [ _posit[0] / _dim[0], _posit[1] / _dim[1] ]);
|
|
|
|
shader_set_uniform_f_array(uniform_scal, [ _posit[2] / _dim[0], _posit[3] / _dim[1] ]);
|
2022-08-30 07:36:37 +02:00
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
draw_sprite_ext(s_fx_pixel, 0, 0, 0, _dim[0], _dim[1], 0, _color, 1);
|
|
|
|
shader_reset();
|
|
|
|
surface_reset_target();
|
2022-12-27 04:00:50 +01:00
|
|
|
|
|
|
|
return _outSurf;
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|
|
|
|
}
|