This commit is contained in:
Tanasart 2024-11-12 09:39:57 +07:00
parent 3952101495
commit 7f15c0fbd3
11 changed files with 96 additions and 64 deletions

View file

@ -31,25 +31,29 @@ function Node_ASE_layer(_x, _y, _group = noone) : Node(_x, _y, _group) construct
var data = getInputDataForce(0);
if(data == noone) return;
var name = getInputData(2);
setDisplayName(name);
var _lname = getInputData(2);
setDisplayName(_lname);
for( var i = 0, n = array_length(data.layers); i < n; i++ ) {
if(data.layers[i].name == name)
if(data.layers[i].name == _lname)
layer_object = data.layers[i];
}
}
static update = function(frame = CURRENT_FRAME) {
findLayer();
if(layer_object == noone) return;
var data = getInputData(0);
var cel = layer_object.getCel(CURRENT_FRAME - data._tag_delay);
var data = getInputData(0);
var celDim = getInputData(1);
var name = getInputData(2);
var _lname = getInputData(2);
outputs[1].setValue(_lname);
if(layer_object == noone) {
logNode($"Layer name {_lname} not found.");
return;
}
var cel = layer_object.getCel(CURRENT_FRAME - data._tag_delay);
var ww = data.content[$ "Width"];
var hh = data.content[$ "Height"];
var cw = cel? cel.data[$ "Width"] : 1;
@ -59,7 +63,8 @@ function Node_ASE_layer(_x, _y, _group = noone) : Node(_x, _y, _group) construct
if(celDim) surf = surface_verify(surf, cw, ch);
else surf = surface_verify(surf, ww, hh);
outputs[0].setValue(surf);
outputs[1].setValue(name);
print($"Setting layer name {_lname}");
if(cel == 0) { surface_clear(surf); return; }

View file

@ -2143,17 +2143,30 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
cache_result = array_verify(cache_result, TOTAL_FRAMES);
}
static cacheCurrentFrame = function(_frame) {
static cacheCurrentFrame = function(_surface) {
cacheArrayCheck();
if(CURRENT_FRAME < 0) return;
if(CURRENT_FRAME >= array_length(cached_output)) return;
var _frame = CURRENT_FRAME;
if(_frame < 0) return;
if(_frame >= array_length(cached_output)) return;
surface_array_free(cached_output[CURRENT_FRAME]);
cached_output[CURRENT_FRAME] = surface_array_clone(_frame);
if(is_array(_surface)) {
surface_array_free(cached_output[_frame]);
cached_output[_frame] = surface_array_clone(_surface);
} else if(surface_exists(_surface)) {
var _sw = surface_get_width(_surface);
var _sh = surface_get_height(_surface);
cached_output[_frame] = surface_verify(cached_output[_frame], _sw, _sh);
surface_set_target(cached_output[_frame]);
DRAW_CLEAR BLEND_OVERRIDE
draw_surface(_surface, 0, 0);
surface_reset_target();
}
array_safe_set(cache_result, CURRENT_FRAME, true);
array_safe_set(cache_result, _frame, true);
return cached_output[CURRENT_FRAME];
return cached_output[_frame];
}
static cacheExist = function(frame = CURRENT_FRAME) {

View file

@ -60,7 +60,7 @@ function Node_Interlaced(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
var _fram = CURRENT_FRAME - _back;
if(_loop) _fram = (_fram + TOTAL_FRAMES) % TOTAL_FRAMES;
var _prev = array_safe_get_fast(cached_output, _fram, noone);
var _prev = getCacheFrameIndex(_array_index, _fram);
surface_set_shader(_outSurf, sh_interlaced);
shader_set_i("useSurf", is_surface(_prev));
@ -74,7 +74,7 @@ function Node_Interlaced(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
draw_surface_safe(_surf);
surface_reset_shader();
cacheCurrentFrame(_surf);
cacheCurrentFrameIndex(_array_index, _surf);
__process_mask_modifier(_data);
_outSurf = mask_apply(_data[0], _outSurf, _data[2], _data[3]);

View file

@ -86,7 +86,6 @@ function Node_MK_Delay_Machine(_x, _y, _group = noone) : Node(_x, _y, _group) co
}
aa = eval_curve_x(_alpC, 1 - i / _amo);
draw_surface_ext(_s, 0, 0, 1, 1, 0, cc, aa);
}

View file

@ -411,25 +411,43 @@ function Node_Processor(_x, _y, _group = noone) : Node(_x, _y, _group) construct
///////////////////// CACHE /////////////////////
static cacheCurrentFrameIndex = function(_frame, index) {
static cacheCurrentFrameIndex = function(_aindex, _surface) {
cacheArrayCheck();
if(CURRENT_FRAME < 0) return;
if(CURRENT_FRAME >= array_length(cached_output)) return;
var _frame = CURRENT_FRAME;
if(_frame < 0) return;
if(_frame >= array_length(cached_output)) return;
var prev = cached_output[CURRENT_FRAME];
surface_array_free(array_safe_get_fast(prev, index));
cached_output[CURRENT_FRAME][index] = surface_array_clone(_frame);
var _surfs = cached_output[_frame];
var _cache = array_safe_get_fast(_surfs, _aindex);
array_safe_set(cache_result, CURRENT_FRAME, true);
if(is_array(_surface)) {
surface_array_free(_cache);
_surfs[_aindex] = surface_array_clone(_surface);
} else if(surface_exists(_surface)) {
var _sw = surface_get_width(_surface);
var _sh = surface_get_height(_surface);
_cache = surface_verify(_cache, _sw, _sh);
surface_set_target(_cache);
DRAW_CLEAR BLEND_OVERRIDE
draw_surface(_surface, 0, 0);
surface_reset_target();
_surfs[_aindex] = _cache;
}
return cached_output[CURRENT_FRAME];
cached_output[_frame] = _surfs;
array_safe_set(cache_result, _frame, true);
return cached_output[_frame];
}
static getCacheFrameIndex = function(frame = CURRENT_FRAME, index = 0) {
if(frame < 0) return false;
if(!cacheExist(frame)) return noone;
static getCacheFrameIndex = function(_aindex = 0, _frame = CURRENT_FRAME) {
if(_frame < 0) return false;
if(!cacheExist(_frame)) return noone;
var surf = array_safe_get_fast(cached_output, frame);
return array_safe_get_fast(surf, index);
var surf = array_safe_get_fast(cached_output, _frame);
return array_safe_get_fast(surf, _aindex, noone);
}
}

View file

@ -23,9 +23,7 @@ function Node_Rate_Remap(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
var _step = PROJECT.animator.framerate / _rate;
var _targ = floor(_time / _step) * _step;
cacheCurrentFrameIndex(_surf, _array_index);
var s = getCacheFrameIndex(_targ, _array_index);
return s;
cacheCurrentFrameIndex(_array_index, _surf);
return getCacheFrameIndex(_array_index, _targ);
}
}

View file

@ -18,7 +18,6 @@ function Node_Revert(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
}
static update = function() {
if(!inputs[0].value_from) return;
if(!inputs[0].value_from.node.renderActive) return;

View file

@ -2,6 +2,8 @@ function Node_Text(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
name = "Draw Text";
font = f_p0;
dimension_index = -1;
newInput(0, nodeValue_Text("Text", self, ""))
.setVisible(true, true);
@ -282,21 +284,24 @@ function Node_Text(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
var _use_path = _path != noone && struct_has(_path, "getPointDistance");
var _ss = 1;
if(_use_path || _dimt == 0) {
if(_use_path) {
_sw = _dim[0];
_sh = _dim[1];
} else if (_dimt == 0) {
_sw = _dim[0];
_sh = _dim[1];
if(_scaF) _ss = min(_sw / ww, _sh / hh);
} else {
_sw = ww;
_sh = hh;
if(_wave) _sh += abs(_waveA) * 2;
}
if(_dimt == 0 && !_use_path && _scaF)
_ss = min(_sw / ww, _sh / hh);
if(_wave) _sh += abs(_waveA) * 2;
_sw += _padd[PADDING.left] + _padd[PADDING.right];
_sh += _padd[PADDING.top] + _padd[PADDING.bottom];
_outSurf = surface_verify(_outSurf, _sw, _sh, attrDepth());
#endregion

View file

@ -3,11 +3,6 @@ function Node_Time_Remap(_x, _y, _group = noone) : Node(_x, _y, _group) construc
use_cache = CACHE_USE.manual;
update_on_frame = true;
shader = sh_time_remap;
uniform_map = shader_get_sampler_index(shader, "map");
uniform_min = shader_get_uniform(shader, "vMin");
uniform_max = shader_get_uniform(shader, "vMax");
newInput(0, nodeValue_Surface("Surface in", self))
.rejectArray();
@ -28,11 +23,12 @@ function Node_Time_Remap(_x, _y, _group = noone) : Node(_x, _y, _group) construc
attribute_surface_depth();
static update = function(frame = CURRENT_FRAME) { #region
static update = function(frame = CURRENT_FRAME) {
var _inSurf = getInputData(0);
var _map = getInputData(1);
var _life = getInputData(2);
var _loop = getInputData(3);
cacheCurrentFrame(_inSurf);
var _surf = outputs[0].getValue();
_surf = surface_verify(_surf, surface_get_width_safe(_inSurf), surface_get_height_safe(_inSurf), attrDepth());
@ -40,26 +36,22 @@ function Node_Time_Remap(_x, _y, _group = noone) : Node(_x, _y, _group) construc
var ste = 1 / _life;
surface_set_shader(_surf, shader);
texture_set_stage(uniform_map, surface_get_texture(_map));
surface_set_shader(_surf, sh_time_remap);
shader_set_surface("map", _map);
for(var i = 0; i <= _life; i++) {
var _frame = CURRENT_FRAME - i;
if(_loop)
_frame = _frame < 0? TOTAL_FRAMES - 1 + _frame : _frame;
else
_frame = clamp(_frame, 0, TOTAL_FRAMES - 1);
if(_loop) _frame = _frame < 0? TOTAL_FRAMES - 1 + _frame : _frame;
else _frame = clamp(_frame, 0, TOTAL_FRAMES - 1);
var s = array_safe_get_fast(cached_output, _frame);
if(!is_surface(s)) continue;
shader_set_uniform_f(uniform_min, i * ste);
shader_set_uniform_f(uniform_max, i * ste + ste);
shader_set_f("vMin", i * ste);
shader_set_f("vMax", i * ste + ste);
draw_surface_safe(s);
}
surface_reset_shader();
cacheCurrentFrame(_inSurf);
} #endregion
}
}

View file

@ -17,7 +17,7 @@ function Node_Trail(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
newInput(6, nodeValue_Curve("Alpha over life", self, CURVE_DEF_11));
newOutput(0, nodeValue_Output("Surface out", self, VALUE_TYPE.surface, noone));
newOutput(0, nodeValue_Output("Surface out", self, VALUE_TYPE.surface, noone));
newOutput(1, nodeValue_Output("Trail UV", self, VALUE_TYPE.surface, noone));
@ -63,7 +63,11 @@ function Node_Trail(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
var _blend = getInputData(5);
var _alpha = getInputData(6);
var cDep = attrDepth();
if(!is_surface(_surf)) return;
if(!is_surface(_surf)) {
logNode($"Surface array not supported.");
return;
}
cacheCurrentFrame(_surf);
for( var i = 0, n = array_length(temp_surface); i < n; i++ ) {

View file

@ -30,8 +30,7 @@
nodeMap = ds_map_create();
nodeNameMap = ds_map_create();
composer = noone;
composer = noone;
animator = new AnimationManager();
globalNode = new Node_Global();
nodeController = new __Node_Controller(self);