mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-26 04:48:17 +01:00
- Shorten tag name in "graphic.json" theme file.
This commit is contained in:
parent
f821f552f2
commit
89cbd946a7
37 changed files with 89 additions and 34 deletions
Binary file not shown.
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Displace(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Displace(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Displace";
|
name = "3D Displace";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
||||||
.setDisplay(VALUE_DISPLAY.vector);
|
.setDisplay(VALUE_DISPLAY.vector);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Extrude(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Extrude(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Extrude";
|
name = "3D Extrude";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Plane(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Plane(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Plane";
|
name = "3D Plane";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Cone(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Cone(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Cone";
|
name = "3D Cone";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
||||||
.setDisplay(VALUE_DISPLAY.vector);
|
.setDisplay(VALUE_DISPLAY.vector);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Cube(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Cube(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Cube";
|
name = "3D Cube";
|
||||||
|
batch_output = false;
|
||||||
dimension_index = 1;
|
dimension_index = 1;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Main texture", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, USE_DEF);
|
inputs[| 0] = nodeValue("Main texture", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, USE_DEF);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Cylinder(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Cylinder(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Cylinder";
|
name = "3D Cylinder";
|
||||||
|
batch_output = false;
|
||||||
dimension_index = 2;
|
dimension_index = 2;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Sides", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 16);
|
inputs[| 0] = nodeValue("Sides", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 16);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Sphere(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Sphere(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Sphere";
|
name = "3D Sphere";
|
||||||
|
batch_output = false;
|
||||||
dimension_index = 1;
|
dimension_index = 1;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Subdivisions", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [8, 4], "Amount of polygon in X and Y axis.")
|
inputs[| 0] = nodeValue("Subdivisions", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [8, 4], "Amount of polygon in X and Y axis.")
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function __Node_3D_Transform(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function __Node_3D_Transform(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "3D Transform";
|
name = "3D Transform";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
||||||
.setDisplay(VALUE_DISPLAY.vector);
|
.setDisplay(VALUE_DISPLAY.vector);
|
||||||
|
|
|
@ -7,6 +7,7 @@ enum LIGHT_SHAPE_2D {
|
||||||
|
|
||||||
function Node_2D_light(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_2D_light(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "2D Light";
|
name = "2D Light";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
shader = sh_2d_light;
|
shader = sh_2d_light;
|
||||||
uniform_colr = shader_get_uniform(shader, "color");
|
uniform_colr = shader_get_uniform(shader, "color");
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_3D_Transform_Image(_x, _y, _group = noone) : Node_3D_Mesh(_x, _y, _group) constructor {
|
function Node_3D_Transform_Image(_x, _y, _group = noone) : Node_3D_Mesh(_x, _y, _group) constructor {
|
||||||
name = "Transform 3D";
|
name = "Transform 3D";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
preview_channel = 1;
|
preview_channel = 1;
|
||||||
object = new __3dPlane();
|
object = new __3dPlane();
|
||||||
|
|
|
@ -10,6 +10,7 @@ function __armature_bind_data(_surface, _bone, _tran, _aang, _pang, _asca, _psca
|
||||||
|
|
||||||
function Node_Armature_Bind(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Armature_Bind(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Armature Bind";
|
name = "Armature Bind";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF)
|
||||||
.setDisplay(VALUE_DISPLAY.vector);
|
.setDisplay(VALUE_DISPLAY.vector);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Average(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Average(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Average";
|
name = "Average";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
shader = sh_average;
|
shader = sh_average;
|
||||||
uniform_dim = shader_get_uniform(shader, "dimension");
|
uniform_dim = shader_get_uniform(shader, "dimension");
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Color_adjust(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Color_adjust(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Color Adjust";
|
name = "Color Adjust";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Color_Data(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Color_Data(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Color Data";
|
name = "Color Data";
|
||||||
|
batch_output = false;
|
||||||
setDimension(96, 48);
|
setDimension(96, 48);
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Color", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_white)
|
inputs[| 0] = nodeValue("Color", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_white)
|
||||||
|
|
|
@ -408,8 +408,11 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
|
|
||||||
outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
|
outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
outputs[| 1] = nodeValue("Atlas data", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, [])
|
outputs[| 1] = nodeValue("Atlas data", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, []);
|
||||||
.rejectArrayProcess();
|
|
||||||
|
outputs[| 2] = nodeValue("Dimension", self, JUNCTION_CONNECT.output, VALUE_TYPE.integer, [1, 1])
|
||||||
|
.setVisible(false)
|
||||||
|
.setDisplay(VALUE_DISPLAY.vector);
|
||||||
|
|
||||||
temp_surface = [ surface_create(1, 1), surface_create(1, 1), surface_create(1, 1) ];
|
temp_surface = [ surface_create(1, 1), surface_create(1, 1), surface_create(1, 1) ];
|
||||||
blend_temp_surface = temp_surface[2];
|
blend_temp_surface = temp_surface[2];
|
||||||
|
@ -429,8 +432,6 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
overlay_w = 0;
|
overlay_w = 0;
|
||||||
overlay_h = 0;
|
overlay_h = 0;
|
||||||
|
|
||||||
atlas_data = [];
|
|
||||||
|
|
||||||
static drawOverlay = function(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
|
static drawOverlay = function(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
|
||||||
PROCESSOR_OVERLAY_CHECK
|
PROCESSOR_OVERLAY_CHECK
|
||||||
|
|
||||||
|
@ -716,18 +717,18 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
surface_selecting = input_fix_len;
|
surface_selecting = input_fix_len;
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
static processData = function(_outSurf, _data, _output_index, _array_index) { #region
|
static processData = function(_outData, _data, _output_index, _array_index) { #region
|
||||||
if(_output_index == 1) return atlas_data;
|
var _outSurf = _outData[0];
|
||||||
if(_output_index == 0 && _array_index == 0) atlas_data = [];
|
|
||||||
|
if(array_length(_data) <= input_fix_len) return [ _outSurf, noone, [1, 1] ];
|
||||||
|
|
||||||
if(array_length(_data) <= input_fix_len) return _outSurf;
|
|
||||||
var _pad = _data[0];
|
var _pad = _data[0];
|
||||||
var _dim_type = _data[1];
|
var _dim_type = _data[1];
|
||||||
var _dim = _data[2];
|
var _dim = _data[2];
|
||||||
var base = _data[3];
|
var base = _data[3];
|
||||||
var cDep = attrDepth();
|
var cDep = attrDepth();
|
||||||
|
|
||||||
if(!is_surface(base)) return _outSurf;
|
if(!is_surface(base)) return [ _outSurf, noone, [1, 1] ];
|
||||||
|
|
||||||
#region dimension
|
#region dimension
|
||||||
var ww = 0, hh = 0;
|
var ww = 0, hh = 0;
|
||||||
|
@ -766,6 +767,7 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
var _vis = attributes.layer_visible;
|
var _vis = attributes.layer_visible;
|
||||||
var bg = 0;
|
var bg = 0;
|
||||||
var _bg = 0;
|
var _bg = 0;
|
||||||
|
var _atlas = [];
|
||||||
|
|
||||||
blend_temp_surface = temp_surface[2];
|
blend_temp_surface = temp_surface[2];
|
||||||
|
|
||||||
|
@ -793,7 +795,7 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
|
|
||||||
var _d0 = point_rotate(cx - _sw / 2, cy - _sh / 2, cx, cy, _rot);
|
var _d0 = point_rotate(cx - _sw / 2, cy - _sh / 2, cx, cy, _rot);
|
||||||
|
|
||||||
array_push(atlas_data, new SurfaceAtlas(_s, _d0[0], _d0[1], _rot, _sca[0], _sca[1]));
|
array_push(_atlas, new SurfaceAtlas(_s, _d0[0], _d0[1], _rot, _sca[0], _sca[1]));
|
||||||
|
|
||||||
surface_set_shader(temp_surface[_bg], sh_sample, true, BLEND.over);
|
surface_set_shader(temp_surface[_bg], sh_sample, true, BLEND.over);
|
||||||
draw_surface_blend_ext(temp_surface[!_bg], _s, _d0[0], _d0[1], _sca[0], _sca[1], _rot, c_white, _alp, _bld, true);
|
draw_surface_blend_ext(temp_surface[!_bg], _s, _d0[0], _d0[1], _sca[0], _sca[1], _rot, c_white, _alp, _bld, true);
|
||||||
|
@ -808,7 +810,7 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
draw_surface_safe(temp_surface[!_bg]);
|
draw_surface_safe(temp_surface[!_bg]);
|
||||||
surface_reset_shader();
|
surface_reset_shader();
|
||||||
|
|
||||||
return _outSurf;
|
return [ _outSurf, _atlas, [ww, hh] ];
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
static attributeSerialize = function() { #region
|
static attributeSerialize = function() { #region
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Gradient_Extract(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Gradient_Extract(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Gradient Data";
|
name = "Gradient Data";
|
||||||
|
batch_output = false;
|
||||||
setDimension(96);
|
setDimension(96);
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Gradient", self, JUNCTION_CONNECT.input, VALUE_TYPE.gradient, new gradientObject(c_white) )
|
inputs[| 0] = nodeValue("Gradient", self, JUNCTION_CONNECT.input, VALUE_TYPE.gradient, new gradientObject(c_white) )
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Gradient_Out(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Gradient_Out(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Gradient";
|
name = "Gradient";
|
||||||
|
batch_output = false;
|
||||||
setDimension(96);
|
setDimension(96);
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Gradient", self, JUNCTION_CONNECT.input, VALUE_TYPE.gradient, new gradientObject([ cola(c_black), cola(c_white) ]) );
|
inputs[| 0] = nodeValue("Gradient", self, JUNCTION_CONNECT.input, VALUE_TYPE.gradient, new gradientObject([ cola(c_black), cola(c_white) ]) );
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_HSV_Channel(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_HSV_Channel(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "HSV Extract";
|
name = "HSV Extract";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Mirror(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Mirror(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Mirror";
|
name = "Mirror";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_MK_Blinker(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_MK_Blinker(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "MK Blinker";
|
name = "MK Blinker";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -23,6 +23,7 @@ function __FlarePart(_type = FLARE_TYPE.circle, _t = 0, _r = 4, _a = 0.5, _seg =
|
||||||
|
|
||||||
function Node_MK_Flare(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_MK_Flare(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "MK Lens Flare";
|
name = "MK Lens Flare";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Background", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Background", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Outline(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Outline(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Outline";
|
name = "Outline";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
attributes.filter = array_create(9, 1);
|
attributes.filter = array_create(9, 1);
|
||||||
filtering_vl = false;
|
filtering_vl = false;
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
function Node_Path_Sample(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Path_Sample(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Sample Path";
|
name = "Sample Path";
|
||||||
setDimension(96, 48);;
|
batch_output = false;
|
||||||
|
setDimension(96, 48);
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Path", self, JUNCTION_CONNECT.input, VALUE_TYPE.pathnode, noone)
|
inputs[| 0] = nodeValue("Path", self, JUNCTION_CONNECT.input, VALUE_TYPE.pathnode, noone)
|
||||||
.setVisible(true, true);
|
.setVisible(true, true);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_PB_Box_Contract(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
function Node_PB_Box_Contract(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
||||||
name = "Split";
|
name = "Split";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
||||||
.setVisible(true, true);
|
.setVisible(true, true);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_PB_Box_Divide(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
function Node_PB_Box_Divide(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
||||||
name = "Divide";
|
name = "Divide";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
||||||
.setVisible(true, true);
|
.setVisible(true, true);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_PB_Box_Inset(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
function Node_PB_Box_Inset(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
||||||
name = "Inset";
|
name = "Inset";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
||||||
.setVisible(true, true);
|
.setVisible(true, true);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_PB_Box_Split(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
function Node_PB_Box_Split(_x, _y, _group = noone) : Node_PB_Box(_x, _y, _group) constructor {
|
||||||
name = "Split";
|
name = "Split";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
inputs[| 1] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone )
|
||||||
.setVisible(true, true);
|
.setVisible(true, true);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_PB_Fx(_x, _y, _group = noone) : Node_PB(_x, _y, _group) constructor {
|
function Node_PB_Fx(_x, _y, _group = noone) : Node_PB(_x, _y, _group) constructor {
|
||||||
name = "PB FX";
|
name = "PB FX";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone)
|
inputs[| 0] = nodeValue("pBox", self, JUNCTION_CONNECT.input, VALUE_TYPE.pbBox, noone)
|
||||||
.setVisible(true, true);
|
.setVisible(true, true);
|
||||||
|
|
|
@ -20,7 +20,7 @@ function Node_Processor(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
||||||
manage_atlas = true;
|
manage_atlas = true;
|
||||||
atlas_index = 0;
|
atlas_index = 0;
|
||||||
|
|
||||||
batch_output = false; //Run processData once with all outputs as array.
|
batch_output = true; //Run processData once with all outputs as array.
|
||||||
|
|
||||||
icon = THEME.node_processor_icon;
|
icon = THEME.node_processor_icon;
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_RGB_Channel(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_RGB_Channel(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "RGBA Extract";
|
name = "RGBA Extract";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface In", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface In", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,7 @@ enum NODE_SCATTER_DIST {
|
||||||
|
|
||||||
function Node_Scatter(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Scatter(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Scatter";
|
name = "Scatter";
|
||||||
|
batch_output = false;
|
||||||
dimension_index = 1;
|
dimension_index = 1;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Shadow_Cast(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Shadow_Cast(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Cast Shadow";
|
name = "Cast Shadow";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Background", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
inputs[| 0] = nodeValue("Background", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function Node_Shape_Polygon(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Shape_Polygon(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Draw Shape Polygon";
|
name = "Draw Shape Polygon";
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
shapesArray = [ "Rectangle", "Ellipse", "Star", "Capsule", "Ring", "Arc", "Gear", "Cross" ];
|
shapesArray = [ "Rectangle", "Ellipse", "Star", "Capsule", "Ring", "Arc", "Gear", "Cross" ];
|
||||||
for( var i = 0, n = array_length(shapesArray); i < n; i++ )
|
for( var i = 0, n = array_length(shapesArray); i < n; i++ )
|
||||||
|
|
|
@ -1813,9 +1813,6 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
|
||||||
var is_hover = hov && point_in_rectangle(_mx, _my, x - _d, y - _d, x + _d - 1, y + _d - 1);
|
var is_hover = hov && point_in_rectangle(_mx, _my, x - _d, y - _d, x + _d - 1, y + _d - 1);
|
||||||
hover_in_graph = is_hover;
|
hover_in_graph = is_hover;
|
||||||
|
|
||||||
var _bgS = THEME.node_junctions_bg;
|
|
||||||
var _fgS = is_hover? THEME.node_junctions_outline_hover : THEME.node_junctions_outline;
|
|
||||||
|
|
||||||
if(is_dummy) {
|
if(is_dummy) {
|
||||||
__draw_sprite_ext(THEME.node_junction_add, is_hover, x, y, _s, _s, 0, c_white, 0.5 + 0.5 * is_hover);
|
__draw_sprite_ext(THEME.node_junction_add, is_hover, x, y, _s, _s, 0, c_white, 0.5 + 0.5 * is_hover);
|
||||||
|
|
||||||
|
@ -1835,6 +1832,18 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
|
||||||
_cfg = merge_color(draw_blend_color, _cfg, draw_blend);
|
_cfg = merge_color(draw_blend_color, _cfg, draw_blend);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var _bgS, _fgS;
|
||||||
|
|
||||||
|
if(_s > .5) {
|
||||||
|
_bgS = THEME.node_junctions_bg_x2;
|
||||||
|
_fgS = is_hover? THEME.node_junctions_outline_hover_x2 : THEME.node_junctions_outline_x2;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
_bgS = THEME.node_junctions_bg;
|
||||||
|
_fgS = is_hover? THEME.node_junctions_outline_hover : THEME.node_junctions_outline;
|
||||||
|
_s *= 2;
|
||||||
|
}
|
||||||
|
|
||||||
__draw_sprite_ext(_bgS, draw_junction_index, x, y, _s, _s, 0, _cbg, 1);
|
__draw_sprite_ext(_bgS, draw_junction_index, x, y, _s, _s, 0, _cbg, 1);
|
||||||
__draw_sprite_ext(_fgS, draw_junction_index, x, y, _s, _s, 0, _cfg, 1);
|
__draw_sprite_ext(_fgS, draw_junction_index, x, y, _s, _s, 0, _cfg, 1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
function Node_Vector_Split(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor { #region
|
function Node_Vector_Split(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor { #region
|
||||||
name = "Vector Split";
|
name = "Vector Split";
|
||||||
color = COLORS.node_blend_number;
|
color = COLORS.node_blend_number;
|
||||||
|
batch_output = false;
|
||||||
|
|
||||||
setDimension(96, 0);
|
setDimension(96, 0);
|
||||||
|
|
||||||
draw_padding = 4;
|
draw_padding = 4;
|
||||||
|
|
|
@ -26,22 +26,33 @@ function _sprite_load_from_struct(str, theme, key) { #region
|
||||||
INLINE
|
INLINE
|
||||||
|
|
||||||
var path = _sprite_path(str.path, theme);
|
var path = _sprite_path(str.path, theme);
|
||||||
var s = sprite_add(path, str.subimages, false, true, str.xorigin, str.yorigin);
|
var s = sprite_add(path, str.s, false, true, str.x, str.y);
|
||||||
|
|
||||||
if(str.slice) {
|
if(s < 0) {
|
||||||
var slice = sprite_nineslice_create();
|
log_message("THEME", $"Load sprite {path} failed.");
|
||||||
slice.enabled = str.slice.enabled;
|
return 0;
|
||||||
slice.left = str.slice.left;
|
|
||||||
slice.right = str.slice.right;
|
|
||||||
slice.top = str.slice.top;
|
|
||||||
slice.bottom = str.slice.bottom;
|
|
||||||
|
|
||||||
if(struct_has(str.slice, "tilemode"))
|
|
||||||
slice.tilemode = str.slice.tilemode;
|
|
||||||
|
|
||||||
if(s >= 0) sprite_set_nineslice(s, slice);
|
|
||||||
else log_message("THEME", $"Load sprite {path} failed.");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(struct_has(str, "slice")) {
|
||||||
|
var slice = sprite_nineslice_create();
|
||||||
|
slice.enabled = true;
|
||||||
|
|
||||||
|
if(is_array(str.slice)) {
|
||||||
|
slice.left = str.slice[0];
|
||||||
|
slice.right = str.slice[1];
|
||||||
|
slice.top = str.slice[2];
|
||||||
|
slice.bottom = str.slice[3];
|
||||||
|
|
||||||
|
} else if(is_real(str.slice)) {
|
||||||
|
slice.left = str.slice;
|
||||||
|
slice.right = str.slice;
|
||||||
|
slice.top = str.slice;
|
||||||
|
slice.bottom = str.slice;
|
||||||
|
|
||||||
|
}
|
||||||
|
sprite_set_nineslice(s, slice);
|
||||||
|
}
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue