mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-23 11:28:06 +01:00
Fix several VFX bugs
This commit is contained in:
parent
20073fd98c
commit
73ebadbfaa
180 changed files with 927 additions and 532 deletions
|
@ -216,6 +216,7 @@
|
|||
{"name":"biterator","order":2,"path":"folders/VCT/biterator.yy",},
|
||||
{"name":"widget","order":3,"path":"folders/VCT/widget.yy",},
|
||||
{"name":"widgets","order":5,"path":"folders/widgets.yy",},
|
||||
{"name":"effector","order":18,"path":"folders/nodes/data/simulation/VFX/effector.yy",},
|
||||
],
|
||||
"ResourceOrderSettings": [
|
||||
{"name":"s_node_corner","order":16,"path":"sprites/s_node_corner/s_node_corner.yy",},
|
||||
|
@ -268,7 +269,7 @@
|
|||
{"name":"node_2d_light","order":1,"path":"scripts/node_2d_light/node_2d_light.yy",},
|
||||
{"name":"node_rigid_activation","order":7,"path":"scripts/node_rigid_activation/node_rigid_activation.yy",},
|
||||
{"name":"s_node_image_gif","order":4,"path":"sprites/s_node_image_gif/s_node_image_gif.yy",},
|
||||
{"name":"node_VFX_effect_wind","order":5,"path":"scripts/node_VFX_effect_wind/node_VFX_effect_wind.yy",},
|
||||
{"name":"node_VFX_effect_wind","order":7,"path":"scripts/node_VFX_effect_wind/node_VFX_effect_wind.yy",},
|
||||
{"name":"s_node_tunnel_out","order":22,"path":"sprites/s_node_tunnel_out/s_node_tunnel_out.yy",},
|
||||
{"name":"__background_set_element","order":3,"path":"scripts/__background_set_element/__background_set_element.yy",},
|
||||
{"name":"s_node_3d_obj","order":3,"path":"sprites/s_node_3d_obj/s_node_3d_obj.yy",},
|
||||
|
@ -679,7 +680,7 @@
|
|||
{"name":"fd_rectangle_get_pressure_height","order":16,"path":"scripts/fd_rectangle_get_pressure_height/fd_rectangle_get_pressure_height.yy",},
|
||||
{"name":"hyperbolic_function","order":16,"path":"scripts/hyperbolic_function/hyperbolic_function.yy",},
|
||||
{"name":"sh_rsh_rotate","order":1,"path":"shaders/sh_rsh_rotate/sh_rsh_rotate.yy",},
|
||||
{"name":"node_VFX_effect_destroy","order":12,"path":"scripts/node_VFX_effect_destroy/node_VFX_effect_destroy.yy",},
|
||||
{"name":"node_VFX_effect_destroy","order":3,"path":"scripts/node_VFX_effect_destroy/node_VFX_effect_destroy.yy",},
|
||||
{"name":"node_cache","order":9,"path":"scripts/node_cache/node_cache.yy",},
|
||||
{"name":"sh_bw","order":3,"path":"shaders/sh_bw/sh_bw.yy",},
|
||||
{"name":"var_comparison","order":1,"path":"scripts/var_comparison/var_comparison.yy",},
|
||||
|
@ -709,10 +710,10 @@
|
|||
{"name":"sh_threshold","order":18,"path":"shaders/sh_threshold/sh_threshold.yy",},
|
||||
{"name":"fd_rectangle_set_initial_value_pressure","order":3,"path":"scripts/fd_rectangle_set_initial_value_pressure/fd_rectangle_set_initial_value_pressure.yy",},
|
||||
{"name":"o_dialog_drag_folder","order":2,"path":"objects/o_dialog_drag_folder/o_dialog_drag_folder.yy",},
|
||||
{"name":"node_VFX_effect_repel","order":9,"path":"scripts/node_VFX_effect_repel/node_VFX_effect_repel.yy",},
|
||||
{"name":"node_VFX_effect_repel","order":4,"path":"scripts/node_VFX_effect_repel/node_VFX_effect_repel.yy",},
|
||||
{"name":"s_node_alpha_cut","order":3,"path":"sprites/s_node_alpha_cut/s_node_alpha_cut.yy",},
|
||||
{"name":"node_iterator_length","order":4,"path":"scripts/node_iterator_length/node_iterator_length.yy",},
|
||||
{"name":"node_VFX_effect_attract","order":8,"path":"scripts/node_VFX_effect_attract/node_VFX_effect_attract.yy",},
|
||||
{"name":"node_VFX_effect_attract","order":2,"path":"scripts/node_VFX_effect_attract/node_VFX_effect_attract.yy",},
|
||||
{"name":"sh_d3d_ssao_blur","order":1,"path":"shaders/sh_d3d_ssao_blur/sh_d3d_ssao_blur.yy",},
|
||||
{"name":"panel_addon","order":5,"path":"scripts/panel_addon/panel_addon.yy",},
|
||||
{"name":"s_node_text_splice","order":6,"path":"sprites/s_node_text_splice/s_node_text_splice.yy",},
|
||||
|
@ -923,7 +924,7 @@
|
|||
{"name":"color_selector","order":4,"path":"scripts/color_selector/color_selector.yy",},
|
||||
{"name":"node_trigger_bool","order":1,"path":"scripts/node_trigger_bool/node_trigger_bool.yy",},
|
||||
{"name":"s_node_strandSim_gravity","order":4,"path":"sprites/s_node_strandSim_gravity/s_node_strandSim_gravity.yy",},
|
||||
{"name":"node_VFX_effect_turbulence","order":11,"path":"scripts/node_VFX_effect_turbulence/node_VFX_effect_turbulence.yy",},
|
||||
{"name":"node_VFX_effect_turbulence","order":5,"path":"scripts/node_VFX_effect_turbulence/node_VFX_effect_turbulence.yy",},
|
||||
{"name":"action_loader","order":15,"path":"scripts/action_loader/action_loader.yy",},
|
||||
{"name":"sh_surface_replace_replace","order":1,"path":"shaders/sh_surface_replace_replace/sh_surface_replace_replace.yy",},
|
||||
{"name":"node_ase_file_read","order":14,"path":"scripts/node_ase_file_read/node_ase_file_read.yy",},
|
||||
|
@ -977,6 +978,7 @@
|
|||
{"name":"sh_blend_replace","order":50,"path":"shaders/sh_blend_replace/sh_blend_replace.yy",},
|
||||
{"name":"node_rigid_render","order":3,"path":"scripts/node_rigid_render/node_rigid_render.yy",},
|
||||
{"name":"node_image_splice_sheet","order":4,"path":"scripts/node_image_splice_sheet/node_image_splice_sheet.yy",},
|
||||
{"name":"node_VFX_renderer_output","order":17,"path":"scripts/node_VFX_renderer_output/node_VFX_renderer_output.yy",},
|
||||
{"name":"sh_posterize_palette","order":12,"path":"shaders/sh_posterize_palette/sh_posterize_palette.yy",},
|
||||
{"name":"fd_rectangle_set_material_maccormack_weight","order":6,"path":"scripts/fd_rectangle_set_material_maccormack_weight/fd_rectangle_set_material_maccormack_weight.yy",},
|
||||
{"name":"collection_data","order":9,"path":"scripts/collection_data/collection_data.yy",},
|
||||
|
@ -1062,7 +1064,7 @@
|
|||
{"name":"s_node_cache_array","order":25,"path":"sprites/s_node_cache_array/s_node_cache_array.yy",},
|
||||
{"name":"sh_blend_alpha_addition","order":13,"path":"shaders/sh_blend_alpha_addition/sh_blend_alpha_addition.yy",},
|
||||
{"name":"widget","order":25,"path":"scripts/widget/widget.yy",},
|
||||
{"name":"node_VFX_effect_vortex","order":10,"path":"scripts/node_VFX_effect_vortex/node_VFX_effect_vortex.yy",},
|
||||
{"name":"node_VFX_effect_vortex","order":6,"path":"scripts/node_VFX_effect_vortex/node_VFX_effect_vortex.yy",},
|
||||
{"name":"s_node_skew","order":11,"path":"sprites/s_node_skew/s_node_skew.yy",},
|
||||
{"name":"s_node_feedback_input","order":10,"path":"sprites/s_node_feedback_input/s_node_feedback_input.yy",},
|
||||
{"name":"s_node_path_builder","order":9,"path":"sprites/s_node_path_builder/s_node_path_builder.yy",},
|
||||
|
@ -1442,7 +1444,7 @@
|
|||
{"name":"s_node_3d_sphere","order":8,"path":"sprites/s_node_3d_sphere/s_node_3d_sphere.yy",},
|
||||
{"name":"fd_rectangle_replace_velocity","order":16,"path":"scripts/fd_rectangle_replace_velocity/fd_rectangle_replace_velocity.yy",},
|
||||
{"name":"s_node_group_thumbnail","order":34,"path":"sprites/s_node_group_thumbnail/s_node_group_thumbnail.yy",},
|
||||
{"name":"node_VFX_effector","order":6,"path":"scripts/node_VFX_effector/node_VFX_effector.yy",},
|
||||
{"name":"node_VFX_effector","order":8,"path":"scripts/node_VFX_effector/node_VFX_effector.yy",},
|
||||
{"name":"node_path_shift","order":5,"path":"scripts/node_path_shift/node_path_shift.yy",},
|
||||
{"name":"s_node_wav_file_write","order":17,"path":"sprites/s_node_wav_file_write/s_node_wav_file_write.yy",},
|
||||
{"name":"s_node_3d_cylinder","order":1,"path":"sprites/s_node_3d_cylinder/s_node_3d_cylinder.yy",},
|
||||
|
@ -1476,6 +1478,7 @@
|
|||
{"name":"fd_rectangle_add_material","order":4,"path":"scripts/fd_rectangle_add_material/fd_rectangle_add_material.yy",},
|
||||
{"name":"fd_rectangle_set_target","order":18,"path":"scripts/fd_rectangle_set_target/fd_rectangle_set_target.yy",},
|
||||
{"name":"node_wav_file_read","order":17,"path":"scripts/node_wav_file_read/node_wav_file_read.yy",},
|
||||
{"name":"s_node_vfx_render_output","order":12,"path":"sprites/s_node_vfx_render_output/s_node_vfx_render_output.yy",},
|
||||
{"name":"draw_line_dashed","order":7,"path":"scripts/draw_line_dashed/draw_line_dashed.yy",},
|
||||
{"name":"pseudo_regex","order":7,"path":"scripts/pseudo_regex/pseudo_regex.yy",},
|
||||
{"name":"node_invert","order":6,"path":"scripts/node_invert/node_invert.yy",},
|
||||
|
@ -1524,7 +1527,7 @@
|
|||
{"name":"fd_rectangle_get_material_height","order":10,"path":"scripts/fd_rectangle_get_material_height/fd_rectangle_get_material_height.yy",},
|
||||
{"name":"rangeBox","order":10,"path":"scripts/rangeBox/rangeBox.yy",},
|
||||
{"name":"s_node_array_copy","order":14,"path":"sprites/s_node_array_copy/s_node_array_copy.yy",},
|
||||
{"name":"node_VFX_effect_accelerate","order":7,"path":"scripts/node_VFX_effect_accelerate/node_VFX_effect_accelerate.yy",},
|
||||
{"name":"node_VFX_effect_accelerate","order":1,"path":"scripts/node_VFX_effect_accelerate/node_VFX_effect_accelerate.yy",},
|
||||
{"name":"node_flood_fill","order":11,"path":"scripts/node_flood_fill/node_flood_fill.yy",},
|
||||
{"name":"node_frame","order":1,"path":"scripts/node_frame/node_frame.yy",},
|
||||
{"name":"s_node_scale_algo","order":7,"path":"sprites/s_node_scale_algo/s_node_scale_algo.yy",},
|
||||
|
|
|
@ -250,6 +250,7 @@
|
|||
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"biterator","folderPath":"folders/VCT/biterator.yy",},
|
||||
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"widget","folderPath":"folders/VCT/widget.yy",},
|
||||
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"widgets","folderPath":"folders/widgets.yy",},
|
||||
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"effector","folderPath":"folders/nodes/data/simulation/VFX/effector.yy",},
|
||||
],
|
||||
"IncludedFiles": [
|
||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"ApolloHelp.html","ConfigValues":{"Itch":{"CopyToMask":"0",},},"CopyToMask":-1,"filePath":"datafiles",},
|
||||
|
@ -1618,6 +1619,7 @@
|
|||
{"id":{"name":"sh_blend_replace","path":"shaders/sh_blend_replace/sh_blend_replace.yy",},},
|
||||
{"id":{"name":"node_rigid_render","path":"scripts/node_rigid_render/node_rigid_render.yy",},},
|
||||
{"id":{"name":"node_image_splice_sheet","path":"scripts/node_image_splice_sheet/node_image_splice_sheet.yy",},},
|
||||
{"id":{"name":"node_VFX_renderer_output","path":"scripts/node_VFX_renderer_output/node_VFX_renderer_output.yy",},},
|
||||
{"id":{"name":"sh_posterize_palette","path":"shaders/sh_posterize_palette/sh_posterize_palette.yy",},},
|
||||
{"id":{"name":"fd_rectangle_set_material_maccormack_weight","path":"scripts/fd_rectangle_set_material_maccormack_weight/fd_rectangle_set_material_maccormack_weight.yy",},},
|
||||
{"id":{"name":"collection_data","path":"scripts/collection_data/collection_data.yy",},},
|
||||
|
@ -2196,6 +2198,7 @@
|
|||
{"id":{"name":"fd_rectangle_add_material","path":"scripts/fd_rectangle_add_material/fd_rectangle_add_material.yy",},},
|
||||
{"id":{"name":"fd_rectangle_set_target","path":"scripts/fd_rectangle_set_target/fd_rectangle_set_target.yy",},},
|
||||
{"id":{"name":"node_wav_file_read","path":"scripts/node_wav_file_read/node_wav_file_read.yy",},},
|
||||
{"id":{"name":"s_node_vfx_render_output","path":"sprites/s_node_vfx_render_output/s_node_vfx_render_output.yy",},},
|
||||
{"id":{"name":"draw_line_dashed","path":"scripts/draw_line_dashed/draw_line_dashed.yy",},},
|
||||
{"id":{"name":"pseudo_regex","path":"scripts/pseudo_regex/pseudo_regex.yy",},},
|
||||
{"id":{"name":"node_invert","path":"scripts/node_invert/node_invert.yy",},},
|
||||
|
|
|
@ -22,5 +22,13 @@
|
|||
"connectTo": {
|
||||
"key": "connectionType",
|
||||
"relations": {}
|
||||
},
|
||||
"context": {
|
||||
"key": "contextNode",
|
||||
"relations": {
|
||||
"Node_Fluid_Group": [ "Node_Fluid_Add", "Node_Fluid_Apply_Velocity", "Node_Fluid_Update", "Node_Fluid_Render", "Node_Fluid_Render_Output" ],
|
||||
"Node_Rigid_Group": [ "Node_Rigid_Object", "Node_Rigid_Force_Apply", "Node_Rigid_Render", "Node_Rigid_Render_Output" ],
|
||||
"Node_Strand_Group": [ "Node_Strand_Create", "Node_Strand_Gravity", "Node_Strand_Update", "Node_Strand_Render", "Node_Strand_Render_Texture" ]
|
||||
}
|
||||
}
|
||||
}
|
|
@ -318,17 +318,22 @@ event_inherited();
|
|||
} else if(ADD_NODE_PAGE == NODE_PAGE_DEFAULT) {
|
||||
_list = ds_list_create();
|
||||
|
||||
var sug = [];
|
||||
|
||||
if(node_called != noone) {
|
||||
var sug = nodeReleatedQuery(
|
||||
array_append(sug, nodeReleatedQuery(
|
||||
node_called.connect_type == JUNCTION_CONNECT.input? "connectTo" : "connectFrom",
|
||||
node_called.type
|
||||
);
|
||||
));
|
||||
}
|
||||
|
||||
if(array_length(sug)) {
|
||||
ds_list_add(_list, "Related");
|
||||
for( var i = 0, n = array_length(sug); i < n; i++ )
|
||||
ds_list_add(_list, ALL_NODES[? sug[i]]);
|
||||
}
|
||||
var _cont = PANEL_GRAPH.getCurrentContext();
|
||||
if(_cont != noone)
|
||||
array_append(sug, nodeReleatedQuery("context", instanceof(_cont)));
|
||||
if(array_length(sug)) {
|
||||
ds_list_add(_list, "Related");
|
||||
for( var i = 0, n = array_length(sug); i < n; i++ )
|
||||
ds_list_add(_list, ALL_NODES[? sug[i]]);
|
||||
}
|
||||
|
||||
ds_list_add(_list, "Favourites");
|
||||
|
|
|
@ -98,7 +98,7 @@ _HOVERING_ELEMENT = noone;
|
|||
if(PROJECT.animator.frame_progress) {
|
||||
__addon_preAnim();
|
||||
|
||||
if(PROJECT.animator.current_frame == 0)
|
||||
if(CURRENT_FRAME == 0)
|
||||
ResetAllNodesRender();
|
||||
Render(true);
|
||||
|
||||
|
|
|
@ -313,8 +313,8 @@ Project.fps = 0;
|
|||
|
||||
function lua_projectData(state) {
|
||||
lua_add_code(state, @"
|
||||
Project.frame = " + string(PROJECT.animator.current_frame) + @";
|
||||
Project.frameTotal = " + string(PROJECT.animator.frames_total) + @";
|
||||
Project.frame = " + string(CURRENT_FRAME) + @";
|
||||
Project.frameTotal = " + string(TOTAL_FRAMES) + @";
|
||||
Project.fps = " + string(PROJECT.animator.framerate) + @";
|
||||
");
|
||||
}
|
||||
|
|
|
@ -66,6 +66,8 @@ function __part(_node) constructor {
|
|||
ground_bounce = 0;
|
||||
ground_friction = 1;
|
||||
|
||||
frame = 0;
|
||||
|
||||
static reset = function() { #region
|
||||
gml_pragma("forceinline");
|
||||
|
||||
|
@ -85,7 +87,7 @@ function __part(_node) constructor {
|
|||
|
||||
life = _life;
|
||||
life_total = life;
|
||||
node.onPartCreate(self);
|
||||
if(node.onPartCreate != noone) node.onPartCreate(self);
|
||||
} #endregion
|
||||
|
||||
static setPhysic = function(_sx, _sy, _ac, _g, _gDir, _turn, _turnSpd) { #region
|
||||
|
@ -148,19 +150,20 @@ function __part(_node) constructor {
|
|||
alp_fade = _fade;
|
||||
} #endregion
|
||||
|
||||
static kill = function() { #region
|
||||
static kill = function(callDestroy = true) { #region
|
||||
gml_pragma("forceinline");
|
||||
|
||||
active = false;
|
||||
|
||||
node.onPartDestroy(self);
|
||||
if(callDestroy && node.onPartDestroy != noone)
|
||||
node.onPartDestroy(self);
|
||||
} #endregion
|
||||
|
||||
static step = function() { #region
|
||||
static step = function(frame = 0) { #region
|
||||
gml_pragma("forceinline");
|
||||
|
||||
if(!active) return;
|
||||
x += speedx;
|
||||
self.frame = frame;
|
||||
|
||||
random_set_seed(seed + life);
|
||||
|
||||
|
@ -192,7 +195,7 @@ function __part(_node) constructor {
|
|||
if(follow) rot = spVec[1];
|
||||
else rot += rot_s;
|
||||
|
||||
if(step_int > 0 && safe_mod(life, step_int) == 0)
|
||||
if(node.onPartStep != noone && step_int > 0 && safe_mod(life, step_int) == 0)
|
||||
node.onPartStep(self);
|
||||
if(life-- < 0) kill();
|
||||
|
||||
|
@ -235,15 +238,21 @@ function __part(_node) constructor {
|
|||
ss = surf[ping >= len? (len - 1) * 2 - ping : ping];
|
||||
break;
|
||||
case ANIM_END_ACTION.destroy:
|
||||
if(ind >= len) return;
|
||||
else ss = surf[ind];
|
||||
if(ind >= len) {
|
||||
//print($"Drawing part destroy when animation end");
|
||||
kill();
|
||||
return;
|
||||
} else ss = surf[ind];
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
var surface = is_instanceof(ss, SurfaceAtlas)? ss.getSurface() : node.surface_cache[$ ss];
|
||||
|
||||
if(!is_surface(surface)) return;
|
||||
if(!is_surface(surface)) {
|
||||
//print($"Drawing part failed: Not a surface");
|
||||
return;
|
||||
}
|
||||
|
||||
var lifeRat = 1 - life / life_total;
|
||||
var scCurve = sct.get(lifeRat);
|
||||
|
@ -268,12 +277,16 @@ function __part(_node) constructor {
|
|||
var x1 = _xx + s_w * 1.5;
|
||||
var y1 = _yy + s_h * 1.5;
|
||||
|
||||
if(x0 > surf_w || y0 > surf_h || x1 < 0 || y1 < 0) return; //culling
|
||||
if(x0 > surf_w || y0 > surf_h || x1 < 0 || y1 < 0) {
|
||||
//print($"Drawing part failed: Outside view");
|
||||
return; //culling
|
||||
}
|
||||
|
||||
var cc = (col == -1)? c_white : col.eval(lifeRat);
|
||||
if(blend != c_white) cc = colorMultiply(blend, cc);
|
||||
alp_draw = alp * alp_fade.get(lifeRat);
|
||||
|
||||
//print($"Draw part [{frame}]: {surface} at {_xx}, {_yy}, scale {drawsx}, {drawsy} - {scCurve} color {cc}, {alp_draw}");
|
||||
draw_surface_ext_safe(surface, _xx, _yy, scx, scy, drawrot, cc, alp_draw);
|
||||
} #endregion
|
||||
|
||||
|
|
|
@ -11,7 +11,7 @@ function __Node_Base(x, y) constructor {
|
|||
anim_priority = -999;
|
||||
|
||||
static step = function() {}
|
||||
static update = function(frame = PROJECT.animator.current_frame) {}
|
||||
static update = function(frame = CURRENT_FRAME) {}
|
||||
|
||||
static valueUpdate = function(index) {}
|
||||
static triggerRender = function() {}
|
||||
|
|
|
@ -145,7 +145,7 @@ function __Node_3D_Combine(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
_3d_clear_local_transform();
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dim = getInputData(0);
|
||||
var _lpos = getInputData(1);
|
||||
var _lrot = getInputData(2);
|
||||
|
|
|
@ -194,7 +194,7 @@ function __Node_3D_Obj(_x, _y, _group = noone) : Node(_x, _y, _group) constructo
|
|||
_3d_clear_local_transform();
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
if(!surface_exists(tex_surface)) reset_tex();
|
||||
|
||||
if(do_reset_material) {
|
||||
|
|
|
@ -170,7 +170,7 @@
|
|||
// _3d_clear_local_transform();
|
||||
// }
|
||||
|
||||
// static update = function(frame = PROJECT.animator.current_frame) {
|
||||
// static update = function(frame = CURRENT_FRAME) {
|
||||
// if(!surface_exists(tex_surface)) reset_tex();
|
||||
|
||||
// if(do_reset_material) {
|
||||
|
|
|
@ -162,7 +162,7 @@ function __Node_3D_Repeat(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
|||
inputs[| 21].setVisible(_proj);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dim = getInputData(0);
|
||||
var _lpos = getInputData(1);
|
||||
var _lrot = getInputData(2);
|
||||
|
|
|
@ -27,7 +27,7 @@ function Node_Iterator(_x, _y, _group = noone) : Node_Collection(_x, _y, _group)
|
|||
|
||||
static doInitLoop = function() {}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { initLoop(); }
|
||||
static update = function(frame = CURRENT_FRAME) { initLoop(); }
|
||||
|
||||
static outputNextNode = function() {
|
||||
LOG_BLOCK_START();
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -177,7 +177,6 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
scatter_index = 0;
|
||||
def_surface = -1;
|
||||
|
||||
current_data = [];
|
||||
surface_cache = {};
|
||||
|
||||
wiggle_maps = {
|
||||
|
@ -195,46 +194,46 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
for( var i = 0; i < attributes.part_amount; i++ )
|
||||
parts[i] = new __part(self);
|
||||
|
||||
static spawn = function(_time = PROJECT.animator.current_frame, _pos = -1) { #region
|
||||
var _inSurf = current_data[ 0];
|
||||
static spawn = function(_time = CURRENT_FRAME, _pos = -1) { #region
|
||||
var _inSurf = getInputData( 0);
|
||||
|
||||
var _spawn_amount = current_data[ 2];
|
||||
var _spawn_amount = getInputData( 2);
|
||||
|
||||
var _spawn_area = current_data[ 3];
|
||||
var _distrib = current_data[ 4];
|
||||
var _dist_map = current_data[30];
|
||||
var _scatter = current_data[24];
|
||||
var _spawn_area = getInputData( 3);
|
||||
var _distrib = getInputData( 4);
|
||||
var _dist_map = getInputData(30);
|
||||
var _scatter = getInputData(24);
|
||||
|
||||
var _life = current_data[ 5];
|
||||
var _direction = current_data[ 6];
|
||||
var _directCenter = current_data[29];
|
||||
var _velocity = current_data[18];
|
||||
var _life = getInputData( 5);
|
||||
var _direction = getInputData( 6);
|
||||
var _directCenter = getInputData(29);
|
||||
var _velocity = getInputData(18);
|
||||
|
||||
var _accel = current_data[ 7];
|
||||
var _grav = current_data[19];
|
||||
var _gvDir = current_data[33];
|
||||
var _turn = current_data[34];
|
||||
var _turnBi = current_data[35];
|
||||
var _turnSc = current_data[36];
|
||||
var _accel = getInputData( 7);
|
||||
var _grav = getInputData(19);
|
||||
var _gvDir = getInputData(33);
|
||||
var _turn = getInputData(34);
|
||||
var _turnBi = getInputData(35);
|
||||
var _turnSc = getInputData(36);
|
||||
|
||||
var _follow = current_data[15];
|
||||
var _rotation = current_data[ 8];
|
||||
var _rotation_speed = current_data[ 9];
|
||||
var _scale = current_data[10];
|
||||
var _size = current_data[17];
|
||||
var _follow = getInputData(15);
|
||||
var _rotation = getInputData( 8);
|
||||
var _rotation_speed = getInputData( 9);
|
||||
var _scale = getInputData(10);
|
||||
var _size = getInputData(17);
|
||||
|
||||
var _color = current_data[12];
|
||||
var _blend = current_data[28];
|
||||
var _alpha = current_data[13];
|
||||
var _color = getInputData(12);
|
||||
var _blend = getInputData(28);
|
||||
var _alpha = getInputData(13);
|
||||
|
||||
var _arr_type = current_data[22];
|
||||
var _anim_speed = current_data[23];
|
||||
var _anim_end = current_data[26];
|
||||
var _arr_type = getInputData(22);
|
||||
var _anim_speed = getInputData(23);
|
||||
var _anim_end = getInputData(26);
|
||||
|
||||
var _ground = current_data[37];
|
||||
var _ground_offset = current_data[38];
|
||||
var _ground_bounce = current_data[39];
|
||||
var _ground_frict = current_data[40];
|
||||
var _ground = getInputData(37);
|
||||
var _ground_offset = getInputData(38);
|
||||
var _ground_bounce = getInputData(39);
|
||||
var _ground_frict = getInputData(40);
|
||||
|
||||
if(_rotation[1] < _rotation[0]) _rotation[1] += 360;
|
||||
|
||||
|
@ -244,7 +243,8 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
var _amo = irandom_range(_spawn_amount[0], _spawn_amount[1]);
|
||||
if(_distrib == 2) _posDist = get_points_from_dist(_dist_map, _amo, seed);
|
||||
|
||||
//print($"Frame {_time}: Spawning {_amo} particles, seed {seed}, {irandom(99999999)}");
|
||||
//print($"[{display_name}] Frame {_time}: Spawning {_amo} particles, seed {seed}, at {_pos}");
|
||||
|
||||
for( var i = 0; i < _amo; i++ ) {
|
||||
seed += 100;
|
||||
random_set_seed(seed);
|
||||
|
@ -335,49 +335,60 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
|
||||
static updateParticleForward = function() {}
|
||||
|
||||
function reset() { #region
|
||||
spawn_index = 0;
|
||||
scatter_index = 0;
|
||||
for(var i = 0; i < array_length(parts); i++) {
|
||||
if(!parts[i].active) continue;
|
||||
parts[i].kill();
|
||||
static getSurfaceCache = function() { #region
|
||||
var surfs = getInputData(0);
|
||||
|
||||
if(!is_array(getInputData(0))) surfs = [ surfs ];
|
||||
if(!array_empty(getInputData(0))) {
|
||||
if(is_array(getInputData(0)))
|
||||
surfs = array_spread(surfs);
|
||||
for( var i = 0, n = array_length(surfs); i < n; i++ ) {
|
||||
if(is_surface(surface_cache[$ surfs[i]])) continue;
|
||||
surface_cache[$ surfs[i]] = surface_clone(surfs[i]);
|
||||
}
|
||||
}
|
||||
} #endregion
|
||||
|
||||
render();
|
||||
seed = getInputData(32);
|
||||
|
||||
var _wigg_pos = getInputData(41);
|
||||
var _wigg_rot = getInputData(42);
|
||||
var _wigg_sca = getInputData(43);
|
||||
var _wigg_dir = getInputData(20);
|
||||
|
||||
wiggle_maps.wig_psx.check(_wigg_pos[0], _wigg_pos[1], seed + 10);
|
||||
wiggle_maps.wig_psy.check(_wigg_pos[0], _wigg_pos[1], seed + 20);
|
||||
wiggle_maps.wig_rot.check(_wigg_rot[0], _wigg_rot[1], seed + 30);
|
||||
wiggle_maps.wig_scx.check(_wigg_sca[0], _wigg_sca[1], seed + 40);
|
||||
wiggle_maps.wig_scy.check(_wigg_sca[0], _wigg_sca[1], seed + 50);
|
||||
wiggle_maps.wig_dir.check(_wigg_dir[0], _wigg_dir[1], seed + 60);
|
||||
|
||||
var _curve_sca = getInputData(11);
|
||||
var _curve_alp = getInputData(14);
|
||||
|
||||
curve_scale = new curveMap(_curve_sca, PROJECT.animator.frames_total);
|
||||
curve_alpha = new curveMap(_curve_alp, PROJECT.animator.frames_total);
|
||||
function reset() { #region
|
||||
getInputs(0);
|
||||
|
||||
var keys = variable_struct_get_names(surface_cache);
|
||||
for( var i = 0, n = array_length(keys); i < n; i++ )
|
||||
surface_free_safe(surface_cache[$ keys[i]]);
|
||||
surface_cache = {};
|
||||
getSurfaceCache();
|
||||
|
||||
var _loop = getInputData(21);
|
||||
if(!_loop) return;
|
||||
spawn_index = 0;
|
||||
scatter_index = 0;
|
||||
|
||||
for(var i = 0; i < PROJECT.animator.frames_total; i++) {
|
||||
runVFX(i, false);
|
||||
updateParticleForward();
|
||||
for(var i = 0; i < array_length(parts); i++) {
|
||||
if(!parts[i].active) continue;
|
||||
parts[i].kill(false);
|
||||
}
|
||||
|
||||
seed = getInputData(32);
|
||||
#region ----- precomputes -----
|
||||
seed = getInputData(32);
|
||||
|
||||
var _wigg_pos = getInputData(41);
|
||||
var _wigg_rot = getInputData(42);
|
||||
var _wigg_sca = getInputData(43);
|
||||
var _wigg_dir = getInputData(20);
|
||||
|
||||
wiggle_maps.wig_psx.check(_wigg_pos[0], _wigg_pos[1], seed + 10);
|
||||
wiggle_maps.wig_psy.check(_wigg_pos[0], _wigg_pos[1], seed + 20);
|
||||
wiggle_maps.wig_rot.check(_wigg_rot[0], _wigg_rot[1], seed + 30);
|
||||
wiggle_maps.wig_scx.check(_wigg_sca[0], _wigg_sca[1], seed + 40);
|
||||
wiggle_maps.wig_scy.check(_wigg_sca[0], _wigg_sca[1], seed + 50);
|
||||
wiggle_maps.wig_dir.check(_wigg_dir[0], _wigg_dir[1], seed + 60);
|
||||
|
||||
var _curve_sca = getInputData(11);
|
||||
var _curve_alp = getInputData(14);
|
||||
|
||||
curve_scale = new curveMap(_curve_sca, TOTAL_FRAMES);
|
||||
curve_alpha = new curveMap(_curve_alp, TOTAL_FRAMES);
|
||||
#endregion
|
||||
|
||||
render();
|
||||
} #endregion
|
||||
|
||||
function checkPartPool() { #region
|
||||
|
@ -392,7 +403,7 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
}
|
||||
} #endregion
|
||||
|
||||
static runVFX = function(_time = PROJECT.animator.current_frame, _render = true) { #region
|
||||
static runVFX = function(_time = CURRENT_FRAME, _render = true) { #region
|
||||
var _spawn_delay = inputs[| 1].getValue(_time);
|
||||
var _spawn_type = inputs[| 16].getValue(_time);
|
||||
var _spawn_active = inputs[| 27].getValue(_time);
|
||||
|
@ -400,22 +411,8 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
|
||||
//print($"{_time} : {_spawn_trig} | {ds_list_to_array(inputs[| 44].animator.values)}");
|
||||
|
||||
for( var i = 0; i < ds_list_size(inputs); i++ )
|
||||
current_data[i] = inputs[| i].getValue(_time);
|
||||
|
||||
var surfs = current_data[0];
|
||||
|
||||
if(!is_array(current_data[0])) surfs = [ surfs ];
|
||||
if(!array_empty(current_data[0])) {
|
||||
if(is_array(current_data[0]))
|
||||
surfs = array_spread(surfs);
|
||||
for( var i = 0, n = array_length(surfs); i < n; i++ ) {
|
||||
if(is_surface(surface_cache[$ surfs[i]])) continue;
|
||||
surface_cache[$ surfs[i]] = surface_clone(surfs[i]);
|
||||
}
|
||||
}
|
||||
|
||||
//print(surface_cache);
|
||||
getInputs(_time);
|
||||
getSurfaceCache();
|
||||
|
||||
if(_spawn_active) {
|
||||
switch(_spawn_type) {
|
||||
|
@ -425,11 +422,16 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
}
|
||||
}
|
||||
|
||||
//var activeParts = 0;
|
||||
for(var i = 0; i < array_length(parts); i++) {
|
||||
if(!parts[i].active) continue;
|
||||
parts[i].step();
|
||||
//activeParts++;
|
||||
parts[i].step(_time);
|
||||
}
|
||||
|
||||
//print($"Run VFX frame {_time} seed {seed}");
|
||||
//print($"[{display_name}] Running VFX frame {_time}: {activeParts} active particles.");
|
||||
|
||||
if(!_render) return;
|
||||
|
||||
render(_time);
|
||||
|
@ -493,18 +495,18 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
|
||||
static onDrawOverlay = -1;
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
checkPartPool();
|
||||
onUpdate();
|
||||
onUpdate(frame);
|
||||
} #endregion
|
||||
|
||||
static onUpdate = function() {}
|
||||
static onUpdate = function(frame = CURRENT_FRAME) {}
|
||||
|
||||
static render = function() {}
|
||||
|
||||
static onPartCreate = function(part) {}
|
||||
static onPartStep = function(part) {}
|
||||
static onPartDestroy = function(part) {}
|
||||
static onPartCreate = noone;
|
||||
static onPartStep = noone;
|
||||
static onPartDestroy = noone;
|
||||
|
||||
static doSerialize = function(_map) { #region
|
||||
_map.part_base_length = input_len;
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
function Node_Fluid(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
||||
color = COLORS.node_blend_fluid;
|
||||
icon = THEME.fluid_sim;
|
||||
update_on_frame = true;
|
||||
|
||||
static updateForward = function(frame = PROJECT.animator.current_frame, _update = true) {
|
||||
static updateForward = function(frame = CURRENT_FRAME, _update = true) {
|
||||
if(_update) update(frame);
|
||||
//print($"Update {frame}: {name}");
|
||||
|
||||
|
|
|
@ -147,7 +147,7 @@ function _Node_Strand_Affector(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
|||
active &= inputs[| 3].drawOverlay(active, px, py, _s, _mx, _my, _snx, _sny, 0, 1, THEME.anchor_scale_hori);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _typ = getInputData(1);
|
||||
inputs[| 4].setVisible(_typ == 1);
|
||||
|
||||
|
|
|
@ -154,8 +154,8 @@ function __addon_lua_panel_variable(lua, panel) {
|
|||
);
|
||||
|
||||
lua_add_code(lua,
|
||||
"Animator.frame_current = " + string(PROJECT.animator.current_frame) + "\n" +
|
||||
"Animator.frame_total = " + string(PROJECT.animator.frames_total) + "\n" +
|
||||
"Animator.frame_current = " + string(CURRENT_FRAME) + "\n" +
|
||||
"Animator.frame_total = " + string(TOTAL_FRAMES) + "\n" +
|
||||
"Animator.frame_rate = " + string(PROJECT.animator.framerate) + "\n"
|
||||
);
|
||||
}
|
||||
|
|
|
@ -7,6 +7,8 @@
|
|||
}
|
||||
|
||||
#macro ANIMATION_STATIC !(PROJECT.animator.is_playing || PROJECT.animator.frame_progress)
|
||||
#macro CURRENT_FRAME PROJECT.animator.current_frame
|
||||
#macro TOTAL_FRAMES PROJECT.animator.frames_total
|
||||
#endregion
|
||||
|
||||
#region animation class
|
||||
|
|
|
@ -69,7 +69,7 @@ function ase_layer(name) constructor {
|
|||
cels[index] = cel;
|
||||
}
|
||||
|
||||
static getCel = function(index = PROJECT.animator.current_frame) {
|
||||
static getCel = function(index = CURRENT_FRAME) {
|
||||
var ind;
|
||||
|
||||
if(tag != noone) {
|
||||
|
|
|
@ -285,7 +285,7 @@ function curveBox(_onModify) : widget() constructor {
|
|||
var cc = merge_color(COLORS._main_icon, COLORS._main_icon_dark, 0.5);
|
||||
if(point_in_rectangle(_m[0], _m[1], bxF, byF, _x + _w, byF + byH)) {
|
||||
cc = COLORS._main_icon;
|
||||
if(mouse_click(mb_left, active))
|
||||
if(mouse_press(mb_left, active))
|
||||
zooming = true;
|
||||
}
|
||||
|
||||
|
|
|
@ -117,7 +117,7 @@ function __LOAD_PATH(path, readonly = false, safe_mode = false, override = false
|
|||
try {
|
||||
if(struct_has(_load_content, "animator")) {
|
||||
var _anim_map = _load_content.animator;
|
||||
PROJECT.animator.frames_total = _anim_map.frames_total;
|
||||
TOTAL_FRAMES = _anim_map.frames_total;
|
||||
PROJECT.animator.framerate = _anim_map.framerate;
|
||||
}
|
||||
} catch(e) {
|
||||
|
|
|
@ -107,7 +107,7 @@ function drawWidget(xx, yy, ww, _m, jun, global_var = true, _hover = false, _foc
|
|||
if(buttonInstant(THEME.button_hide, bx - ui(12), by - ui(12), ui(24), ui(24), _m, _focus, _hover, "", THEME.prop_keyframe, 2) == 2) {
|
||||
for(var j = 0; j < ds_list_size(jun.animator.values); j++) {
|
||||
var _key = jun.animator.values[| j];
|
||||
if(_key.time > PROJECT.animator.current_frame) {
|
||||
if(_key.time > CURRENT_FRAME) {
|
||||
PROJECT.animator.setFrame(_key.time);
|
||||
break;
|
||||
}
|
||||
|
@ -118,7 +118,7 @@ function drawWidget(xx, yy, ww, _m, jun, global_var = true, _hover = false, _foc
|
|||
var cc = COLORS.panel_animation_keyframe_unselected;
|
||||
var kfFocus = false;
|
||||
for(var j = 0; j < ds_list_size(jun.animator.values); j++) {
|
||||
if(jun.animator.values[| j].time == PROJECT.animator.current_frame) {
|
||||
if(jun.animator.values[| j].time == CURRENT_FRAME) {
|
||||
cc = COLORS.panel_animation_keyframe_selected;
|
||||
kfFocus = true;
|
||||
break;
|
||||
|
@ -130,18 +130,18 @@ function drawWidget(xx, yy, ww, _m, jun, global_var = true, _hover = false, _foc
|
|||
var _add = false;
|
||||
for(var j = 0; j < ds_list_size(jun.animator.values); j++) {
|
||||
var _key = jun.animator.values[| j];
|
||||
if(_key.time == PROJECT.animator.current_frame) {
|
||||
if(_key.time == CURRENT_FRAME) {
|
||||
if(ds_list_size(jun.animator.values) > 1)
|
||||
ds_list_delete(jun.animator.values, j);
|
||||
_add = true;
|
||||
break;
|
||||
} else if(_key.time > PROJECT.animator.current_frame) {
|
||||
ds_list_insert(jun.animator.values, j, new valueKey(PROJECT.animator.current_frame, jun.showValue(), jun.animator));
|
||||
} else if(_key.time > CURRENT_FRAME) {
|
||||
ds_list_insert(jun.animator.values, j, new valueKey(CURRENT_FRAME, jun.showValue(), jun.animator));
|
||||
_add = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(!_add) ds_list_add(jun.animator.values, new valueKey(PROJECT.animator.current_frame, jun.showValue(), jun.animator));
|
||||
if(!_add) ds_list_add(jun.animator.values, new valueKey(CURRENT_FRAME, jun.showValue(), jun.animator));
|
||||
}
|
||||
|
||||
bx -= ui(26);
|
||||
|
@ -149,7 +149,7 @@ function drawWidget(xx, yy, ww, _m, jun, global_var = true, _hover = false, _foc
|
|||
var _t = -1;
|
||||
for(var j = 0; j < ds_list_size(jun.animator.values); j++) {
|
||||
var _key = jun.animator.values[| j];
|
||||
if(_key.time < PROJECT.animator.current_frame)
|
||||
if(_key.time < CURRENT_FRAME)
|
||||
_t = _key.time;
|
||||
}
|
||||
if(_t > -1) PROJECT.animator.setFrame(_t);
|
||||
|
|
|
@ -36,7 +36,7 @@ function Node_VCT(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) const
|
|||
vct[$ inputs[| i].display_data.key].setDirect(_data[i]);
|
||||
|
||||
var params = {
|
||||
frame: PROJECT.animator.current_frame
|
||||
frame: CURRENT_FRAME
|
||||
};
|
||||
|
||||
return vct.process(params);
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -139,7 +139,7 @@ function Node_VFX_effector(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
onAffect(part, str);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var val = getInputData(0);
|
||||
outputs[| 0].setValue(val);
|
||||
if(val == -1) return;
|
||||
|
@ -162,4 +162,6 @@ function Node_VFX_effector(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
var bbox = drawGetBbox(xx, yy, _s);
|
||||
draw_sprite_fit(node_draw_icon, 0, bbox.xc, bbox.yc, bbox.w, bbox.h);
|
||||
}
|
||||
|
||||
getPreviewingNode = VFX_PREVIEW_NODE;
|
||||
}
|
|
@ -5,7 +5,7 @@
|
|||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
"name": "effector",
|
||||
"path": "folders/nodes/data/simulation/VFX/effector.yy",
|
||||
},
|
||||
}
|
|
@ -1,17 +1,76 @@
|
|||
function VFX_PREVIEW_NODE() {
|
||||
if(!is_instanceof(group, Node_VFX_Group)) return self;
|
||||
return group.getPreviewingNode();
|
||||
}
|
||||
|
||||
function Node_VFX_Group(_x, _y, _group = noone) : Node_Collection(_x, _y, _group) constructor {
|
||||
name = "VFX";
|
||||
color = COLORS.node_blend_vfx;
|
||||
icon = THEME.vfx;
|
||||
ungroupable = false;
|
||||
|
||||
topoList = ds_list_create();
|
||||
ungroupable = false;
|
||||
preview_node = noone;
|
||||
|
||||
inputs[| 0] = nodeValue("Loop", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true )
|
||||
.rejectArray();
|
||||
|
||||
custom_input_index = ds_list_size(inputs);
|
||||
|
||||
if(!LOADING && !APPENDING && !CLONING) {
|
||||
var input = nodeBuild("Node_VFX_Spawner", -256, -32, self);
|
||||
var renderer = nodeBuild("Node_VFX_Renderer", 256, -32, self);
|
||||
var output = nodeBuild("Node_Group_Output", 256 + 32 * 5, -32, self);
|
||||
var output = nodeBuild("Node_VFX_Renderer_Output", 256 + 32 * 5, -32, self);
|
||||
|
||||
renderer.inputs[| renderer.input_fix_len].setFrom(input.outputs[| 0]);
|
||||
output.inputs[| 0].setFrom(renderer.outputs[| 0]);
|
||||
output.inputs[| output.input_fix_len].setFrom(input.outputs[| 0]);
|
||||
preview_node = output;
|
||||
}
|
||||
|
||||
PATCH_STATIC
|
||||
static reset = function() {
|
||||
for( var i = 0, n = ds_list_size(nodes); i < n; i++ ) {
|
||||
var node = nodes[| i];
|
||||
if(is_instanceof(node, Node_VFX_Spawner_Base))
|
||||
node.reset();
|
||||
}
|
||||
|
||||
var loop = getInputData(0);
|
||||
if(!loop) return;
|
||||
|
||||
for( var i = 0; i < TOTAL_FRAMES; i++ )
|
||||
for( var j = 0, m = ds_list_size(topoList); j < m; j++ ) {
|
||||
var node = topoList[| j];
|
||||
if(is_instanceof(node, Node_VFX_Renderer_Output) ||
|
||||
is_instanceof(node, Node_VFX_Renderer)) continue;
|
||||
|
||||
node.update(i);
|
||||
}
|
||||
|
||||
for( var i = 0, n = ds_list_size(nodes); i < n; i++ ) {
|
||||
var node = nodes[| i];
|
||||
if(!is_instanceof(node, Node_VFX_Spawner_Base)) continue;
|
||||
|
||||
node.seed = node.getInputData(32);
|
||||
}
|
||||
}
|
||||
|
||||
static update = function() {
|
||||
if(CURRENT_FRAME == 0) {
|
||||
NodeListSort(topoList, nodes);
|
||||
reset();
|
||||
}
|
||||
}
|
||||
|
||||
static ononDoubleClick = function(panel) { #region
|
||||
preview_node = noone;
|
||||
|
||||
for( var i = 0, n = ds_list_size(nodes); i < n; i++ ) {
|
||||
var node = nodes[| i];
|
||||
if(is_instanceof(node, Node_VFX_Renderer_Output) ||
|
||||
is_instanceof(node, Node_VFX_Renderer)) {
|
||||
preview_node = node;
|
||||
break;
|
||||
}
|
||||
}
|
||||
} #endregion
|
||||
|
||||
getPreviewingNode = function() { return preview_node; }
|
||||
}
|
|
@ -29,7 +29,7 @@ function Node_VFX_Override(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
|
||||
outputs[| 0] = nodeValue("Particles", self, JUNCTION_CONNECT.output, VALUE_TYPE.particle, -1 );
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var parts = getInputData(0);
|
||||
if(!is_array(parts)) return;
|
||||
|
||||
|
@ -73,4 +73,6 @@ function Node_VFX_Override(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
var bbox = drawGetBbox(xx, yy, _s);
|
||||
draw_sprite_fit(node_draw_icon, 0, bbox.xc, bbox.yc, bbox.w, bbox.h);
|
||||
}
|
||||
|
||||
getPreviewingNode = VFX_PREVIEW_NODE;
|
||||
}
|
|
@ -34,7 +34,7 @@ function Node_VFX_Renderer(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
|
||||
static onInspector2Update = function() { clearCache(); }
|
||||
|
||||
static refreshDynamicInput = function() {
|
||||
static refreshDynamicInput = function() { #region
|
||||
var _l = ds_list_create();
|
||||
for( var i = 0; i < ds_list_size(inputs); i++ ) {
|
||||
if(i < input_fix_len || inputs[| i].value_from)
|
||||
|
@ -50,24 +50,27 @@ function Node_VFX_Renderer(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
inputs = _l;
|
||||
|
||||
createNewInput();
|
||||
}
|
||||
} #endregion
|
||||
|
||||
static onValueFromUpdate = function(index) {
|
||||
static onValueFromUpdate = function(index) { #region
|
||||
if(index < input_fix_len) return;
|
||||
if(LOADING || APPENDING) return;
|
||||
|
||||
refreshDynamicInput();
|
||||
}
|
||||
} #endregion
|
||||
|
||||
static step = function() {
|
||||
static step = function() { #region
|
||||
var _dim = getInputData(0);
|
||||
var _outSurf = outputs[| 0].getValue();
|
||||
|
||||
_outSurf = surface_verify(_outSurf, _dim[0], _dim[1], attrDepth());
|
||||
outputs[| 0].setValue(_outSurf);
|
||||
}
|
||||
|
||||
static update = function(_time = PROJECT.animator.current_frame) {
|
||||
if(previewing && is_instanceof(group, Node_VFX_Group))
|
||||
group.preview_node = self;
|
||||
} #endregion
|
||||
|
||||
static update = function(_time = CURRENT_FRAME) { #region
|
||||
if(!PROJECT.animator.is_playing) {
|
||||
recoverCache();
|
||||
return;
|
||||
|
@ -112,5 +115,7 @@ function Node_VFX_Renderer(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
surface_reset_shader();
|
||||
|
||||
cacheCurrentFrame(_outSurf);
|
||||
}
|
||||
} #endregion
|
||||
|
||||
getPreviewingNode = VFX_PREVIEW_NODE;
|
||||
}
|
165
scripts/node_VFX_renderer_output/node_VFX_renderer_output.gml
Normal file
165
scripts/node_VFX_renderer_output/node_VFX_renderer_output.gml
Normal file
|
@ -0,0 +1,165 @@
|
|||
function Node_VFX_Renderer_Output(_x, _y, _group = noone) : Node_Group_Output(_x, _y, _group) constructor {
|
||||
name = "Renderer";
|
||||
color = COLORS.node_blend_vfx;
|
||||
icon = THEME.vfx;
|
||||
use_cache = CACHE_USE.auto;
|
||||
|
||||
w = 128;
|
||||
h = 128;
|
||||
min_h = h;
|
||||
previewable = true;
|
||||
|
||||
inputs[| 0] = nodeValue("Output dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
||||
.setDisplay(VALUE_DISPLAY.vector);
|
||||
|
||||
inputs[| 1] = nodeValue("Round position", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true, "Round position to the closest integer value to avoid jittering.")
|
||||
.rejectArray();
|
||||
|
||||
inputs[| 2] = nodeValue("Blend mode", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0 )
|
||||
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Normal", "Alpha", "Additive" ])
|
||||
.rejectArray();
|
||||
|
||||
setIsDynamicInput(1);
|
||||
|
||||
attribute_surface_depth();
|
||||
attribute_interpolation();
|
||||
|
||||
insp2UpdateTooltip = "Clear cache";
|
||||
insp2UpdateIcon = [ THEME.cache, 0, COLORS._main_icon ];
|
||||
|
||||
static onInspector2Update = function() { clearCache(); }
|
||||
|
||||
static createNewInput = function() { #region
|
||||
var index = ds_list_size(inputs);
|
||||
inputs[| index] = nodeValue("Particles", self, JUNCTION_CONNECT.input, VALUE_TYPE.particle, noone )
|
||||
.setVisible(true, true);
|
||||
} if(!LOADING && !APPENDING) createNewInput(); #endregion
|
||||
|
||||
static createOutput = function(override_order = true) { #region
|
||||
if(group == noone) return;
|
||||
if(!is_struct(group)) return;
|
||||
|
||||
if(override_order)
|
||||
attributes.input_priority = ds_list_size(group.outputs);
|
||||
|
||||
if(!is_undefined(outParent))
|
||||
ds_list_remove(group.outputs, outParent);
|
||||
|
||||
outParent = nodeValue("Rendered", group, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone)
|
||||
.uncache()
|
||||
.setVisible(true, true);
|
||||
outParent.from = self;
|
||||
|
||||
ds_list_add(group.outputs, outParent);
|
||||
group.setHeight();
|
||||
group.sortIO();
|
||||
} if(!LOADING && !APPENDING) createOutput(); #endregion
|
||||
|
||||
static refreshDynamicInput = function() { #region
|
||||
var _l = ds_list_create();
|
||||
for( var i = 0; i < ds_list_size(inputs); i++ ) {
|
||||
if(i < input_fix_len || inputs[| i].value_from)
|
||||
ds_list_add(_l, inputs[| i]);
|
||||
else
|
||||
delete inputs[| i];
|
||||
}
|
||||
|
||||
for( var i = 0; i < ds_list_size(_l); i++ )
|
||||
_l[| i].index = i;
|
||||
|
||||
ds_list_destroy(inputs);
|
||||
inputs = _l;
|
||||
|
||||
createNewInput();
|
||||
} #endregion
|
||||
|
||||
static onValueFromUpdate = function(index) { #region
|
||||
if(index < input_fix_len) return;
|
||||
if(LOADING || APPENDING) return;
|
||||
|
||||
refreshDynamicInput();
|
||||
} #endregion
|
||||
|
||||
static step = function() { #region
|
||||
var _dim = getInputData(0);
|
||||
var _outSurf = outParent.getValue();
|
||||
|
||||
_outSurf = surface_verify(_outSurf, _dim[0], _dim[1], attrDepth());
|
||||
outParent.setValue(_outSurf);
|
||||
|
||||
if(previewing && is_instanceof(group, Node_VFX_Group))
|
||||
group.preview_node = self;
|
||||
} #endregion
|
||||
|
||||
static update = function(_time = CURRENT_FRAME) { #region
|
||||
if(!is_instanceof(outParent, NodeValue)) return noone;
|
||||
|
||||
var _dim = inputs[| 0].getValue(_time);
|
||||
var _exact = inputs[| 1].getValue(_time);
|
||||
var _blend = inputs[| 2].getValue(_time);
|
||||
|
||||
var _outSurf = outParent.getValue();
|
||||
|
||||
_outSurf = surface_verify(_outSurf, _dim[0], _dim[1], attrDepth());
|
||||
outParent.setValue(_outSurf);
|
||||
|
||||
surface_set_shader(_outSurf);
|
||||
shader_set_interpolation(_outSurf);
|
||||
|
||||
if(_blend == PARTICLE_BLEND_MODE.normal)
|
||||
BLEND_NORMAL;
|
||||
else if(_blend == PARTICLE_BLEND_MODE.alpha)
|
||||
BLEND_ALPHA;
|
||||
else if(_blend == PARTICLE_BLEND_MODE.additive)
|
||||
BLEND_ADD;
|
||||
|
||||
var surf_w = surface_get_width_safe(_outSurf);
|
||||
var surf_h = surface_get_height_safe(_outSurf);
|
||||
|
||||
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i++ ) {
|
||||
var parts = inputs[| i].getValue(_time);
|
||||
|
||||
if(!is_array(parts) || array_length(parts) == 0) continue;
|
||||
if(!is_array(parts[0])) parts = [ parts ];
|
||||
|
||||
//var drawnParts = 0;
|
||||
|
||||
for(var j = 0; j < array_length(parts); j++)
|
||||
for(var k = 0; k < array_length(parts[j]); k++) {
|
||||
if(!parts[j][k].active) continue;
|
||||
|
||||
//drawnParts++;
|
||||
parts[j][k].draw(_exact, surf_w, surf_h);
|
||||
}
|
||||
|
||||
//print($"Renderer input index {i}: {drawnParts} particles drawn.");
|
||||
}
|
||||
|
||||
BLEND_NORMAL;
|
||||
surface_reset_shader();
|
||||
|
||||
cacheCurrentFrame(_outSurf);
|
||||
} #endregion
|
||||
|
||||
static recoverCache = function(frame = CURRENT_FRAME) { #region
|
||||
if(!is_instanceof(outParent, NodeValue)) return false;
|
||||
if(!cacheExist(frame)) return false;
|
||||
|
||||
var _s = cached_output[CURRENT_FRAME];
|
||||
outParent.setValue(_s);
|
||||
|
||||
return true;
|
||||
} #endregion
|
||||
|
||||
static getGraphPreviewSurface = function() { #region
|
||||
if(!is_instanceof(outParent, NodeValue)) return noone;
|
||||
return outParent.getValue();
|
||||
} #endregion
|
||||
|
||||
static getPreviewValues = function() { #region
|
||||
if(!is_instanceof(outParent, NodeValue)) return noone;
|
||||
return outParent.getValue();
|
||||
} #endregion
|
||||
|
||||
getPreviewingNode = VFX_PREVIEW_NODE;
|
||||
}
|
11
scripts/node_VFX_renderer_output/node_VFX_renderer_output.yy
Normal file
11
scripts/node_VFX_renderer_output/node_VFX_renderer_output.yy
Normal file
|
@ -0,0 +1,11 @@
|
|||
{
|
||||
"resourceType": "GMScript",
|
||||
"resourceVersion": "1.0",
|
||||
"name": "node_VFX_renderer_output",
|
||||
"isCompatibility": false,
|
||||
"isDnD": false,
|
||||
"parent": {
|
||||
"name": "VFX",
|
||||
"path": "folders/nodes/data/simulation/VFX.yy",
|
||||
},
|
||||
}
|
|
@ -5,26 +5,24 @@ function Node_VFX_Spawner(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y
|
|||
|
||||
attributes.Output_pool = false;
|
||||
|
||||
inputs[| 21].setVisible(false, false);
|
||||
|
||||
inputs[| input_len + 0] = nodeValue("Spawn trigger", self, JUNCTION_CONNECT.input, VALUE_TYPE.node, false)
|
||||
.setVisible(true, true);
|
||||
|
||||
inputs[| input_len + 1] = nodeValue("Step interval", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1, "How often the 'on step' event is triggered.\nWith 1 being trigger every frame, 2 means triggered once every 2 frames.");
|
||||
|
||||
outputs[| 0] = nodeValue("Particles", self, JUNCTION_CONNECT.output, VALUE_TYPE.particle, [] );
|
||||
outputs[| 1] = nodeValue("On create", self, JUNCTION_CONNECT.output, VALUE_TYPE.node, noone );
|
||||
outputs[| 2] = nodeValue("On step", self, JUNCTION_CONNECT.output, VALUE_TYPE.node, noone );
|
||||
outputs[| 3] = nodeValue("On destroy", self, JUNCTION_CONNECT.output, VALUE_TYPE.node, noone );
|
||||
outputs[| 0] = nodeValue("Particles", self, JUNCTION_CONNECT.output, VALUE_TYPE.particle, [] );
|
||||
outputs[| 1] = nodeValue("On create", self, JUNCTION_CONNECT.output, VALUE_TYPE.node, noone );
|
||||
outputs[| 2] = nodeValue("On step", self, JUNCTION_CONNECT.output, VALUE_TYPE.node, noone );
|
||||
outputs[| 3] = nodeValue("On destroy", self, JUNCTION_CONNECT.output, VALUE_TYPE.node, noone );
|
||||
|
||||
array_insert(input_display_list, 0, ["Trigger", true], input_len + 0, input_len + 1);
|
||||
|
||||
UPDATE_PART_FORWARD
|
||||
|
||||
static onUpdate = function() { #region
|
||||
RETURN_ON_REST
|
||||
|
||||
if(PROJECT.animator.current_frame == 0)
|
||||
reset();
|
||||
runVFX(PROJECT.animator.current_frame);
|
||||
static onUpdate = function(frame = CURRENT_FRAME) { #region
|
||||
runVFX(frame);
|
||||
|
||||
if(attributes.Output_pool) {
|
||||
outputs[| 0].setValue(parts);
|
||||
|
@ -52,7 +50,7 @@ function Node_VFX_Spawner(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y
|
|||
for( var i = 0; i < ds_list_size(vt.value_to); i++ ) {
|
||||
var _n = vt.value_to[| i];
|
||||
if(_n.value_from != vt) continue;
|
||||
_n.node.spawn(, pv);
|
||||
_n.node.spawn(part.frame, pv);
|
||||
}
|
||||
} #endregion
|
||||
|
||||
|
@ -65,7 +63,7 @@ function Node_VFX_Spawner(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y
|
|||
for( var i = 0; i < ds_list_size(vt.value_to); i++ ) {
|
||||
var _n = vt.value_to[| i];
|
||||
if(_n.value_from != vt) continue;
|
||||
_n.node.spawn(, pv);
|
||||
_n.node.spawn(part.frame, pv);
|
||||
}
|
||||
} #endregion
|
||||
|
||||
|
@ -78,7 +76,7 @@ function Node_VFX_Spawner(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y
|
|||
for( var i = 0; i < ds_list_size(vt.value_to); i++ ) {
|
||||
var _n = vt.value_to[| i];
|
||||
if(_n.value_from != vt) continue;
|
||||
_n.node.spawn(, pv);
|
||||
_n.node.spawn(part.frame, pv);
|
||||
}
|
||||
} #endregion
|
||||
|
||||
|
@ -100,4 +98,5 @@ function Node_VFX_Spawner(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y
|
|||
draw_surface_align(spr, cx, cy, ss, fa_center, fa_center);
|
||||
} #endregion
|
||||
|
||||
getPreviewingNode = VFX_PREVIEW_NODE;
|
||||
}
|
|
@ -44,7 +44,7 @@ function Node_VFX_Variable(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
.setDisplay(VALUE_DISPLAY.vector)
|
||||
.setVisible(false);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var parts = getInputData(0);
|
||||
if(!is_array(parts)) return;
|
||||
|
||||
|
@ -75,4 +75,6 @@ function Node_VFX_Variable(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
var bbox = drawGetBbox(xx, yy, _s);
|
||||
draw_sprite_fit(node_draw_icon, 0, bbox.xc, bbox.yc, bbox.w, bbox.h);
|
||||
}
|
||||
|
||||
getPreviewingNode = VFX_PREVIEW_NODE;
|
||||
}
|
|
@ -26,7 +26,7 @@ function Node_Anim_Curve(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
|
|||
|
||||
static processData = function(_output, _data, _output_index, _array_index = 0) {
|
||||
var curve = _data[0];
|
||||
var time = _data[4]? PROJECT.animator.current_frame / (PROJECT.animator.frames_total - 1) : _data[1];
|
||||
var time = _data[4]? CURRENT_FRAME / (TOTAL_FRAMES - 1) : _data[1];
|
||||
var _min = _data[2];
|
||||
var _max = _data[3];
|
||||
var val = eval_curve_x(curve, time) * (_max - _min) + _min;
|
||||
|
|
|
@ -39,7 +39,7 @@ function Node_Animation_Control(_x, _y, _group = noone) : Node(_x, _y, _group) c
|
|||
|
||||
if(getInputData(5)) {
|
||||
var fr = getInputData(6);
|
||||
PROJECT.animator.setFrame(PROJECT.animator.current_frame + fr);
|
||||
PROJECT.animator.setFrame(CURRENT_FRAME + fr);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -563,7 +563,7 @@ function Node_Armature(_x, _y, _group = noone) : Node(_x, _y, _group) constructo
|
|||
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
outputs[| 0].setValue(attributes.bones);
|
||||
} #endregion
|
||||
|
||||
|
|
|
@ -236,7 +236,7 @@ function Node_Armature_Pose(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
if(_boneCount != _b.childCount()) setBone();
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
var _b = getInputData(0);
|
||||
if(_b == noone) return;
|
||||
|
||||
|
|
|
@ -146,7 +146,7 @@ function Node_Array(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|||
refreshDynamicInput();
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _typ = getType();
|
||||
|
||||
outputs[| 0].setType(_typ);
|
||||
|
|
|
@ -51,7 +51,7 @@ function Node_Array_Add(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
refreshDynamicInput();
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
|
||||
if(inputs[| 0].value_from == noone) {
|
||||
|
|
|
@ -31,7 +31,7 @@ function Node_Array_Composite(_x, _y, _group = noone) : Node(_x, _y, _group) con
|
|||
});
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
var _ker = getInputData(1);
|
||||
|
||||
|
|
|
@ -39,7 +39,7 @@ function Node_Array_Convolute(_x, _y, _group = noone) : Node(_x, _y, _group) con
|
|||
});
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
var _ker = getInputData(1);
|
||||
|
||||
|
|
|
@ -25,7 +25,7 @@ function Node_Array_Copy(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
outputs[| 0].setType(_typ);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
var _ind = getInputData(1);
|
||||
var _siz = getInputData(2);
|
||||
|
|
|
@ -14,7 +14,7 @@ function Node_Array_CSV_Parse(_x, _y, _group = noone) : Node(_x, _y, _group) con
|
|||
outputs[| 0] = nodeValue("Array", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0)
|
||||
.setArrayDepth(1);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _str = getInputData(0);
|
||||
var _skp = getInputData(1);
|
||||
|
||||
|
|
|
@ -15,7 +15,7 @@ function Node_Array_Find(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
|
||||
outputs[| 0] = nodeValue("Index", self, JUNCTION_CONNECT.output, VALUE_TYPE.integer, 0);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
|
||||
inputs[| 0].setType(VALUE_TYPE.any);
|
||||
|
|
|
@ -54,7 +54,7 @@ function Node_Array_Get(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
return array_safe_get(_arr, index);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
|
||||
if(!is_array(_arr)) return;
|
||||
|
|
|
@ -19,7 +19,7 @@ function Node_Array_Insert(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
|
||||
outputs[| 0] = nodeValue("Array", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
|
||||
inputs[| 0].setType(VALUE_TYPE.any);
|
||||
|
|
|
@ -11,7 +11,7 @@ function Node_Array_Length(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
|
||||
outputs[| 0] = nodeValue("Size", self, JUNCTION_CONNECT.output, VALUE_TYPE.integer, 0);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
inputs[| 0].setType(inputs[| 0].value_from == noone? VALUE_TYPE.any : inputs[| 0].value_from.type);
|
||||
|
||||
|
|
|
@ -15,7 +15,7 @@ function Node_Array_Range(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
|||
|
||||
outputs[| 0] = nodeValue("Array", self, JUNCTION_CONNECT.output, VALUE_TYPE.float, []);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var st = getInputData(0);
|
||||
var ed = getInputData(1);
|
||||
var step = getInputData(2);
|
||||
|
|
|
@ -42,7 +42,7 @@ function Node_Array_Remove(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
if(!is_array(_arr)) return;
|
||||
|
||||
|
|
|
@ -11,7 +11,7 @@ function Node_Array_Reverse(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
|
||||
outputs[| 0] = nodeValue("Array", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
|
||||
inputs[| 0].setType(VALUE_TYPE.any);
|
||||
|
|
|
@ -16,7 +16,7 @@ function Node_Array_Set(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
|
||||
outputs[| 0] = nodeValue("Array", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
|
||||
inputs[| 0].setType(VALUE_TYPE.any);
|
||||
|
|
|
@ -13,7 +13,7 @@ function Node_Array_Shift(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
|||
|
||||
outputs[| 0] = nodeValue("Array", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
var _shf = getInputData(1);
|
||||
|
||||
|
|
|
@ -12,7 +12,7 @@ function Node_Array_Shuffle(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
|
||||
outputs[| 0] = nodeValue("Shuffled array", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, []);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var arr = getInputData(0);
|
||||
var sed = getInputData(1);
|
||||
|
||||
|
|
|
@ -18,7 +18,7 @@ function Node_Array_Sort(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
static sortAcs = function(v1, v2) { return v1[1] < v2[1]; }
|
||||
static sortDes = function(v1, v2) { return v1[1] > v2[1]; }
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var arr = getInputData(0);
|
||||
var asc = getInputData(1);
|
||||
|
||||
|
|
|
@ -48,7 +48,7 @@ function Node_Array_Zip(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
refreshDynamicInput();
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _arr = getInputData(0);
|
||||
|
||||
if(inputs[| 0].value_from == noone) {
|
||||
|
|
|
@ -122,7 +122,7 @@ function Node_ASE_File_Read(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
var st = tag[? "Frame start"];
|
||||
var ed = tag[? "Frame end"];
|
||||
var rn = ed - st + 1;
|
||||
var progFr = safe_mod(PROJECT.animator.current_frame - _tag_delay, rn) + 1;
|
||||
var progFr = safe_mod(CURRENT_FRAME - _tag_delay, rn) + 1;
|
||||
var prog = progFr / rn;
|
||||
var txt = "";
|
||||
|
||||
|
@ -299,7 +299,7 @@ function Node_ASE_File_Read(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
}
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var path = getInputData(0);
|
||||
var current_tag = getInputData(2);
|
||||
if(path_current != path) updatePaths(path);
|
||||
|
@ -316,7 +316,7 @@ function Node_ASE_File_Read(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
_tag_delay = 0;
|
||||
for( var i = 0; i < ds_list_size(inputs[| 2].animator.values); i++ ) {
|
||||
var kf = inputs[| 2].animator.values[| i];
|
||||
if(kf.time > PROJECT.animator.current_frame) break;
|
||||
if(kf.time > CURRENT_FRAME) break;
|
||||
_tag_delay = kf.time;
|
||||
}
|
||||
|
||||
|
@ -333,7 +333,7 @@ function Node_ASE_File_Read(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
|
||||
for( var i = 0, n = array_length(layers); i < n; i++ ) {
|
||||
layers[i].tag = tag;
|
||||
var cel = layers[i].getCel(PROJECT.animator.current_frame - _tag_delay);
|
||||
var cel = layers[i].getCel(CURRENT_FRAME - _tag_delay);
|
||||
if(!cel) continue;
|
||||
if(!array_safe_get(vis, i, true)) continue;
|
||||
|
||||
|
|
|
@ -34,7 +34,7 @@ function Node_ASE_layer(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
}
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var data = getInputData(0);
|
||||
if(data == noone) return;
|
||||
|
||||
|
@ -44,7 +44,7 @@ function Node_ASE_layer(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
}
|
||||
|
||||
if(layer_object == noone) return;
|
||||
var cel = layer_object.getCel(PROJECT.animator.current_frame - data._tag_delay);
|
||||
var cel = layer_object.getCel(CURRENT_FRAME - data._tag_delay);
|
||||
|
||||
var celDim = getInputData(1);
|
||||
var ww = data.content[? "Width"];
|
||||
|
|
|
@ -12,7 +12,7 @@ function Node_Atlas_Draw(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
|
||||
attribute_interpolation(true);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var dim = getInputData(0);
|
||||
var atl = getInputData(1);
|
||||
|
||||
|
|
|
@ -25,7 +25,7 @@ function Node_Atlas_Get(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
outputs[| 5] = nodeValue("Alpha", self, JUNCTION_CONNECT.output, VALUE_TYPE.float, [])
|
||||
.setArrayDepth(1);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var atl = getInputData(0);
|
||||
|
||||
if(atl == noone) return;
|
||||
|
|
|
@ -27,7 +27,7 @@ function Node_Atlas_Set(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
|
||||
outputs[| 0] = nodeValue("Atlas", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var atl = getInputData(0);
|
||||
|
||||
if(atl == noone) return;
|
||||
|
|
|
@ -46,7 +46,7 @@ function Node_Audio_Window(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
|||
update_on_frame = _anim;
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _aud = getInputData(0);
|
||||
if(!is_instanceof(_aud, audioObject)) return;
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ function Node_Cache(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|||
cache_result[cache_loading_progress] = true;
|
||||
cache_loading_progress++;
|
||||
|
||||
if(cache_loading_progress == PROJECT.animator.frames_total) {
|
||||
if(cache_loading_progress == TOTAL_FRAMES) {
|
||||
cache_loading = false;
|
||||
update();
|
||||
}
|
||||
|
|
|
@ -49,13 +49,13 @@ function Node_Cache_Array(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
|||
var stp = getInputData(3);
|
||||
|
||||
if(str < 0) str = 1;
|
||||
if(lst < 0) lst = PROJECT.animator.frames_total;
|
||||
if(lst < 0) lst = TOTAL_FRAMES;
|
||||
|
||||
str -= 1;
|
||||
lst -= 1;
|
||||
|
||||
if(PROJECT.animator.current_frame < str) return;
|
||||
if(PROJECT.animator.current_frame > lst) return;
|
||||
if(CURRENT_FRAME < str) return;
|
||||
if(CURRENT_FRAME > lst) return;
|
||||
|
||||
if(lst > str && stp > 0)
|
||||
for( var i = str; i <= lst; i += stp ) {
|
||||
|
|
|
@ -990,10 +990,10 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
update_on_frame = fram > 1 && anim;
|
||||
|
||||
if(update_on_frame)
|
||||
preview_index = safe_mod(PROJECT.animator.current_frame * anims, fram);
|
||||
preview_index = safe_mod(CURRENT_FRAME * anims, fram);
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
var _dim = getInputData(0);
|
||||
var _bg = getInputData(8);
|
||||
var _bga = getInputData(9);
|
||||
|
@ -1035,7 +1035,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
}
|
||||
|
||||
if(_anim) {
|
||||
var _fr_index = safe_mod(PROJECT.animator.current_frame * _anims, _frames);
|
||||
var _fr_index = safe_mod(CURRENT_FRAME * _anims, _frames);
|
||||
outputs[| 0].setValue(output_surface[_fr_index]);
|
||||
} else
|
||||
outputs[| 0].setValue(output_surface);
|
||||
|
|
|
@ -156,12 +156,14 @@ function Node_Collection(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
|
||||
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
|
||||
if(!draw_input_overlay) return;
|
||||
|
||||
for(var i = custom_input_index; i < ds_list_size(inputs); i++) {
|
||||
var _in = inputs[| i];
|
||||
var _show = _in.from.getInputData(6);
|
||||
|
||||
if(!_show) continue;
|
||||
_in.drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
var _hov = _in.drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
if(_hov != undefined) active &= !_hov;
|
||||
}
|
||||
} #endregion
|
||||
|
||||
|
@ -296,7 +298,7 @@ function Node_Collection(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
static stepBegin = function() { #region
|
||||
use_cache = CACHE_USE.none;
|
||||
|
||||
array_safe_set(cache_result, PROJECT.animator.current_frame, true);
|
||||
array_safe_set(cache_result, CURRENT_FRAME, true);
|
||||
|
||||
var node_list = getNodeList();
|
||||
for(var i = 0; i < ds_list_size(node_list); i++) {
|
||||
|
@ -305,8 +307,8 @@ function Node_Collection(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
if(!_node.use_cache) continue;
|
||||
|
||||
use_cache = CACHE_USE.manual;
|
||||
if(!array_safe_get(_node.cache_result, PROJECT.animator.current_frame))
|
||||
array_safe_set(cache_result, PROJECT.animator.current_frame, false);
|
||||
if(!array_safe_get(_node.cache_result, CURRENT_FRAME))
|
||||
array_safe_set(cache_result, CURRENT_FRAME, false);
|
||||
}
|
||||
|
||||
var out_surf = false;
|
||||
|
@ -506,8 +508,12 @@ function Node_Collection(_x, _y, _group = noone) : Node(_x, _y, _group) construc
|
|||
|
||||
static onDoubleClick = function(panel) { #region
|
||||
panel.addContext(self);
|
||||
if(ononDoubleClick != noone)
|
||||
ononDoubleClick(panel);
|
||||
} #endregion
|
||||
|
||||
static ononDoubleClick = noone;
|
||||
|
||||
static getGraphPreviewSurface = function() { #region
|
||||
var _output_junc = outputs[| preview_channel];
|
||||
for( var i = 0, n = ds_list_size(nodes); i < n; i++ ) {
|
||||
|
|
|
@ -54,7 +54,7 @@ function Node_Compare(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
return 0;
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var mode = getInputData(0);
|
||||
var a = getInputData(1);
|
||||
var b = getInputData(2);
|
||||
|
|
|
@ -51,7 +51,7 @@ function Node_Condition(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
inputs[| 8].setVisible(_mode == 2, _mode == 2);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _true = getInputData(3);
|
||||
var _fals = getInputData(4);
|
||||
|
||||
|
|
|
@ -27,13 +27,13 @@ function Node_Counter(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) c
|
|||
}
|
||||
|
||||
static processData = function(_output, _data, _output_index, _array_index = 0) {
|
||||
var time = PROJECT.animator.current_frame;
|
||||
var time = CURRENT_FRAME;
|
||||
var mode = _data[2];
|
||||
var val = 0;
|
||||
|
||||
switch(mode) {
|
||||
case 0 : val = _data[0] + time * _data[1]; break;
|
||||
case 1 : val = time / (PROJECT.animator.frames_total - 1) * _data[1]; break;
|
||||
case 1 : val = time / (TOTAL_FRAMES - 1) * _data[1]; break;
|
||||
}
|
||||
|
||||
return val;
|
||||
|
|
|
@ -100,7 +100,7 @@ function Node_CSV_File_Read(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
update();
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var path = getInputData(0);
|
||||
if(path == "") return;
|
||||
if(path_current != path) updatePaths(path);
|
||||
|
|
|
@ -48,7 +48,7 @@ function Node_CSV_File_Write(_x, _y, _group = noone) : Node(_x, _y, _group) cons
|
|||
file_text_close(f);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { writeFile(); }
|
||||
static update = function(frame = CURRENT_FRAME) { writeFile(); }
|
||||
static onInspector1Update = function() { writeFile(); }
|
||||
|
||||
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) {
|
||||
|
|
|
@ -21,7 +21,7 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
ds_list_add(PANEL_GRAPH.getNodeList(_group), self);
|
||||
|
||||
active_index = -1;
|
||||
active_range = [ 0, PROJECT.animator.frames_total - 1 ];
|
||||
active_range = [ 0, TOTAL_FRAMES - 1 ];
|
||||
#endregion
|
||||
|
||||
static resetInternalName = function() { #region
|
||||
|
@ -163,6 +163,8 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
|
||||
preview_mx = 0;
|
||||
preview_my = 0;
|
||||
|
||||
getPreviewingNode = noone;
|
||||
#endregion
|
||||
|
||||
#region ---- rendering ----
|
||||
|
@ -434,11 +436,11 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
return array_safe_get(inputs_data, index, def);
|
||||
} #endregion
|
||||
|
||||
static getInputs = function() { #region
|
||||
static getInputs = function(frame = CURRENT_FRAME) { #region
|
||||
inputs_data = array_create(ds_list_size(inputs), undefined);
|
||||
|
||||
for(var i = 0; i < ds_list_size(inputs); i++)
|
||||
inputs_data[i] = inputs[| i].getValue(,,, false);
|
||||
inputs_data[i] = inputs[| i].getValue(frame,,, false);
|
||||
} #endregion
|
||||
|
||||
static forceUpdate = function() { #region
|
||||
|
@ -1187,26 +1189,26 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
} #endregion
|
||||
|
||||
static cacheArrayCheck = function() { #region
|
||||
if(array_length(cached_output) != PROJECT.animator.frames_total)
|
||||
array_resize(cached_output, PROJECT.animator.frames_total);
|
||||
if(array_length(cache_result) != PROJECT.animator.frames_total)
|
||||
array_resize(cache_result, PROJECT.animator.frames_total);
|
||||
if(array_length(cached_output) != TOTAL_FRAMES)
|
||||
array_resize(cached_output, TOTAL_FRAMES);
|
||||
if(array_length(cache_result) != TOTAL_FRAMES)
|
||||
array_resize(cache_result, TOTAL_FRAMES);
|
||||
} #endregion
|
||||
|
||||
static cacheCurrentFrame = function(_frame) { #region
|
||||
cacheArrayCheck();
|
||||
if(PROJECT.animator.current_frame < 0) return;
|
||||
if(PROJECT.animator.current_frame >= array_length(cached_output)) return;
|
||||
if(CURRENT_FRAME < 0) return;
|
||||
if(CURRENT_FRAME >= array_length(cached_output)) return;
|
||||
|
||||
surface_array_free(cached_output[PROJECT.animator.current_frame]);
|
||||
cached_output[PROJECT.animator.current_frame] = surface_array_clone(_frame);
|
||||
surface_array_free(cached_output[CURRENT_FRAME]);
|
||||
cached_output[CURRENT_FRAME] = surface_array_clone(_frame);
|
||||
|
||||
array_safe_set(cache_result, PROJECT.animator.current_frame, true);
|
||||
array_safe_set(cache_result, CURRENT_FRAME, true);
|
||||
|
||||
return cached_output[PROJECT.animator.current_frame];
|
||||
return cached_output[CURRENT_FRAME];
|
||||
} #endregion
|
||||
|
||||
static cacheExist = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static cacheExist = function(frame = CURRENT_FRAME) { #region
|
||||
if(frame < 0) return false;
|
||||
|
||||
if(frame >= array_length(cached_output)) return false;
|
||||
|
@ -1217,7 +1219,7 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
return is_array(s) || surface_exists(s);
|
||||
} #endregion
|
||||
|
||||
static getCacheFrame = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static getCacheFrame = function(frame = CURRENT_FRAME) { #region
|
||||
if(frame < 0) return false;
|
||||
|
||||
if(!cacheExist(frame)) return noone;
|
||||
|
@ -1225,10 +1227,10 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
return surf;
|
||||
} #endregion
|
||||
|
||||
static recoverCache = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static recoverCache = function(frame = CURRENT_FRAME) { #region
|
||||
if(!cacheExist(frame)) return false;
|
||||
|
||||
var _s = cached_output[PROJECT.animator.current_frame];
|
||||
var _s = cached_output[CURRENT_FRAME];
|
||||
outputs[| 0].setValue(_s);
|
||||
|
||||
return true;
|
||||
|
@ -1241,8 +1243,8 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
if(!use_cache) return;
|
||||
if(!isRenderActive()) return;
|
||||
|
||||
if(array_length(cached_output) != PROJECT.animator.frames_total)
|
||||
array_resize(cached_output, PROJECT.animator.frames_total);
|
||||
if(array_length(cached_output) != TOTAL_FRAMES)
|
||||
array_resize(cached_output, TOTAL_FRAMES);
|
||||
for(var i = 0; i < array_length(cached_output); i++) {
|
||||
var _s = cached_output[i];
|
||||
if(is_surface(_s))
|
||||
|
@ -1715,5 +1717,5 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
|||
return surface_get_format(_s);
|
||||
} #endregion
|
||||
|
||||
static toString = function() { return $"PixelComposerNode: {node_id}[{internalName}] {input_hash}"; }
|
||||
static toString = function() { return $"PixelComposerNode [{internalName}]: {node_id}"; }
|
||||
}
|
|
@ -71,7 +71,7 @@ function Node_Display_Image(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
|||
return false;
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var path = getInputData(0);
|
||||
if(path == "") return;
|
||||
if(path_current != path) updatePaths(path);
|
||||
|
|
|
@ -100,7 +100,7 @@ function Node_Dust(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|||
_outSurf = surface_verify(_outSurf, _dim[0], _dim[1]);
|
||||
outputs[| 0].setValue(_outSurf);
|
||||
|
||||
if(PROJECT.animator.current_frame == 0) {
|
||||
if(CURRENT_FRAME == 0) {
|
||||
dusts = [ new __Dust( 0, _dim[1] / 2 ) ];
|
||||
} else {
|
||||
for( var i = 0, n = array_length(dusts); i < n; i++ )
|
||||
|
|
|
@ -51,7 +51,7 @@ function Node_DynaSurf_In(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
|||
}
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
if(is_undefined(inParent)) return;
|
||||
var _val = inParent.getValue();
|
||||
|
||||
|
|
|
@ -108,7 +108,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
inputs[| 11] = nodeValue("Sequence begin", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0);
|
||||
|
||||
inputs[| 12] = nodeValue("Frame range", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [0, -1])
|
||||
.setDisplay(VALUE_DISPLAY.slider_range, { range: [0, PROJECT.animator.frames_total, 1] });
|
||||
.setDisplay(VALUE_DISPLAY.slider_range, { range: [0, TOTAL_FRAMES, 1] });
|
||||
|
||||
png_format = [ "INDEX4", "INDEX8", "Default (PNG32)" ];
|
||||
png_format_r = [ "PNG4", "PNG8" ];
|
||||
|
@ -369,12 +369,12 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
var float_str = string_digits(str);
|
||||
if(float_str != "") {
|
||||
var float_val = string_digits(float_str);
|
||||
var str_val = max(float_val - string_length(string(PROJECT.animator.current_frame + strt)), 0);
|
||||
var str_val = max(float_val - string_length(string(CURRENT_FRAME + strt)), 0);
|
||||
repeat(str_val)
|
||||
_txt += "0";
|
||||
}
|
||||
|
||||
_txt += string(PROJECT.animator.current_frame + strt);
|
||||
_txt += string(CURRENT_FRAME + strt);
|
||||
if(_array) array_push(s, [ "f", _txt ]);
|
||||
else s += _txt;
|
||||
res = true;
|
||||
|
@ -510,10 +510,10 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
|
||||
if(form >= 1) {
|
||||
var rng_s = rang[0];
|
||||
var rng_e = rang[1] == -1? PROJECT.animator.frames_total : rang[1];
|
||||
var rng_e = rang[1] == -1? TOTAL_FRAMES : rang[1];
|
||||
|
||||
if(PROJECT.animator.current_frame < rng_s) return;
|
||||
if(PROJECT.animator.current_frame > rng_e) return;
|
||||
if(CURRENT_FRAME < rng_s) return;
|
||||
if(CURRENT_FRAME > rng_e) return;
|
||||
}
|
||||
|
||||
if(is_array(surf)) {
|
||||
|
@ -523,7 +523,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
if(!is_surface(_surf)) continue;
|
||||
|
||||
if(form == NODE_EXPORT_FORMAT.gif) {
|
||||
p = directory + "/" + string(i) + "/" + string_lead_zero(PROJECT.animator.current_frame, 5) + ".png";
|
||||
p = directory + "/" + string(i) + "/" + string_lead_zero(CURRENT_FRAME, 5) + ".png";
|
||||
} else {
|
||||
if(is_array(path) && array_length(path) == array_length(surf))
|
||||
p = pathString(path[ safe_mod(i, array_length(path)) ], i);
|
||||
|
@ -546,7 +546,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
if(is_array(path)) p = path[0];
|
||||
|
||||
if(form == NODE_EXPORT_FORMAT.gif)
|
||||
p = directory + "/" + string_lead_zero(PROJECT.animator.current_frame, 5) + ".png";
|
||||
p = directory + "/" + string_lead_zero(CURRENT_FRAME, 5) + ".png";
|
||||
else
|
||||
p = pathString(p);
|
||||
|
||||
|
@ -596,7 +596,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
playing = true;
|
||||
played = 0;
|
||||
PROJECT.animator.real_frame = -1;
|
||||
PROJECT.animator.current_frame = -1;
|
||||
CURRENT_FRAME = -1;
|
||||
PROJECT.animator.is_playing = true;
|
||||
PROJECT.animator.rendering = true;
|
||||
|
||||
|
@ -628,7 +628,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
inputs[| 8].setVisible(anim == 2);
|
||||
inputs[| 11].setVisible(anim == 1);
|
||||
inputs[| 12].setVisible(anim > 0);
|
||||
inputs[| 12].editWidget.maxx = PROJECT.animator.frames_total;
|
||||
inputs[| 12].editWidget.maxx = TOTAL_FRAMES;
|
||||
inputs[| 13].setVisible(anim < 2);
|
||||
|
||||
if(anim == NODE_EXPORT_FORMAT.gif) {
|
||||
|
@ -644,7 +644,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
outputs[| 0].visible = isInLoop();
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
var anim = getInputData(3);
|
||||
if(anim == NODE_EXPORT_FORMAT.single) {
|
||||
if(isInLoop()) export();
|
||||
|
@ -656,12 +656,12 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
return;
|
||||
}
|
||||
|
||||
if(!PROJECT.animator.frame_progress || !playing || PROJECT.animator.current_frame <= -1)
|
||||
if(!PROJECT.animator.frame_progress || !playing || CURRENT_FRAME <= -1)
|
||||
return;
|
||||
|
||||
export();
|
||||
|
||||
if(PROJECT.animator.current_frame < PROJECT.animator.frames_total - 1)
|
||||
if(CURRENT_FRAME < TOTAL_FRAMES - 1)
|
||||
return;
|
||||
|
||||
if(anim != NODE_EXPORT_FORMAT.gif)
|
||||
|
|
|
@ -15,7 +15,7 @@ function Node_Feedback_Input(_x, _y, _group = noone) : Node_Group_Input(_x, _y,
|
|||
_node_output = vt;
|
||||
}
|
||||
|
||||
if(PROJECT.animator.current_frame > 0 && _node_output != noone && _node_output.node.cache_value != noone) //use cache from output
|
||||
if(CURRENT_FRAME > 0 && _node_output != noone && _node_output.node.cache_value != noone) //use cache from output
|
||||
return [ _node_output.node.cache_value, inParent ];
|
||||
|
||||
return outputs[| 0].getValueDefault();
|
||||
|
|
|
@ -11,9 +11,9 @@ function Node_Feedback_Output(_x, _y, _group = noone) : Node_Group_Output(_x, _y
|
|||
|
||||
cache_value = -1;
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
if(inputs[| 0].value_from == noone) return;
|
||||
if(PROJECT.animator.current_frame == PROJECT.animator.frames_total - 1) {
|
||||
if(CURRENT_FRAME == TOTAL_FRAMES - 1) {
|
||||
cache_value = noone;
|
||||
return;
|
||||
}
|
||||
|
|
|
@ -54,7 +54,7 @@ function Node_Fluid_Add(_x, _y, _group = noone) : Node_Fluid(_x, _y, _group) con
|
|||
inputs[| 2].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dom = inputs[| 0].getValue(frame);
|
||||
var _mat = inputs[| 1].getValue(frame);
|
||||
var _pos = inputs[| 2].getValue(frame);
|
||||
|
|
|
@ -34,7 +34,7 @@ function Node_Fluid_Add_Collider(_x, _y, _group = noone) : Node_Fluid(_x, _y, _g
|
|||
inputs[| 2].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dom = inputs[| 0].getValue(frame);
|
||||
var _mat = inputs[| 1].getValue(frame);
|
||||
var _area = inputs[| 2].getValue(frame);
|
||||
|
|
|
@ -39,7 +39,7 @@ function Node_Fluid_Apply_Velocity(_x, _y, _group = noone) : Node_Fluid(_x, _y,
|
|||
inputs[| 2].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dom = inputs[| 0].getValue(frame);
|
||||
var _mat = inputs[| 1].getValue(frame);
|
||||
var _pos = inputs[| 2].getValue(frame);
|
||||
|
|
|
@ -51,7 +51,7 @@ function Node_Fluid_Domain(_x, _y, _group = noone) : Node_Fluid(_x, _y, _group)
|
|||
domain = fd_rectangle_create(256, 256);
|
||||
_dim_old = [0, 0];
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
RETURN_ON_REST
|
||||
|
||||
var _dim = inputs[| 0].getValue(frame);
|
||||
|
@ -67,7 +67,7 @@ function Node_Fluid_Domain(_x, _y, _group = noone) : Node_Fluid(_x, _y, _group)
|
|||
var vMac = inputs[| 10].getValue(frame);
|
||||
var wrap = inputs[| 11].getValue(frame);
|
||||
|
||||
if(PROJECT.animator.current_frame == 0 || !is_surface(domain.sf_world)) {
|
||||
if(CURRENT_FRAME == 0 || !is_surface(domain.sf_world)) {
|
||||
fd_rectangle_clear(domain);
|
||||
fd_rectangle_destroy(domain);
|
||||
domain = fd_rectangle_create(_dim[0], _dim[1]);
|
||||
|
|
|
@ -41,7 +41,7 @@ function Node_Fluid_Render(_x, _y, _group = noone) : Node_Fluid(_x, _y, _group)
|
|||
}
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
if(recoverCache() || !PROJECT.animator.is_playing)
|
||||
return;
|
||||
|
||||
|
|
|
@ -45,7 +45,7 @@ function Node_Fluid_Render_Output(_x, _y, _group = noone) : Node_Group_Output(_x
|
|||
if(!is_undefined(outParent))
|
||||
ds_list_remove(group.outputs, outParent);
|
||||
|
||||
outParent = nodeValue("Value", group, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone)
|
||||
outParent = nodeValue("Rendered", group, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone)
|
||||
.uncache()
|
||||
.setVisible(true, true);
|
||||
outParent.from = self;
|
||||
|
@ -60,7 +60,7 @@ function Node_Fluid_Render_Output(_x, _y, _group = noone) : Node_Group_Output(_x
|
|||
outParent.name = display_name;
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
if(!is_instanceof(outParent, NodeValue)) return noone;
|
||||
|
||||
var _dim = inputs[| 1].getValue(frame);
|
||||
|
@ -94,11 +94,11 @@ function Node_Fluid_Render_Output(_x, _y, _group = noone) : Node_Group_Output(_x
|
|||
cacheCurrentFrame(_outSurf);
|
||||
} #endregion
|
||||
|
||||
static recoverCache = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static recoverCache = function(frame = CURRENT_FRAME) { #region
|
||||
if(!is_instanceof(outParent, NodeValue)) return false;
|
||||
if(!cacheExist(frame)) return false;
|
||||
|
||||
var _s = cached_output[PROJECT.animator.current_frame];
|
||||
var _s = cached_output[CURRENT_FRAME];
|
||||
outParent.setValue(_s);
|
||||
|
||||
return true;
|
||||
|
|
|
@ -37,7 +37,7 @@ function Node_Fluid_Repulse(_x, _y, _group = noone) : Node_Fluid(_x, _y, _group)
|
|||
inputs[| 2].drawOverlay(active, px, py, _s, _mx, _my, _snx, _sny, 0, 1, THEME.anchor_scale_hori);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dom = inputs[| 0].getValue(frame);
|
||||
var _pos = inputs[| 1].getValue(frame);
|
||||
var _rad = inputs[| 2].getValue(frame);
|
||||
|
|
|
@ -81,7 +81,7 @@ function Node_Fluid_Group(_x, _y, _group = noone) : Node_Collection(_x, _y, _gro
|
|||
var vMac = getInputData(10);
|
||||
var wrap = getInputData(11);
|
||||
|
||||
if(PROJECT.animator.current_frame == 0 || !is_surface(domain.sf_world)) {
|
||||
if(CURRENT_FRAME == 0 || !is_surface(domain.sf_world)) {
|
||||
fd_rectangle_clear(domain);
|
||||
fd_rectangle_destroy(domain);
|
||||
domain = fd_rectangle_create(_dim[0], _dim[1]);
|
||||
|
|
|
@ -31,7 +31,7 @@ function Node_Fluid_Turbulence(_x, _y, _group = noone) : Node_Fluid(_x, _y, _gro
|
|||
inputs[| 1].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dom = inputs[| 0].getValue(frame);
|
||||
var _are = inputs[| 1].getValue(frame);
|
||||
var _str = inputs[| 2].getValue(frame);
|
||||
|
@ -57,11 +57,9 @@ function Node_Fluid_Turbulence(_x, _y, _group = noone) : Node_Fluid(_x, _y, _gro
|
|||
shader_reset();
|
||||
surface_reset_target();
|
||||
|
||||
with(_dom) {
|
||||
fd_rectangle_set_target(id, _mod? FD_TARGET_TYPE.ADD_VELOCITY : FD_TARGET_TYPE.REPLACE_VELOCITY);
|
||||
draw_surface_safe(vSurface, 0, 0);
|
||||
fd_rectangle_reset_target(id);
|
||||
}
|
||||
fd_rectangle_set_target(_dom, _mod? FD_TARGET_TYPE.ADD_VELOCITY : FD_TARGET_TYPE.REPLACE_VELOCITY);
|
||||
draw_surface_safe(vSurface, 0, 0);
|
||||
fd_rectangle_reset_target(_dom);
|
||||
|
||||
surface_free(vSurface);
|
||||
}
|
||||
|
|
|
@ -17,7 +17,7 @@ function Node_Fluid_Update(_x, _y, _group = noone) : Node_Fluid(_x, _y, _group)
|
|||
|
||||
outputs[| 0] = nodeValue("Fluid Domain", self, JUNCTION_CONNECT.output, VALUE_TYPE.fdomain, noone);
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
if(!PROJECT.animator.is_playing) return;
|
||||
|
||||
var _dom = inputs[| 0].getValue(frame);
|
||||
|
|
|
@ -41,7 +41,7 @@ function Node_Fluid_Vortex(_x, _y, _group = noone) : Node_Fluid(_x, _y, _group)
|
|||
inputs[| 2].drawOverlay(active, px, py, _s, _mx, _my, _snx, _sny, 0, 1, THEME.anchor_scale_hori);
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var _dom = inputs[| 0].getValue(frame);
|
||||
var _pos = inputs[| 1].getValue(frame);
|
||||
var _rad = inputs[| 2].getValue(frame);
|
||||
|
|
|
@ -135,7 +135,7 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
|||
|
||||
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
|
||||
if(inParent.isArray()) return;
|
||||
inParent.drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
return inParent.drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||
} #endregion
|
||||
|
||||
static onValueUpdate = function(index = 0) { #region
|
||||
|
@ -358,7 +358,7 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
|||
|
||||
PATCH_STATIC
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
if(is_undefined(inParent)) return;
|
||||
} #endregion
|
||||
|
||||
|
|
|
@ -92,6 +92,7 @@ function __generate_node_data() { #region
|
|||
|
||||
for( var i = 0, n = array_length(_keys); i < n; i++ ) {
|
||||
var _group = _json[$ _keys[i]];
|
||||
|
||||
if(!struct_has(_rel, _keys[i]))
|
||||
_rel[$ _keys[i]] = { relations : {} };
|
||||
var _Vgroup = _rel[$ _keys[i]].relations;
|
||||
|
@ -105,6 +106,13 @@ function __generate_node_data() { #region
|
|||
array_append(_Vgroup[$ _k], _group.relations[$ _types[j]]);
|
||||
}
|
||||
break;
|
||||
case "contextNode" :
|
||||
var _nodes = variable_struct_get_names(_group.relations);
|
||||
for( var j = 0, m = array_length(_nodes); j < m; j++ ) {
|
||||
if(!struct_has(_Vgroup, _nodes[j])) _Vgroup[$ _nodes[j]] = [];
|
||||
array_append(_Vgroup[$ _nodes[j]], _group.relations[$ _nodes[j]]);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -91,7 +91,7 @@ function Node_Image(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|||
update();
|
||||
}
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) {
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var path = getInputData(0);
|
||||
var pad = getInputData(1);
|
||||
if(path == "") return;
|
||||
|
|
|
@ -59,7 +59,7 @@ function Node_Image_Animated(_x, _y, _group = noone) : Node(_x, _y, _group) cons
|
|||
inputs[| 5] = nodeValue("Set animation length to match", self, JUNCTION_CONNECT.input, VALUE_TYPE.trigger, 0)
|
||||
.setDisplay(VALUE_DISPLAY.button, { name: "Match length", onClick: function() {
|
||||
if(array_length(spr) == 0) return;
|
||||
PROJECT.animator.frames_total = array_length(spr);
|
||||
TOTAL_FRAMES = array_length(spr);
|
||||
} });
|
||||
|
||||
inputs[| 6] = nodeValue("Custom frame order", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
|
||||
|
@ -149,7 +149,7 @@ function Node_Image_Animated(_x, _y, _group = noone) : Node(_x, _y, _group) cons
|
|||
inputs[| 4].setVisible(!_cus && !str);
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
var path = getInputData(0);
|
||||
if(path == "") return;
|
||||
if(is_array(path) && !array_equals(path, path_loaded))
|
||||
|
@ -161,9 +161,9 @@ function Node_Image_Animated(_x, _y, _group = noone) : Node(_x, _y, _group) cons
|
|||
var _cus = getInputData(6);
|
||||
var _str = getInputData(2);
|
||||
var _end = getInputData(4);
|
||||
var _spd = _str? (PROJECT.animator.frames_total + 1) / array_length(spr) : 1 / getInputData(3);
|
||||
var _spd = _str? (TOTAL_FRAMES + 1) / array_length(spr) : 1 / getInputData(3);
|
||||
if(_spd == 0) _spd = 1;
|
||||
var _frame = _cus? getInputData(7) : floor(PROJECT.animator.current_frame / _spd);
|
||||
var _frame = _cus? getInputData(7) : floor(CURRENT_FRAME / _spd);
|
||||
|
||||
var _len = array_length(spr);
|
||||
var _drw = true;
|
||||
|
|
|
@ -35,7 +35,7 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
.setDisplay(VALUE_DISPLAY.button, { name: "Match length", onClick: function() {
|
||||
if(!spr) return;
|
||||
if(!sprite_exists(spr)) return;
|
||||
PROJECT.animator.frames_total = sprite_get_number(spr);
|
||||
TOTAL_FRAMES = sprite_get_number(spr);
|
||||
PROJECT.animator.framerate = 12;
|
||||
} });
|
||||
|
||||
|
@ -138,7 +138,7 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
}
|
||||
} #endregion
|
||||
|
||||
static update = function(frame = PROJECT.animator.current_frame) { #region
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
var path = getInputData(0);
|
||||
if(path == "") return;
|
||||
if(path_current != path) updatePaths(path);
|
||||
|
@ -176,7 +176,7 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
var _strt = getInputData(4);
|
||||
var _cust = getInputData(5);
|
||||
var _spd = getInputData(7);
|
||||
var _frm = _cust? getInputData(6) : PROJECT.animator.current_frame * _spd - _strt;
|
||||
var _frm = _cust? getInputData(6) : CURRENT_FRAME * _spd - _strt;
|
||||
|
||||
var _len = sprite_get_number(spr);
|
||||
var _drw = true;
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue