2023-09-22 17:01:56 +02:00
|
|
|
function Node_create_Scale_Algo(_x, _y, _group = noone, _param = {}) {
|
|
|
|
var query = struct_try_get(_param, "query", "");
|
|
|
|
var node = new Node_Scale_Algo(_x, _y, _group);
|
2022-01-26 13:02:30 +01:00
|
|
|
|
2023-09-22 17:01:56 +02:00
|
|
|
switch(query) {
|
2022-01-26 13:02:30 +01:00
|
|
|
case "scale2x" : node.inputs[| 1].setValue(0); break;
|
|
|
|
case "scale3x" : node.inputs[| 1].setValue(1); break;
|
|
|
|
}
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
return node;
|
|
|
|
}
|
|
|
|
|
2023-02-28 09:43:01 +01:00
|
|
|
function Node_Scale_Algo(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
2023-01-25 06:49:00 +01:00
|
|
|
name = "Scale Algorithm";
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
manage_atlas = false;
|
|
|
|
|
2023-02-14 05:32:32 +01:00
|
|
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2023-02-14 05:32:32 +01:00
|
|
|
inputs[| 1] = nodeValue("Algorithm", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
2022-01-13 05:24:03 +01:00
|
|
|
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Scale2x", "Scale3x" ]);
|
|
|
|
|
2023-02-14 05:32:32 +01:00
|
|
|
inputs[| 2] = nodeValue("Tolerance", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0)
|
2023-10-02 08:57:44 +02:00
|
|
|
.setDisplay(VALUE_DISPLAY.slider);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2023-02-14 05:32:32 +01:00
|
|
|
inputs[| 3] = nodeValue("Active", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true);
|
|
|
|
active_index = 3;
|
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
inputs[| 4] = nodeValue("Scale atlas position", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true);
|
|
|
|
|
2023-02-14 05:32:32 +01:00
|
|
|
outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
|
|
|
|
|
|
|
|
input_display_list = [ 3,
|
2023-11-08 14:37:51 +01:00
|
|
|
["Surfaces", false], 0,
|
2023-10-10 07:12:42 +02:00
|
|
|
["Scale", false], 1, 2, 4,
|
2023-02-14 05:32:32 +01:00
|
|
|
]
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2023-03-19 09:17:39 +01:00
|
|
|
attribute_surface_depth();
|
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
static step = function() {
|
|
|
|
var _surf = getSingleValue(0);
|
|
|
|
|
|
|
|
var _atlas = is_instanceof(_surf, SurfaceAtlas);
|
|
|
|
inputs[| 4].setVisible(_atlas);
|
|
|
|
}
|
|
|
|
|
2023-08-17 16:56:54 +02:00
|
|
|
static processData = function(_outSurf, _data, _output_index, _array_index) {
|
2022-01-13 05:24:03 +01:00
|
|
|
var inSurf = _data[0];
|
2023-03-19 09:17:39 +01:00
|
|
|
var algo = _data[1];
|
2023-10-10 07:12:42 +02:00
|
|
|
var _atlS = _data[4];
|
2023-09-08 21:37:36 +02:00
|
|
|
var ww = surface_get_width_safe(inSurf);
|
|
|
|
var hh = surface_get_height_safe(inSurf);
|
2023-03-19 09:17:39 +01:00
|
|
|
var cDep = attrDepth();
|
2022-12-21 02:30:23 +01:00
|
|
|
var shader;
|
2022-01-13 05:24:03 +01:00
|
|
|
var sc = 2;
|
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
var isAtlas = is_instanceof(_data[0], SurfaceAtlas);
|
|
|
|
if(isAtlas && !is_instanceof(_outSurf, SurfaceAtlas))
|
|
|
|
_outSurf = _data[0].clone(true);
|
|
|
|
var _surf = isAtlas? _outSurf.getSurface() : _outSurf;
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
switch(algo) {
|
|
|
|
case 0 :
|
|
|
|
shader = sh_scale2x;
|
|
|
|
sc = 2;
|
|
|
|
var sw = ww * 2;
|
|
|
|
var sh = hh * 2;
|
2022-12-27 04:00:50 +01:00
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
_surf = surface_verify(_surf, sw, sh, cDep);
|
2022-01-13 05:24:03 +01:00
|
|
|
break;
|
|
|
|
case 1 :
|
|
|
|
shader = sh_scale3x;
|
|
|
|
sc = 3;
|
|
|
|
var sw = ww * 3;
|
|
|
|
var sh = hh * 3;
|
2022-12-27 04:00:50 +01:00
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
_surf = surface_verify(_surf, sw, sh, cDep);
|
2022-01-13 05:24:03 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
surface_set_target(_surf);
|
2023-03-19 09:17:39 +01:00
|
|
|
DRAW_CLEAR
|
2023-02-14 05:32:32 +01:00
|
|
|
BLEND_OVERRIDE;
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2022-12-21 02:30:23 +01:00
|
|
|
var uniform_dim = shader_get_uniform(shader, "dimension");
|
|
|
|
var uniform_tol = shader_get_uniform(shader, "tol");
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
shader_set(shader);
|
2023-02-14 05:32:32 +01:00
|
|
|
shader_set_uniform_f_array_safe(uniform_dim, [ ww, hh ]);
|
2022-01-13 05:24:03 +01:00
|
|
|
shader_set_uniform_f(uniform_tol, _data[2]);
|
|
|
|
draw_surface_ext_safe(_data[0], 0, 0, sc, sc, 0, c_white, 1);
|
|
|
|
shader_reset();
|
|
|
|
|
2023-02-14 05:32:32 +01:00
|
|
|
BLEND_NORMAL;
|
2022-01-13 05:24:03 +01:00
|
|
|
surface_reset_target();
|
|
|
|
|
2023-10-10 07:12:42 +02:00
|
|
|
if(isAtlas) {
|
|
|
|
if(_atlS) {
|
|
|
|
_outSurf.x = _data[0].x * sc;
|
|
|
|
_outSurf.y = _data[0].y * sc;
|
|
|
|
} else {
|
|
|
|
_outSurf.x = _data[0].x;
|
|
|
|
_outSurf.y = _data[0].y;
|
|
|
|
}
|
|
|
|
|
|
|
|
_outSurf.setSurface(_surf);
|
|
|
|
}
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
return _outSurf;
|
|
|
|
}
|
|
|
|
}
|