mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-23 11:28:06 +01:00
297 lines
No EOL
8.4 KiB
Text
297 lines
No EOL
8.4 KiB
Text
enum MATH_OPERATOR {
|
|
add,
|
|
subtract,
|
|
multiply,
|
|
divide,
|
|
power,
|
|
root,
|
|
|
|
sin,
|
|
cos,
|
|
tan,
|
|
|
|
modulo,
|
|
|
|
floor,
|
|
ceiling,
|
|
round,
|
|
|
|
lerp,
|
|
abs,
|
|
|
|
clamp,
|
|
snap,
|
|
}
|
|
|
|
#region create
|
|
global.node_math_keys = [ "add", "subtract", "multiply", "divide", "power", "root", "+", "-", "*", "/", "^",
|
|
"sin", "cos", "tan",
|
|
"modulo",
|
|
"round", "ceiling", "floor",
|
|
"lerp", "abs",
|
|
"clamp", "snap" ];
|
|
|
|
function Node_create_Math(_x, _y, _group = noone, _param = {}) {
|
|
var query = struct_try_get(_param, "query", "");
|
|
var node = new Node_Math(_x, _y, _group);
|
|
|
|
switch(query) { #region
|
|
case "add" :
|
|
case "+" :
|
|
node.inputs[| 0].setValue(MATH_OPERATOR.add); break;
|
|
case "subtract" :
|
|
case "-" :
|
|
node.inputs[| 0].setValue(MATH_OPERATOR.subtract); break;
|
|
case "multiply" :
|
|
case "*" :
|
|
node.inputs[| 0].setValue(MATH_OPERATOR.multiply); break;
|
|
case "divide" :
|
|
case "/" :
|
|
node.inputs[| 0].setValue(MATH_OPERATOR.divide); break;
|
|
case "power" :
|
|
case "^" :
|
|
node.inputs[| 0].setValue(MATH_OPERATOR.power); break;
|
|
case "root" : node.inputs[| 0].setValue(MATH_OPERATOR.root); break;
|
|
|
|
case "sin" : node.inputs[| 0].setValue(MATH_OPERATOR.sin); break;
|
|
case "cos" : node.inputs[| 0].setValue(MATH_OPERATOR.cos); break;
|
|
case "tan" : node.inputs[| 0].setValue(MATH_OPERATOR.tan); break;
|
|
|
|
case "modulo" : node.inputs[| 0].setValue(MATH_OPERATOR.modulo); break;
|
|
|
|
case "floor" : node.inputs[| 0].setValue(MATH_OPERATOR.floor); break;
|
|
case "ceiling" : node.inputs[| 0].setValue(MATH_OPERATOR.ceiling); break;
|
|
case "round" : node.inputs[| 0].setValue(MATH_OPERATOR.round); break;
|
|
|
|
case "lerp" : node.inputs[| 0].setValue(MATH_OPERATOR.lerp); break;
|
|
case "abs" : node.inputs[| 0].setValue(MATH_OPERATOR.abs); break;
|
|
|
|
case "clamp" : node.inputs[| 0].setValue(MATH_OPERATOR.clamp); break;
|
|
case "snap" : node.inputs[| 0].setValue(MATH_OPERATOR.snap); break;
|
|
} #endregion
|
|
|
|
return node;
|
|
}
|
|
#endregion
|
|
|
|
function Node_Math(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|
name = "Math";
|
|
color = COLORS.node_blend_number;
|
|
setDimension(96, 48);
|
|
|
|
inputs[| 0] = nodeValue("Type", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
|
.setDisplay(VALUE_DISPLAY.enum_scroll, [
|
|
/* 0 - 9*/ "Add", "Subtract", "Multiply", "Divide", "Power", "Root", "Sin", "Cos", "Tan", "Modulo",
|
|
/*10 - 20*/ "Floor", "Ceil", "Round", "Lerp", "Abs", "Clamp", "Snap" ])
|
|
.rejectArray();
|
|
|
|
inputs[| 1] = nodeValue("a", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0)
|
|
.setVisible(true, true);
|
|
|
|
inputs[| 2] = nodeValue("b", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0)
|
|
.setVisible(true, true);
|
|
|
|
inputs[| 3] = nodeValue("Degree angle", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true);
|
|
|
|
inputs[| 4] = nodeValue("To integer", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
|
|
|
|
inputs[| 5] = nodeValue("Amount", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0);
|
|
|
|
input_display_list = [
|
|
0, 1, 2, 5, 3, 4,
|
|
]
|
|
|
|
outputs[| 0] = nodeValue("Result", self, JUNCTION_CONNECT.output, VALUE_TYPE.float, 0);
|
|
|
|
use_mod = 0;
|
|
use_deg = false;
|
|
|
|
static _eval = function(a, b, c = 0) { #region
|
|
switch(use_mod) {
|
|
case MATH_OPERATOR.add : return a + b;
|
|
case MATH_OPERATOR.subtract : return a - b;
|
|
case MATH_OPERATOR.multiply : return a * b;
|
|
case MATH_OPERATOR.divide : return b == 0? 0 : a / b;
|
|
|
|
case MATH_OPERATOR.power : return power(a, b);
|
|
case MATH_OPERATOR.root : return b == 0? 0 : power(a, 1 / b);
|
|
|
|
case MATH_OPERATOR.sin : return sin(use_deg? degtorad(a) : a) * b;
|
|
case MATH_OPERATOR.cos : return cos(use_deg? degtorad(a) : a) * b;
|
|
case MATH_OPERATOR.tan : return tan(use_deg? degtorad(a) : a) * b;
|
|
case MATH_OPERATOR.modulo : return safe_mod(a, b);
|
|
|
|
case MATH_OPERATOR.floor : return floor(a);
|
|
case MATH_OPERATOR.ceiling : return ceil(a);
|
|
case MATH_OPERATOR.round : return round(a);
|
|
|
|
case MATH_OPERATOR.lerp : return lerp(a, b, c);
|
|
case MATH_OPERATOR.abs : return abs(a);
|
|
|
|
case MATH_OPERATOR.clamp : return clamp(a, b, c);
|
|
case MATH_OPERATOR.snap : return value_snap(a, b);
|
|
}
|
|
return 0;
|
|
} #endregion
|
|
|
|
static step = function() { #region
|
|
var mode = getInputData(0);
|
|
|
|
switch(mode) {
|
|
case MATH_OPERATOR.sin :
|
|
case MATH_OPERATOR.cos :
|
|
case MATH_OPERATOR.tan :
|
|
inputs[| 3].setVisible(true);
|
|
break;
|
|
default:
|
|
inputs[| 3].setVisible(false);
|
|
break;
|
|
}
|
|
|
|
switch(mode) {
|
|
case MATH_OPERATOR.round :
|
|
case MATH_OPERATOR.floor :
|
|
case MATH_OPERATOR.ceiling :
|
|
inputs[| 4].setVisible(true);
|
|
|
|
var int = getInputData(4);
|
|
if(int) outputs[| 0].setType(VALUE_TYPE.integer);
|
|
else outputs[| 0].setType(VALUE_TYPE.float);
|
|
break;
|
|
default:
|
|
inputs[| 4].setVisible(false);
|
|
|
|
outputs[| 0].setType(VALUE_TYPE.float);
|
|
break;
|
|
}
|
|
|
|
inputs[| 5].setVisible(false);
|
|
|
|
switch(mode) {
|
|
case MATH_OPERATOR.add :
|
|
case MATH_OPERATOR.subtract :
|
|
case MATH_OPERATOR.multiply :
|
|
case MATH_OPERATOR.divide :
|
|
case MATH_OPERATOR.power :
|
|
case MATH_OPERATOR.root :
|
|
case MATH_OPERATOR.modulo :
|
|
inputs[| 2].name = "b";
|
|
|
|
inputs[| 2].setVisible(true, true);
|
|
break;
|
|
|
|
case MATH_OPERATOR.sin :
|
|
case MATH_OPERATOR.cos :
|
|
case MATH_OPERATOR.tan :
|
|
inputs[| 2].name = "Amplitude";
|
|
|
|
inputs[| 2].setVisible(true, true);
|
|
break;
|
|
|
|
case MATH_OPERATOR.floor :
|
|
case MATH_OPERATOR.ceiling :
|
|
case MATH_OPERATOR.round :
|
|
case MATH_OPERATOR.abs :
|
|
inputs[| 2].setVisible(false);
|
|
break;
|
|
|
|
case MATH_OPERATOR.lerp :
|
|
inputs[| 2].name = "To";
|
|
inputs[| 5].name = "Amount";
|
|
|
|
inputs[| 2].setVisible(true, true);
|
|
inputs[| 5].setVisible(true, true);
|
|
break;
|
|
|
|
case MATH_OPERATOR.clamp :
|
|
inputs[| 2].name = "Min";
|
|
inputs[| 5].name = "Max";
|
|
|
|
inputs[| 2].setVisible(true, true);
|
|
inputs[| 5].setVisible(true, true);
|
|
break;
|
|
|
|
case MATH_OPERATOR.snap :
|
|
inputs[| 2].name = "Snap";
|
|
|
|
inputs[| 2].setVisible(true, true);
|
|
break;
|
|
|
|
default: return;
|
|
}
|
|
} #endregion
|
|
|
|
function evalArray(a, b, c = 0) { #region
|
|
var _as = is_array(a);
|
|
var _bs = is_array(b);
|
|
var _cs = is_array(c);
|
|
|
|
if(!_as && !_bs && !_cs)
|
|
return _eval(a, b, c);
|
|
|
|
if(!_as) a = [ a ];
|
|
if(!_bs) b = [ b ];
|
|
if(!_cs) c = [ c ];
|
|
|
|
var al = array_length(a);
|
|
var bl = array_length(b);
|
|
var cl = array_length(c);
|
|
|
|
var amo = max(al, bl, cl);
|
|
var val = array_create(amo);
|
|
|
|
for( var i = 0; i < amo; i++ )
|
|
val[i] = evalArray(
|
|
array_safe_get(a, i,, ARRAY_OVERFLOW.loop),
|
|
array_safe_get(b, i,, ARRAY_OVERFLOW.loop),
|
|
array_safe_get(c, i,, ARRAY_OVERFLOW.loop),
|
|
);
|
|
|
|
return val;
|
|
} #endregion
|
|
|
|
static update = function(frame = CURRENT_FRAME) { #region
|
|
use_mod = getInputData(0);
|
|
use_deg = getInputData(3);
|
|
|
|
var a = getInputData(1);
|
|
var b = getInputData(2);
|
|
var c = getInputData(5);
|
|
|
|
var val = evalArray(a, b, c);
|
|
outputs[| 0].setValue(val);
|
|
} #endregion
|
|
|
|
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { #region
|
|
draw_set_text(f_sdf, fa_center, fa_center, COLORS._main_text);
|
|
var str = "";
|
|
switch(getInputData(0)) {
|
|
case MATH_OPERATOR.add : str = "+"; break;
|
|
case MATH_OPERATOR.subtract : str = "-"; break;
|
|
case MATH_OPERATOR.multiply : str = "*"; break;
|
|
case MATH_OPERATOR.divide : str = "/"; break;
|
|
case MATH_OPERATOR.power : str = "pow"; break;
|
|
case MATH_OPERATOR.root : str = "root"; break;
|
|
|
|
case MATH_OPERATOR.sin : str = "sin"; break;
|
|
case MATH_OPERATOR.cos : str = "cos"; break;
|
|
case MATH_OPERATOR.tan : str = "tan"; break;
|
|
case MATH_OPERATOR.modulo : str = "mod"; break;
|
|
|
|
case MATH_OPERATOR.floor : str = "floor"; break;
|
|
case MATH_OPERATOR.ceiling : str = "ceil"; break;
|
|
case MATH_OPERATOR.round : str = "round"; break;
|
|
|
|
case MATH_OPERATOR.lerp : str = "lerp"; break;
|
|
case MATH_OPERATOR.abs : str = "abs"; break;
|
|
|
|
case MATH_OPERATOR.clamp : str = "clamp"; break;
|
|
case MATH_OPERATOR.snap : str = "snap"; break;
|
|
default: return;
|
|
}
|
|
|
|
var bbox = drawGetBbox(xx, yy, _s);
|
|
var ss = string_scale(str, bbox.w, bbox.h);
|
|
draw_text_transformed(bbox.xc, bbox.yc, str, ss * 0.8, ss * 0.8, 0);
|
|
} #endregion
|
|
} |