mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2024-11-11 04:54:06 +01:00
128 lines
3.7 KiB
Plaintext
128 lines
3.7 KiB
Plaintext
function Node_create_Wiggler(_x, _y) {
|
|
var node = new Node_Wiggler(_x, _y);
|
|
ds_list_add(PANEL_GRAPH.nodes_list, node);
|
|
return node;
|
|
}
|
|
|
|
function Node_Wiggler(_x, _y) : Node_Value_Processor(_x, _y) constructor {
|
|
name = "Wiggler";
|
|
update_on_frame = true;
|
|
previewable = false;
|
|
|
|
w = 96;
|
|
min_h = 0;
|
|
|
|
inputs[| 0] = nodeValue(0, "Value", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0);
|
|
|
|
inputs[| 1] = nodeValue(1, "Range", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 1 );
|
|
|
|
inputs[| 2] = nodeValue(2, "Frequency", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 3, 5 ] )
|
|
.setDisplay(VALUE_DISPLAY.slider_range, [1, 32, 1]);
|
|
|
|
inputs[| 3] = nodeValue(3, "Seed", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, irandom(9999999) );
|
|
|
|
inputs[| 4] = nodeValue(4, "Display", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1 )
|
|
.setDisplay(VALUE_DISPLAY.enum_scroll, ["Number", "Graph"])
|
|
|
|
outputs[| 0] = nodeValue(0, "Output", self, JUNCTION_CONNECT.output, VALUE_TYPE.float, 0);
|
|
|
|
input_display_list = [
|
|
["Display", true], 4,
|
|
["Wiggle", false], 3, 0, 1, 2,
|
|
];
|
|
|
|
graph_value = array_create(64, 0);
|
|
|
|
static onValueUpdate = function(index) {
|
|
var val = inputs[| 0].getValue();
|
|
var ran = inputs[| 1].getValue();
|
|
var fre = inputs[| 2].getValue();
|
|
var sed = inputs[| 3].getValue();
|
|
|
|
var _min = val - ran;
|
|
var _max = val + ran;
|
|
var _fmin = ANIMATOR.frames_total / max(1, min(fre[0], fre[1]));
|
|
var _fmax = ANIMATOR.frames_total / max(1, max(fre[0], fre[1]));
|
|
var _val;
|
|
|
|
for( var i = 0; i < 64; i++ ) {
|
|
_val = getWiggle(_min, _max, _fmin, _fmax, i, sed);
|
|
graph_value[i] = _val;
|
|
}
|
|
}
|
|
|
|
function process_value_data(_data, index = 0) {
|
|
if(array_length(graph_value) != ANIMATOR.frames_total)
|
|
array_resize(graph_value, ANIMATOR.frames_total);
|
|
|
|
var time = ANIMATOR.current_frame;
|
|
var _min = _data[0] - _data[1];
|
|
var _max = _data[0] + _data[1];
|
|
var _fmin = ANIMATOR.frames_total / max(1, min(_data[2][0], _data[2][1]));
|
|
var _fmax = ANIMATOR.frames_total / max(1, max(_data[2][0], _data[2][1]));
|
|
|
|
var _val = getWiggle(_min, _max, _fmin, _fmax, time, _data[3]);
|
|
return _val;
|
|
}
|
|
|
|
doUpdate();
|
|
|
|
static onDrawNode = function(xx, yy, _mx, _my, _s) {
|
|
var disp = inputs[| 4].getValue();
|
|
var time = ANIMATOR.current_frame;
|
|
var total_time = ANIMATOR.frames_total;
|
|
|
|
switch(disp) {
|
|
case 0 :
|
|
min_h = 0;
|
|
draw_set_text(f_h5, fa_center, fa_center, c_white);
|
|
var str = string(outputs[| 0].getValue());
|
|
var ss = string_scale(str, (w - 16) * _s, (h - 16) * _s - 20);
|
|
draw_text_transformed(xx + w / 2 * _s, yy + 10 + h / 2 * _s, str, ss, ss, 0);
|
|
break;
|
|
case 1 :
|
|
w = 128;
|
|
min_h = 96;
|
|
|
|
var val = inputs[| 0].getValue();
|
|
var ran = inputs[| 1].getValue();
|
|
var fre = inputs[| 2].getValue();
|
|
var sed = inputs[| 3].getValue();
|
|
|
|
var _min = val - ran;
|
|
var _max = val + ran;
|
|
var _fmin = max(1, fre[0]);
|
|
var _fmax = max(1, fre[1]);
|
|
|
|
var x0 = xx + 8 * _s;
|
|
var x1 = xx + (w - 8) * _s;
|
|
var y0 = yy + 20 + 8 * _s;
|
|
var y1 = yy + (h - 8) * _s;
|
|
var ww = x1 - x0;
|
|
var hh = y1 - y0;
|
|
|
|
var yc = (y0 + y1) / 2;
|
|
draw_set_color(c_ui_blue_grey);
|
|
draw_line(x0, yc, x1, yc);
|
|
var _fx = x0 + (time / total_time * ww);
|
|
draw_line(_fx, y0, _fx, y1);
|
|
|
|
var lw = ww / (array_length(graph_value) - 1);
|
|
draw_set_color(c_white);
|
|
var ox, oy;
|
|
for( var i = 0; i < array_length(graph_value); i++ ) {
|
|
var _x = x0 + i * lw;
|
|
var _y = yc - (graph_value[i] - val) / (ran * 2) * hh;
|
|
if(i)
|
|
draw_line(ox, oy, _x, _y);
|
|
|
|
ox = _x;
|
|
oy = _y;
|
|
}
|
|
|
|
draw_set_color(c_ui_blue_grey);
|
|
draw_rectangle(x0, y0, x1, y1, true);
|
|
break;
|
|
}
|
|
}
|
|
} |