From 0d21c32e73a2afef357d0e947ae6c23cc89a32be Mon Sep 17 00:00:00 2001 From: Tanasart Date: Fri, 24 May 2024 17:45:45 +0700 Subject: [PATCH] - [Replace Image] Extends the replacement loop to match target loop if the later is longer. --- .../node_surface_replace.gml | 19 +++++++++++++------ .../sh_surface_replace_find.fsh | 2 +- 2 files changed, 14 insertions(+), 7 deletions(-) diff --git a/scripts/node_surface_replace/node_surface_replace.gml b/scripts/node_surface_replace/node_surface_replace.gml index eee091874..584cf1ff6 100644 --- a/scripts/node_surface_replace/node_surface_replace.gml +++ b/scripts/node_surface_replace/node_surface_replace.gml @@ -63,8 +63,10 @@ function Node_Surface_Replace(_x, _y, _group = noone) : Node_Processor(_x, _y, _ surface_set_shader(_surf, _fst? sh_surface_replace_fast_replace : sh_surface_replace_replace, false, BLEND.normal); shader_set_f("dimension", surface_get_width_safe(_base), surface_get_height_safe(_base)); + shader_set_surface("replace", _replace); shader_set_f("replace_dim", surface_get_width_safe(_replace), surface_get_height_safe(_replace)); + shader_set_surface("findRes", _res); shader_set_f("index", _index); @@ -95,10 +97,12 @@ function Node_Surface_Replace(_x, _y, _group = noone) : Node_Processor(_x, _y, _ temp_surface[0] = surface_verify(temp_surface[0], _sw, _sh); surface_clear(temp_surface[0]); - - var amo = array_length(_tar); - for( var i = 0; i < amo; i++ ) matchTemplate(i / amo, temp_surface[0], _bas, _tar[i], _cthr, _pthr, _fst); - //return temp_surface[0]; + + var tamo = array_length(_tar); + var ramo = array_length(_rep); + + for( var i = 0; i < tamo; i++ ) matchTemplate(i / tamo, temp_surface[0], _bas, _tar[i], _cthr, _pthr, _fst); + // return temp_surface[0]; _outSurf = surface_verify(_outSurf, _sw, _sh); surface_set_target(_outSurf); @@ -106,8 +110,11 @@ function Node_Surface_Replace(_x, _y, _group = noone) : Node_Processor(_x, _y, _ if(_drw) draw_surface_safe(_bas); surface_reset_target(); - var amo = array_length(_rep); - for( var i = 0; i < amo; i++ ) replaceTemplate(i / amo, _outSurf, _bas, temp_surface[0], _rep[i], _fst); + var amo = max(tamo, ramo); + for( var i = 0; i < amo; i++ ) { + var _ri = i % ramo; + replaceTemplate(_ri / amo, _outSurf, _bas, temp_surface[0], _rep[_ri], _fst); + } return _outSurf; } diff --git a/shaders/sh_surface_replace_find/sh_surface_replace_find.fsh b/shaders/sh_surface_replace_find/sh_surface_replace_find.fsh index fa89e5ee2..ad029390d 100644 --- a/shaders/sh_surface_replace_find/sh_surface_replace_find.fsh +++ b/shaders/sh_surface_replace_find/sh_surface_replace_find.fsh @@ -57,7 +57,7 @@ void main() { if(uv.x < 0. || uv.y < 0.) continue; if(uv.x - .5 + targetDimension.x > dimension.x || uv.y - .5 + targetDimension.y > dimension.y) continue; - gl_FragColor = vec4(1.); + //gl_FragColor = vec4(1.); float matchTemp = matchTemplate(uv); if(matchTemp > match) { match = matchTemp;