mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-26 12:58:49 +01:00
- [RGB combine] Fix output error when input is not a square.
This commit is contained in:
parent
480e38ae01
commit
ff566da654
2 changed files with 10 additions and 28 deletions
|
@ -1,15 +1,6 @@
|
||||||
function Node_Combine_RGB(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Combine_RGB(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "RGB Combine";
|
name = "RGB Combine";
|
||||||
|
|
||||||
shader = sh_combine_rgb;
|
|
||||||
uniform_r = shader_get_sampler_index(shader, "samR");
|
|
||||||
uniform_g = shader_get_sampler_index(shader, "samG");
|
|
||||||
uniform_b = shader_get_sampler_index(shader, "samB");
|
|
||||||
uniform_a = shader_get_sampler_index(shader, "samA");
|
|
||||||
|
|
||||||
uniform_usea = shader_get_uniform(shader, "useA");
|
|
||||||
uniform_mode = shader_get_uniform(shader, "mode");
|
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Red", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
inputs[| 0] = nodeValue("Red", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
||||||
inputs[| 1] = nodeValue("Green", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
inputs[| 1] = nodeValue("Green", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
||||||
inputs[| 2] = nodeValue("Blue", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
inputs[| 2] = nodeValue("Blue", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
||||||
|
@ -34,24 +25,17 @@ function Node_Combine_RGB(_x, _y, _group = noone) : Node_Processor(_x, _y, _grou
|
||||||
var _a = _data[3];
|
var _a = _data[3];
|
||||||
var _mode = _data[4];
|
var _mode = _data[4];
|
||||||
|
|
||||||
surface_set_target(_outSurf);
|
surface_set_shader(_outSurf, sh_combine_rgb);
|
||||||
DRAW_CLEAR
|
shader_set_surface("samR", _r);
|
||||||
BLEND_OVERRIDE;
|
shader_set_surface("samG", _g);
|
||||||
|
shader_set_surface("samB", _b);
|
||||||
|
shader_set_surface("samA", _a);
|
||||||
|
|
||||||
shader_set(shader);
|
shader_set_i("useA", _mode);
|
||||||
texture_set_stage(uniform_r, surface_get_texture(_r));
|
shader_set_i("mode", is_surface(_a));
|
||||||
texture_set_stage(uniform_g, surface_get_texture(_g));
|
|
||||||
texture_set_stage(uniform_b, surface_get_texture(_b));
|
|
||||||
|
|
||||||
shader_set_uniform_i(uniform_mode, _mode);
|
draw_sprite_stretched(s_fx_pixel, 0, 0, 0, surface_get_width_safe(_outSurf), surface_get_height_safe(_outSurf));
|
||||||
shader_set_uniform_i(uniform_usea, is_surface(_a));
|
surface_reset_shader();
|
||||||
texture_set_stage(uniform_a, surface_get_texture(_a));
|
|
||||||
|
|
||||||
draw_sprite_ext(s_fx_pixel, 0, 0, 0, surface_get_width_safe(_outSurf), surface_get_width_safe(_outSurf), 0, c_white, 1);
|
|
||||||
shader_reset();
|
|
||||||
|
|
||||||
BLEND_NORMAL;
|
|
||||||
surface_reset_target();
|
|
||||||
|
|
||||||
return _outSurf;
|
return _outSurf;
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
|
@ -916,9 +916,7 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
|
||||||
break; #endregion
|
break; #endregion
|
||||||
case VALUE_DISPLAY.matrix : #region
|
case VALUE_DISPLAY.matrix : #region
|
||||||
editWidget = new matrixGrid(_txt, display_data, function(index, val) {
|
editWidget = new matrixGrid(_txt, display_data, function(index, val) {
|
||||||
var _val = animator.getValue();
|
return setValueDirect(val, index);
|
||||||
_val[index] = val;
|
|
||||||
return setValueDirect(_val);
|
|
||||||
}, unit );
|
}, unit );
|
||||||
if(type == VALUE_TYPE.integer) editWidget.setSlideSpeed(1);
|
if(type == VALUE_TYPE.integer) editWidget.setSlideSpeed(1);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue