mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-23 19:38:05 +01:00
1.16rc3
This commit is contained in:
parent
581b924cee
commit
2bec138844
30 changed files with 595 additions and 441 deletions
|
@ -241,6 +241,7 @@
|
||||||
{"name":"button","order":34,"path":"folders/widgets/button.yy",},
|
{"name":"button","order":34,"path":"folders/widgets/button.yy",},
|
||||||
{"name":"rotator","order":35,"path":"folders/widgets/rotator.yy",},
|
{"name":"rotator","order":35,"path":"folders/widgets/rotator.yy",},
|
||||||
{"name":"text","order":36,"path":"folders/widgets/text.yy",},
|
{"name":"text","order":36,"path":"folders/widgets/text.yy",},
|
||||||
|
{"name":"find boundary","order":9,"path":"folders/shader/misc/find boundary.yy",},
|
||||||
],
|
],
|
||||||
"ResourceOrderSettings": [
|
"ResourceOrderSettings": [
|
||||||
{"name":"s_node_corner","order":16,"path":"sprites/s_node_corner/s_node_corner.yy",},
|
{"name":"s_node_corner","order":16,"path":"sprites/s_node_corner/s_node_corner.yy",},
|
||||||
|
@ -494,6 +495,7 @@
|
||||||
{"name":"s_node_gabor","order":32,"path":"sprites/s_node_gabor/s_node_gabor.yy",},
|
{"name":"s_node_gabor","order":32,"path":"sprites/s_node_gabor/s_node_gabor.yy",},
|
||||||
{"name":"s_node_dithering","order":21,"path":"sprites/s_node_dithering/s_node_dithering.yy",},
|
{"name":"s_node_dithering","order":21,"path":"sprites/s_node_dithering/s_node_dithering.yy",},
|
||||||
{"name":"node_3d_mesh_extrude","order":8,"path":"scripts/node_3d_mesh_extrude/node_3d_mesh_extrude.yy",},
|
{"name":"node_3d_mesh_extrude","order":8,"path":"scripts/node_3d_mesh_extrude/node_3d_mesh_extrude.yy",},
|
||||||
|
{"name":"sh_find_boundary_stretch_x","order":1,"path":"shaders/sh_find_boundary_stretch_x/sh_find_boundary_stretch_x.yy",},
|
||||||
{"name":"s_workshop_badge","order":1,"path":"sprites/s_workshop_badge/s_workshop_badge.yy",},
|
{"name":"s_workshop_badge","order":1,"path":"sprites/s_workshop_badge/s_workshop_badge.yy",},
|
||||||
{"name":"node_pb_fx_brick","order":12,"path":"scripts/node_pb_fx_brick/node_pb_fx_brick.yy",},
|
{"name":"node_pb_fx_brick","order":12,"path":"scripts/node_pb_fx_brick/node_pb_fx_brick.yy",},
|
||||||
{"name":"node_compare","order":16,"path":"scripts/node_compare/node_compare.yy",},
|
{"name":"node_compare","order":16,"path":"scripts/node_compare/node_compare.yy",},
|
||||||
|
@ -839,6 +841,7 @@
|
||||||
{"name":"pcx_parse","order":3,"path":"scripts/pcx_parse/pcx_parse.yy",},
|
{"name":"pcx_parse","order":3,"path":"scripts/pcx_parse/pcx_parse.yy",},
|
||||||
{"name":"node_9slice","order":5,"path":"scripts/node_9slice/node_9slice.yy",},
|
{"name":"node_9slice","order":5,"path":"scripts/node_9slice/node_9slice.yy",},
|
||||||
{"name":"fd_rectangle_add_velocity_surface","order":24,"path":"scripts/fd_rectangle_add_velocity_surface/fd_rectangle_add_velocity_surface.yy",},
|
{"name":"fd_rectangle_add_velocity_surface","order":24,"path":"scripts/fd_rectangle_add_velocity_surface/fd_rectangle_add_velocity_surface.yy",},
|
||||||
|
{"name":"sh_find_boundary_stretch_y","order":2,"path":"shaders/sh_find_boundary_stretch_y/sh_find_boundary_stretch_y.yy",},
|
||||||
{"name":"BBMOD_Vec2","order":4,"path":"scripts/BBMOD_Vec2/BBMOD_Vec2.yy",},
|
{"name":"BBMOD_Vec2","order":4,"path":"scripts/BBMOD_Vec2/BBMOD_Vec2.yy",},
|
||||||
{"name":"sh_grid_hex","order":1,"path":"shaders/sh_grid_hex/sh_grid_hex.yy",},
|
{"name":"sh_grid_hex","order":1,"path":"shaders/sh_grid_hex/sh_grid_hex.yy",},
|
||||||
{"name":"s_node_lua_surface","order":18,"path":"sprites/s_node_lua_surface/s_node_lua_surface.yy",},
|
{"name":"s_node_lua_surface","order":18,"path":"sprites/s_node_lua_surface/s_node_lua_surface.yy",},
|
||||||
|
@ -1134,7 +1137,6 @@
|
||||||
{"name":"s_node_fluidSim_vortex","order":8,"path":"sprites/s_node_fluidSim_vortex/s_node_fluidSim_vortex.yy",},
|
{"name":"s_node_fluidSim_vortex","order":8,"path":"sprites/s_node_fluidSim_vortex/s_node_fluidSim_vortex.yy",},
|
||||||
{"name":"string_hexadecimal","order":1,"path":"scripts/string_hexadecimal/string_hexadecimal.yy",},
|
{"name":"string_hexadecimal","order":1,"path":"scripts/string_hexadecimal/string_hexadecimal.yy",},
|
||||||
{"name":"s_node_camera","order":3,"path":"sprites/s_node_camera/s_node_camera.yy",},
|
{"name":"s_node_camera","order":3,"path":"sprites/s_node_camera/s_node_camera.yy",},
|
||||||
{"name":"sh_find_boundary","order":2,"path":"shaders/sh_find_boundary/sh_find_boundary.yy",},
|
|
||||||
{"name":"Obj_FirebaseFirestore_Document_Set","order":6,"path":"objects/Obj_FirebaseFirestore_Document_Set/Obj_FirebaseFirestore_Document_Set.yy",},
|
{"name":"Obj_FirebaseFirestore_Document_Set","order":6,"path":"objects/Obj_FirebaseFirestore_Document_Set/Obj_FirebaseFirestore_Document_Set.yy",},
|
||||||
{"name":"_node_strand_affector","order":10,"path":"scripts/_node_strand_affector/_node_strand_affector.yy",},
|
{"name":"_node_strand_affector","order":10,"path":"scripts/_node_strand_affector/_node_strand_affector.yy",},
|
||||||
{"name":"Steamworks","order":2,"path":"extensions/Steamworks/Steamworks.yy",},
|
{"name":"Steamworks","order":2,"path":"extensions/Steamworks/Steamworks.yy",},
|
||||||
|
|
|
@ -276,6 +276,7 @@
|
||||||
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"button","folderPath":"folders/widgets/button.yy",},
|
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"button","folderPath":"folders/widgets/button.yy",},
|
||||||
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"rotator","folderPath":"folders/widgets/rotator.yy",},
|
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"rotator","folderPath":"folders/widgets/rotator.yy",},
|
||||||
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"text","folderPath":"folders/widgets/text.yy",},
|
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"text","folderPath":"folders/widgets/text.yy",},
|
||||||
|
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"find boundary","folderPath":"folders/shader/misc/find boundary.yy",},
|
||||||
],
|
],
|
||||||
"IncludedFiles": [
|
"IncludedFiles": [
|
||||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"ApolloHelp.html","ConfigValues":{"Itch":{"CopyToMask":"0",},},"CopyToMask":-1,"filePath":"datafiles",},
|
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"ApolloHelp.html","ConfigValues":{"Itch":{"CopyToMask":"0",},},"CopyToMask":-1,"filePath":"datafiles",},
|
||||||
|
@ -1088,6 +1089,7 @@
|
||||||
{"id":{"name":"s_node_gabor","path":"sprites/s_node_gabor/s_node_gabor.yy",},},
|
{"id":{"name":"s_node_gabor","path":"sprites/s_node_gabor/s_node_gabor.yy",},},
|
||||||
{"id":{"name":"s_node_dithering","path":"sprites/s_node_dithering/s_node_dithering.yy",},},
|
{"id":{"name":"s_node_dithering","path":"sprites/s_node_dithering/s_node_dithering.yy",},},
|
||||||
{"id":{"name":"node_3d_mesh_extrude","path":"scripts/node_3d_mesh_extrude/node_3d_mesh_extrude.yy",},},
|
{"id":{"name":"node_3d_mesh_extrude","path":"scripts/node_3d_mesh_extrude/node_3d_mesh_extrude.yy",},},
|
||||||
|
{"id":{"name":"sh_find_boundary_stretch_x","path":"shaders/sh_find_boundary_stretch_x/sh_find_boundary_stretch_x.yy",},},
|
||||||
{"id":{"name":"s_node_boolean","path":"sprites/s_node_boolean/s_node_boolean.yy",},},
|
{"id":{"name":"s_node_boolean","path":"sprites/s_node_boolean/s_node_boolean.yy",},},
|
||||||
{"id":{"name":"s_workshop_badge","path":"sprites/s_workshop_badge/s_workshop_badge.yy",},},
|
{"id":{"name":"s_workshop_badge","path":"sprites/s_workshop_badge/s_workshop_badge.yy",},},
|
||||||
{"id":{"name":"node_pb_fx_brick","path":"scripts/node_pb_fx_brick/node_pb_fx_brick.yy",},},
|
{"id":{"name":"node_pb_fx_brick","path":"scripts/node_pb_fx_brick/node_pb_fx_brick.yy",},},
|
||||||
|
@ -1487,6 +1489,7 @@
|
||||||
{"id":{"name":"pcx_parse","path":"scripts/pcx_parse/pcx_parse.yy",},},
|
{"id":{"name":"pcx_parse","path":"scripts/pcx_parse/pcx_parse.yy",},},
|
||||||
{"id":{"name":"node_9slice","path":"scripts/node_9slice/node_9slice.yy",},},
|
{"id":{"name":"node_9slice","path":"scripts/node_9slice/node_9slice.yy",},},
|
||||||
{"id":{"name":"fd_rectangle_add_velocity_surface","path":"scripts/fd_rectangle_add_velocity_surface/fd_rectangle_add_velocity_surface.yy",},},
|
{"id":{"name":"fd_rectangle_add_velocity_surface","path":"scripts/fd_rectangle_add_velocity_surface/fd_rectangle_add_velocity_surface.yy",},},
|
||||||
|
{"id":{"name":"sh_find_boundary_stretch_y","path":"shaders/sh_find_boundary_stretch_y/sh_find_boundary_stretch_y.yy",},},
|
||||||
{"id":{"name":"sprite_add_functions","path":"scripts/sprite_add_functions/sprite_add_functions.yy",},},
|
{"id":{"name":"sprite_add_functions","path":"scripts/sprite_add_functions/sprite_add_functions.yy",},},
|
||||||
{"id":{"name":"BBMOD_Vec2","path":"scripts/BBMOD_Vec2/BBMOD_Vec2.yy",},},
|
{"id":{"name":"BBMOD_Vec2","path":"scripts/BBMOD_Vec2/BBMOD_Vec2.yy",},},
|
||||||
{"id":{"name":"sh_grid_hex","path":"shaders/sh_grid_hex/sh_grid_hex.yy",},},
|
{"id":{"name":"sh_grid_hex","path":"shaders/sh_grid_hex/sh_grid_hex.yy",},},
|
||||||
|
|
|
@ -32,7 +32,7 @@ function Node_Active_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
||||||
[ "Brush properties", false ], 1, 5, 6, 8,
|
[ "Brush properties", false ], 1, 5, 6, 8,
|
||||||
];
|
];
|
||||||
|
|
||||||
brush_prev = [];
|
brush_prev = noone;
|
||||||
brush_next_dist = 0;
|
brush_next_dist = 0;
|
||||||
|
|
||||||
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
||||||
|
@ -68,19 +68,21 @@ function Node_Active_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
||||||
_surf = surface_verify(_surf, _dim[0], _dim[1]);
|
_surf = surface_verify(_surf, _dim[0], _dim[1]);
|
||||||
var _bdense = _bdst[0] == _bdst[1] && _bdst[0] == 1;
|
var _bdense = _bdst[0] == _bdst[1] && _bdst[0] == 1;
|
||||||
|
|
||||||
|
outputs[| 0].setValue(_surf);
|
||||||
|
|
||||||
surface_set_target(_surf);
|
surface_set_target(_surf);
|
||||||
if(CURRENT_FRAME == 0) DRAW_CLEAR
|
if(CURRENT_FRAME == 0) DRAW_CLEAR
|
||||||
|
|
||||||
if(_bact) {
|
if(_bact) {
|
||||||
if(!is_surface(_bsurf)) {
|
if(!is_surface(_bsurf)) {
|
||||||
if(CURRENT_FRAME == 0)
|
if(CURRENT_FRAME == 0 || brush_prev == noone)
|
||||||
draw_point_color(_bpos[0] - 1, _bpos[1] - 1, _bcol);
|
draw_point_color(_bpos[0] - 1, _bpos[1] - 1, _bcol);
|
||||||
else
|
else
|
||||||
draw_line_color(brush_prev[2][0] - 1, brush_prev[2][1] - 1, _bpos[0] - 1, _bpos[1] - 1, brush_prev[5], _bcol);
|
draw_line_color(brush_prev[2][0] - 1, brush_prev[2][1] - 1, _bpos[0] - 1, _bpos[1] - 1, brush_prev[5], _bcol);
|
||||||
} else {
|
} else {
|
||||||
BLEND_ALPHA
|
BLEND_ALPHA
|
||||||
|
|
||||||
if(CURRENT_FRAME == 0) {
|
if(CURRENT_FRAME == 0 || brush_prev == noone) {
|
||||||
brush_draw_surface(_bsurf, _bpos[0], _bpos[1], _bsca[0], _bsca[1], _brot, _bcol, _balp);
|
brush_draw_surface(_bsurf, _bpos[0], _bpos[1], _bsca[0], _bsca[1], _brot, _bcol, _balp);
|
||||||
} else {
|
} else {
|
||||||
var _x0 = brush_prev[2][0];
|
var _x0 = brush_prev[2][0];
|
||||||
|
@ -120,7 +122,5 @@ function Node_Active_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) const
|
||||||
|
|
||||||
for( var i = 0, n = array_length(inputs_data); i < n; i++ )
|
for( var i = 0, n = array_length(inputs_data); i < n; i++ )
|
||||||
brush_prev[i] = variable_clone(inputs_data[i], 1);
|
brush_prev[i] = variable_clone(inputs_data[i], 1);
|
||||||
|
|
||||||
outputs[| 0].setValue(_surf);
|
|
||||||
} #endregion
|
} #endregion
|
||||||
}
|
}
|
|
@ -4,7 +4,7 @@ function Node_Camera(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Background", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
inputs[| 0] = nodeValue("Background", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
||||||
|
|
||||||
onSurfaceSize = function() { return getInputData(0, DEF_SURF); };
|
onSurfaceSize = function() { return surface_get_dimension(getInputData(0, DEF_SURF)); };
|
||||||
inputs[| 1] = nodeValue("Focus area", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 0, 0, 16, 16, AREA_SHAPE.rectangle ])
|
inputs[| 1] = nodeValue("Focus area", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 0, 0, 16, 16, AREA_SHAPE.rectangle ])
|
||||||
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ function Node_Crop_Content(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
||||||
drag_my = 0;
|
drag_my = 0;
|
||||||
drag_sv = 0;
|
drag_sv = 0;
|
||||||
|
|
||||||
temp_surface = [ surface_create(1, 1, surface_r32float) ];
|
temp_surface = [ surface_create(1, 1, surface_r32float), surface_create(1, 1, surface_r32float) ];
|
||||||
|
|
||||||
static update = function() {
|
static update = function() {
|
||||||
var _inSurf = getInputData(0);
|
var _inSurf = getInputData(0);
|
||||||
|
@ -44,6 +44,11 @@ function Node_Crop_Content(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
||||||
}
|
}
|
||||||
|
|
||||||
var _arr = is_array(_inSurf);
|
var _arr = is_array(_inSurf);
|
||||||
|
_array &= _arr;
|
||||||
|
|
||||||
|
if(!is_array(_inSurf) && !is_surface(_inSurf)) return;
|
||||||
|
if( is_array(_inSurf) && array_empty(_inSurf)) return;
|
||||||
|
|
||||||
if(!_arr) _inSurf = [ _inSurf ];
|
if(!_arr) _inSurf = [ _inSurf ];
|
||||||
var _amo = array_length(_inSurf);
|
var _amo = array_length(_inSurf);
|
||||||
|
|
||||||
|
@ -57,36 +62,25 @@ function Node_Crop_Content(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
||||||
var _surf = _inSurf[j];
|
var _surf = _inSurf[j];
|
||||||
|
|
||||||
var _dim = [ surface_get_width_safe(_surf), surface_get_height_safe(_surf) ];
|
var _dim = [ surface_get_width_safe(_surf), surface_get_height_safe(_surf) ];
|
||||||
var _minx = 0, _miny = 0, _maxx = _dim[0], _maxy = _dim[1];
|
var _minx = 0, _miny = 0, _maxx = _dim[0] - 1, _maxy = _dim[1] - 1;
|
||||||
temp_surface[0] = surface_verify(temp_surface[0], 1, 1, surface_r32float);
|
|
||||||
|
|
||||||
for( var i = 0; i < 4; i++ ) {
|
temp_surface[0] = surface_verify(temp_surface[0], _dim[0], _dim[1], surface_r32float);
|
||||||
surface_set_target(temp_surface[0]);
|
temp_surface[1] = surface_verify(temp_surface[1], _dim[0], _dim[1], surface_r32float);
|
||||||
shader_set(sh_find_boundary);
|
|
||||||
shader_set_f("dimension", _dim);
|
|
||||||
shader_set_surface("texture", _surf);
|
|
||||||
|
|
||||||
shader_set_i("mode", i);
|
surface_set_shader(temp_surface[0], sh_find_boundary_stretch_x);
|
||||||
shader_set_f("bbox", [ _minx, _miny, _maxx, _maxy ]);
|
shader_set_f("dimension", _dim);
|
||||||
|
draw_surface_safe(_surf);
|
||||||
|
surface_reset_shader();
|
||||||
|
|
||||||
DRAW_CLEAR
|
surface_set_shader(temp_surface[1], sh_find_boundary_stretch_y);
|
||||||
BLEND_OVERRIDE
|
shader_set_f("dimension", _dim);
|
||||||
draw_sprite(s_fx_pixel, 0, 0, 0);
|
draw_surface_safe(_surf);
|
||||||
BLEND_NORMAL
|
surface_reset_shader();
|
||||||
|
|
||||||
shader_reset();
|
for( ; _minx < _dim[0]; _minx++ ) if(surface_get_pixel(temp_surface[0], _minx, 0) > 0) break;
|
||||||
surface_reset_target();
|
for( ; _maxx >= 0; _maxx-- ) if(surface_get_pixel(temp_surface[0], _maxx, 0) > 0) break;
|
||||||
|
for( ; _miny < _dim[1]; _miny++ ) if(surface_get_pixel(temp_surface[1], 0, _miny) > 0) break;
|
||||||
var px = surface_getpixel(temp_surface[0], 0, 0);
|
for( ; _maxy >= 0; _maxy-- ) if(surface_get_pixel(temp_surface[1], 0, _maxy) > 0) break;
|
||||||
px = px[0];
|
|
||||||
|
|
||||||
switch(i) {
|
|
||||||
case 0 : _minx = px; break;
|
|
||||||
case 1 : _miny = px; break;
|
|
||||||
case 2 : _maxx = px; break;
|
|
||||||
case 3 : _maxy = px; break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(_array) {
|
if(_array) {
|
||||||
minx[j] = _minx;
|
minx[j] = _minx;
|
||||||
|
@ -115,12 +109,10 @@ function Node_Crop_Content(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
||||||
|
|
||||||
res[i] = surface_create_valid(resDim[DIMENSION.width], resDim[DIMENSION.height], cDep);
|
res[i] = surface_create_valid(resDim[DIMENSION.width], resDim[DIMENSION.height], cDep);
|
||||||
|
|
||||||
surface_set_target(res[i]);
|
surface_set_shader(res[i], noone);
|
||||||
DRAW_CLEAR
|
|
||||||
BLEND_OVERRIDE
|
|
||||||
draw_surface_safe(_surf, -minx + _padd[PADDING.left], -miny + _padd[PADDING.top]);
|
draw_surface_safe(_surf, -minx + _padd[PADDING.left], -miny + _padd[PADDING.top]);
|
||||||
BLEND_NORMAL
|
surface_reset_shader();
|
||||||
surface_reset_target();
|
|
||||||
} else if(_array == 1) {
|
} else if(_array == 1) {
|
||||||
var resDim = [maxx[i] - minx[i] + 1, maxy[i] - miny[i] + 1];
|
var resDim = [maxx[i] - minx[i] + 1, maxy[i] - miny[i] + 1];
|
||||||
resDim[DIMENSION.width] += _padd[PADDING.left] + _padd[PADDING.right];
|
resDim[DIMENSION.width] += _padd[PADDING.left] + _padd[PADDING.right];
|
||||||
|
@ -128,12 +120,9 @@ function Node_Crop_Content(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
||||||
|
|
||||||
res[i] = surface_create_valid(resDim[DIMENSION.width], resDim[DIMENSION.height], cDep);
|
res[i] = surface_create_valid(resDim[DIMENSION.width], resDim[DIMENSION.height], cDep);
|
||||||
|
|
||||||
surface_set_target(res[i]);
|
surface_set_shader(res[i], noone);
|
||||||
DRAW_CLEAR
|
|
||||||
BLEND_OVERRIDE
|
|
||||||
draw_surface_safe(_surf, -minx[i] + _padd[PADDING.left], -miny[i] + _padd[PADDING.top]);
|
draw_surface_safe(_surf, -minx[i] + _padd[PADDING.left], -miny[i] + _padd[PADDING.top]);
|
||||||
BLEND_NORMAL
|
surface_reset_shader();
|
||||||
surface_reset_target();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,8 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
||||||
|
|
||||||
run_in(1, function() {
|
run_in(1, function() {
|
||||||
resetInternalName();
|
resetInternalName();
|
||||||
|
|
||||||
|
if(renamed) return;
|
||||||
display_name = __txt_node_name(instanceof(self), name);
|
display_name = __txt_node_name(instanceof(self), name);
|
||||||
if(!LOCALE_DEF || TESTING) renamed = true;
|
if(!LOCALE_DEF || TESTING) renamed = true;
|
||||||
});
|
});
|
||||||
|
@ -1660,8 +1662,9 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
|
||||||
array_push(_trigger, inspectInput2.serialize(scale, preset));
|
array_push(_trigger, inspectInput2.serialize(scale, preset));
|
||||||
array_push(_trigger, updatedInTrigger.serialize(scale, preset));
|
array_push(_trigger, updatedInTrigger.serialize(scale, preset));
|
||||||
array_push(_trigger, updatedOutTrigger.serialize(scale, preset));
|
array_push(_trigger, updatedOutTrigger.serialize(scale, preset));
|
||||||
|
|
||||||
_map.inspectInputs = _trigger;
|
_map.inspectInputs = _trigger;
|
||||||
_map.renamed = renamed;
|
_map.renamed = renamed;
|
||||||
|
|
||||||
doSerialize(_map);
|
doSerialize(_map);
|
||||||
processSerialize(_map);
|
processSerialize(_map);
|
||||||
|
|
|
@ -22,8 +22,8 @@ function Node_create_Image_path(_x, _y, path) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function Node_Image(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
function Node_Image(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
||||||
name = "Image";
|
name = "Image";
|
||||||
color = COLORS.node_blend_input;
|
color = COLORS.node_blend_input;
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Path", self, JUNCTION_CONNECT.input, VALUE_TYPE.path, "")
|
inputs[| 0] = nodeValue("Path", self, JUNCTION_CONNECT.input, VALUE_TYPE.path, "")
|
||||||
.setDisplay(VALUE_DISPLAY.path_load, { filter: "*.png" })
|
.setDisplay(VALUE_DISPLAY.path_load, { filter: "*.png" })
|
||||||
|
@ -106,12 +106,9 @@ function Node_Image(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
||||||
_outsurf = surface_verify(_outsurf, ww, hh, attrDepth());
|
_outsurf = surface_verify(_outsurf, ww, hh, attrDepth());
|
||||||
outputs[| 0].setValue(_outsurf);
|
outputs[| 0].setValue(_outsurf);
|
||||||
|
|
||||||
surface_set_target(_outsurf);
|
surface_set_shader(_outsurf, noone);
|
||||||
DRAW_CLEAR
|
draw_sprite(spr, 0, pad[2], pad[1]);
|
||||||
BLEND_OVERRIDE;
|
surface_reset_shader();
|
||||||
draw_sprite(spr, 0, pad[2], pad[1]);
|
|
||||||
BLEND_NORMAL;
|
|
||||||
surface_reset_target();
|
|
||||||
|
|
||||||
if(!first_update) return;
|
if(!first_update) return;
|
||||||
first_update = false;
|
first_update = false;
|
||||||
|
|
|
@ -115,7 +115,7 @@ function Node_Image_Animated(_x, _y, _group = noone) : Node(_x, _y, _group) cons
|
||||||
path_loaded[i] = paths[i];
|
path_loaded[i] = paths[i];
|
||||||
var path = try_get_path(paths[i]);
|
var path = try_get_path(paths[i]);
|
||||||
if(path == -1) continue;
|
if(path == -1) continue;
|
||||||
setDisplayName(string_replace(filename_name(path), filename_ext(path), ""));
|
setDisplayName(filename_name_only(path));
|
||||||
|
|
||||||
var ext = string_lower(filename_ext(path));
|
var ext = string_lower(filename_ext(path));
|
||||||
|
|
||||||
|
|
|
@ -102,6 +102,7 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
||||||
if(ext != ".gif")
|
if(ext != ".gif")
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
setDisplayName(_name);
|
||||||
outputs[| 1].setValue(path);
|
outputs[| 1].setValue(path);
|
||||||
|
|
||||||
if(spr) sprite_delete(spr);
|
if(spr) sprite_delete(spr);
|
||||||
|
|
|
@ -107,6 +107,7 @@ function Node_Image_Sequence(_x, _y, _group = noone) : Node(_x, _y, _group) cons
|
||||||
var path = try_get_path(paths[i]);
|
var path = try_get_path(paths[i]);
|
||||||
if(path == -1) continue;
|
if(path == -1) continue;
|
||||||
var ext = string_lower(filename_ext(path));
|
var ext = string_lower(filename_ext(path));
|
||||||
|
setDisplayName(filename_name_only(path));
|
||||||
|
|
||||||
switch(ext) {
|
switch(ext) {
|
||||||
case ".png" :
|
case ".png" :
|
||||||
|
|
|
@ -2,7 +2,7 @@ function Node_Particle(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y, _
|
||||||
name = "Particle";
|
name = "Particle";
|
||||||
use_cache = CACHE_USE.auto;
|
use_cache = CACHE_USE.auto;
|
||||||
|
|
||||||
onSurfaceSize = function() { return getInputData(input_len, DEF_SURF); };
|
onSurfaceSize = function() { return surface_get_dimension(getInputData(input_len, DEF_SURF)); };
|
||||||
inputs[| 3].setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
inputs[| 3].setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
||||||
|
|
||||||
inputs[| 22].setDisplay(VALUE_DISPLAY.enum_scroll, [ "Random", "Order", "Animation", "Array" ]);
|
inputs[| 22].setDisplay(VALUE_DISPLAY.enum_scroll, [ "Random", "Order", "Animation", "Array" ]);
|
||||||
|
|
|
@ -229,6 +229,12 @@ function NodeObject(_name, _spr, _node, _create, tags = []) constructor { #regio
|
||||||
global.RECENT_NODES = file_exists(recPath)? json_load_struct(recPath) : [];
|
global.RECENT_NODES = file_exists(recPath)? json_load_struct(recPath) : [];
|
||||||
if(!is_array(global.RECENT_NODES)) global.RECENT_NODES = [];
|
if(!is_array(global.RECENT_NODES)) global.RECENT_NODES = [];
|
||||||
|
|
||||||
|
NODE_PAGE_DEFAULT = ds_list_size(NODE_CATEGORY);
|
||||||
|
ADD_NODE_PAGE = NODE_PAGE_DEFAULT;
|
||||||
|
|
||||||
|
var fav = ds_list_create();
|
||||||
|
addNodeCatagory("Favourites", fav);
|
||||||
|
|
||||||
var group = ds_list_create(); #region
|
var group = ds_list_create(); #region
|
||||||
addNodeCatagory("Group", group, ["Node_Group"]);
|
addNodeCatagory("Group", group, ["Node_Group"]);
|
||||||
ds_list_add(group, "Groups");
|
ds_list_add(group, "Groups");
|
||||||
|
@ -373,11 +379,7 @@ function NodeObject(_name, _spr, _node, _create, tags = []) constructor { #regio
|
||||||
addNodeObject(strandSim, "Strand Collision", s_node_strandSim_collide, "Node_Strand_Collision", [1, Node_Strand_Collision],, "Create solid object for strands to collides to.").hideRecent().setVersion(1140);
|
addNodeObject(strandSim, "Strand Collision", s_node_strandSim_collide, "Node_Strand_Collision", [1, Node_Strand_Collision],, "Create solid object for strands to collides to.").hideRecent().setVersion(1140);
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
NODE_PAGE_DEFAULT = ds_list_size(NODE_CATEGORY);
|
//////////////////////////////////////////////////////////////////////////////////
|
||||||
ADD_NODE_PAGE = NODE_PAGE_DEFAULT;
|
|
||||||
|
|
||||||
var fav = ds_list_create();
|
|
||||||
addNodeCatagory("Favourites", fav);
|
|
||||||
|
|
||||||
var input = ds_list_create(); #region
|
var input = ds_list_create(); #region
|
||||||
addNodeCatagory("IO", input);
|
addNodeCatagory("IO", input);
|
||||||
|
|
|
@ -15,7 +15,7 @@ function Node_Scatter(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) c
|
||||||
inputs[| 4] = nodeValue("Angle", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 0, 0, 0, 0, 0 ] )
|
inputs[| 4] = nodeValue("Angle", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 0, 0, 0, 0, 0 ] )
|
||||||
.setDisplay(VALUE_DISPLAY.rotation_random);
|
.setDisplay(VALUE_DISPLAY.rotation_random);
|
||||||
|
|
||||||
onSurfaceSize = function() { return getInputData(1, DEF_SURF); };
|
onSurfaceSize = function() { return surface_get_dimension(getInputData(1, DEF_SURF)); };
|
||||||
inputs[| 5] = nodeValue("Area", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ DEF_SURF_W / 2, DEF_SURF_H / 2, DEF_SURF_W / 2, DEF_SURF_H / 2, AREA_SHAPE.rectangle ])
|
inputs[| 5] = nodeValue("Area", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ DEF_SURF_W / 2, DEF_SURF_H / 2, DEF_SURF_W / 2, DEF_SURF_H / 2, AREA_SHAPE.rectangle ])
|
||||||
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ function Node_Scatter_Points(_x, _y, _group = noone) : Node(_x, _y, _group) cons
|
||||||
|
|
||||||
w = 96;
|
w = 96;
|
||||||
|
|
||||||
onSurfaceSize = function() { return getInputData(7, DEF_SURF); };
|
onSurfaceSize = function() { return surface_get_dimension(getInputData(7, DEF_SURF)); };
|
||||||
inputs[| 0] = nodeValue("Point area", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ DEF_SURF_W / 2, DEF_SURF_H / 2, DEF_SURF_W / 2, DEF_SURF_H / 2, AREA_SHAPE.rectangle ])
|
inputs[| 0] = nodeValue("Point area", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ DEF_SURF_W / 2, DEF_SURF_H / 2, DEF_SURF_W / 2, DEF_SURF_H / 2, AREA_SHAPE.rectangle ])
|
||||||
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ function Node_Shape(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) con
|
||||||
inputs[| 2] = nodeValue("Shape", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
inputs[| 2] = nodeValue("Shape", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
|
||||||
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Rectangle", "Ellipse", "Regular polygon", "Star", "Arc", "Teardrop", "Cross", "Leaf" ]);
|
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Rectangle", "Ellipse", "Regular polygon", "Star", "Arc", "Teardrop", "Cross", "Leaf" ]);
|
||||||
|
|
||||||
onSurfaceSize = function() { return getInputData(0, DEF_SURF); };
|
onSurfaceSize = function() { return surface_get_dimension(getInputData(0, DEF_SURF)); };
|
||||||
inputs[| 3] = nodeValue("Position", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ DEF_SURF_W / 2, DEF_SURF_H / 2, DEF_SURF_W / 2, DEF_SURF_H / 2, AREA_SHAPE.rectangle ])
|
inputs[| 3] = nodeValue("Position", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ DEF_SURF_W / 2, DEF_SURF_H / 2, DEF_SURF_W / 2, DEF_SURF_H / 2, AREA_SHAPE.rectangle ])
|
||||||
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
||||||
|
|
||||||
|
|
|
@ -956,6 +956,7 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
|
||||||
editWidget = new areaBox(function(index, val) {
|
editWidget = new areaBox(function(index, val) {
|
||||||
return setValueDirect(val, index);
|
return setValueDirect(val, index);
|
||||||
}, unit);
|
}, unit);
|
||||||
|
|
||||||
if(type == VALUE_TYPE.integer) editWidget.setSlideSpeed(1);
|
if(type == VALUE_TYPE.integer) editWidget.setSlideSpeed(1);
|
||||||
if(struct_has(display_data, "onSurfaceSize")) editWidget.onSurfaceSize = display_data.onSurfaceSize;
|
if(struct_has(display_data, "onSurfaceSize")) editWidget.onSurfaceSize = display_data.onSurfaceSize;
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ function Node_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
|
|
||||||
attributes[? "initalset"] = true;
|
attributes[? "initalset"] = true;
|
||||||
}
|
}
|
||||||
} #endregion
|
} if(!LOADING && !APPENDING) run_in(1, function() { onValueFromUpdate(0); }) #endregion
|
||||||
|
|
||||||
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
|
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
|
||||||
PROCESSOR_OVERLAY_CHECK
|
PROCESSOR_OVERLAY_CHECK
|
||||||
|
|
|
@ -3,7 +3,7 @@ function Node_Wrap_Area(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
inputs[| 0] = nodeValue("Surface in", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);
|
||||||
|
|
||||||
onSurfaceSize = function() { return getInputData(0, DEF_SURF); };
|
onSurfaceSize = function() { return surface_get_dimension(getInputData(0, DEF_SURF)); };
|
||||||
inputs[| 1] = nodeValue("Area", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ 16, 16, 4, 4, AREA_SHAPE.rectangle ])
|
inputs[| 1] = nodeValue("Area", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ 16, 16, 4, 4, AREA_SHAPE.rectangle ])
|
||||||
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
.setDisplay(VALUE_DISPLAY.area, { onSurfaceSize });
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ function Node_Wrap_Area(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
|
||||||
inputs[| 1].setValue([ _sw / 2, _sh / 2, _sw / 2, _sh / 2, AREA_SHAPE.rectangle ]);
|
inputs[| 1].setValue([ _sw / 2, _sh / 2, _sw / 2, _sh / 2, AREA_SHAPE.rectangle ]);
|
||||||
attributes[? "initalset"] = true;
|
attributes[? "initalset"] = true;
|
||||||
}
|
}
|
||||||
} #endregion
|
} if(!LOADING && !APPENDING) run_in(1, function() { onValueFromUpdate(0); }) #endregion
|
||||||
|
|
||||||
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
||||||
inputs[| 1].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
inputs[| 1].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||||
|
|
|
@ -261,6 +261,9 @@ function Panel_Menu() : PanelContent() constructor {
|
||||||
var dia = dialogPanelCall(new Panel_Node_Data_Gen());
|
var dia = dialogPanelCall(new Panel_Node_Data_Gen());
|
||||||
dia.destroy_on_click_out = false;
|
dia.destroy_on_click_out = false;
|
||||||
}),
|
}),
|
||||||
|
menuItem(__txtx("panel_menu_test_gen_theme", "Generate theme object"), function() {
|
||||||
|
__test_generate_theme();
|
||||||
|
}),
|
||||||
-1,
|
-1,
|
||||||
menuItem(__txtx("panel_menu_test_crash", "Force crash"), function() {
|
menuItem(__txtx("panel_menu_test_crash", "Force crash"), function() {
|
||||||
print(1 + "a");
|
print(1 + "a");
|
||||||
|
|
|
@ -1,17 +1,28 @@
|
||||||
function preview_overlay_area_padding(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag, display_data) {
|
function preview_overlay_area_padding(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag, display_data) { #region
|
||||||
var _val = array_clone(getValue());
|
var _val = array_clone(getValue());
|
||||||
var hover = -1;
|
var hover = -1;
|
||||||
|
|
||||||
if(!is_callable(display_data)) return hover;
|
if(!is_callable(display_data)) return hover;
|
||||||
|
|
||||||
var ss = display_data();
|
var __ax = array_safe_get(_val, 0);
|
||||||
|
var __ay = array_safe_get(_val, 1);
|
||||||
|
var __aw = array_safe_get(_val, 2);
|
||||||
|
var __ah = array_safe_get(_val, 3);
|
||||||
var __at = array_safe_get(_val, 4);
|
var __at = array_safe_get(_val, 4);
|
||||||
var _r = array_safe_get(_val, 0);
|
|
||||||
var _t = array_safe_get(_val, 1);
|
var _x0 = __ax - __aw;
|
||||||
var _l = array_safe_get(_val, 2);
|
var _x1 = __ax + __aw;
|
||||||
var _b = array_safe_get(_val, 3);
|
var _y0 = __ay - __ah;
|
||||||
var _xc = ((ss[0] - _r) + _l) / 2;
|
var _y1 = __ay + __ah;
|
||||||
var _yc = ((ss[1] - _b) + _t) / 2;
|
|
||||||
|
var ss = display_data();
|
||||||
|
|
||||||
|
var _l = _x0;
|
||||||
|
var _r = ss[0] - _x1;
|
||||||
|
var _t = _y0;
|
||||||
|
var _b = ss[1] - _y1;
|
||||||
|
var _xc = __ax;
|
||||||
|
var _yc = __ay;
|
||||||
|
|
||||||
var x0 = _l * _s + _x;
|
var x0 = _l * _s + _x;
|
||||||
var y0 = _t * _s + _y;
|
var y0 = _t * _s + _y;
|
||||||
|
@ -42,50 +53,19 @@ function preview_overlay_area_padding(interact, active, _x, _y, _s, _mx, _my, _s
|
||||||
draw_sprite_colored(THEME.anchor_solid_hori, 0, x1, yc,, 90);
|
draw_sprite_colored(THEME.anchor_solid_hori, 0, x1, yc,, 90);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(drag_type == 1) {
|
if(drag_type == 1) _r = value_snap(drag_sx - (_mx - drag_mx) / _s, _snx);
|
||||||
var _xx = value_snap(drag_sx - (_mx - drag_mx) / _s, _snx);
|
else if(drag_type == 2) _t = value_snap(drag_sy + (_my - drag_my) / _s, _sny);
|
||||||
_val[0] = _xx;
|
else if(drag_type == 3) _l = value_snap(drag_sx + (_mx - drag_mx) / _s, _snx);
|
||||||
|
else if(drag_type == 4) _b = value_snap(drag_sy - (_my - drag_my) / _s, _sny);
|
||||||
|
|
||||||
if(setValue(_val))
|
if(drag_type) {
|
||||||
UNDO_HOLDING = true;
|
var _val = [ _r, _t, _l, _b, __at ];
|
||||||
} else if(drag_type == 2) {
|
if(setValue(_val)) UNDO_HOLDING = true;
|
||||||
var _yy = value_snap(drag_sy + (_my - drag_my) / _s, _sny);
|
|
||||||
_val[1] = _yy;
|
|
||||||
|
|
||||||
if(setValue(_val))
|
if(mouse_release(mb_left)) {
|
||||||
UNDO_HOLDING = true;
|
drag_type = 0;
|
||||||
} else if(drag_type == 3) {
|
UNDO_HOLDING = false;
|
||||||
var _xx = value_snap(drag_sx + (_mx - drag_mx) / _s, _snx);
|
}
|
||||||
_val[2] = _xx;
|
|
||||||
|
|
||||||
if(setValue(_val))
|
|
||||||
UNDO_HOLDING = true;
|
|
||||||
} else if(drag_type == 4) {
|
|
||||||
var _yy = value_snap(drag_sy - (_my - drag_my) / _s, _sny);
|
|
||||||
_val[3] = _yy;
|
|
||||||
|
|
||||||
if(setValue(_val))
|
|
||||||
UNDO_HOLDING = true;
|
|
||||||
} else if(drag_type == 5) {
|
|
||||||
var _xx = value_snap(drag_sx + (_mx - drag_mx) / _s, _snx);
|
|
||||||
var _yy = value_snap(drag_sy + (_my - drag_my) / _s, _sny);
|
|
||||||
var _w = ss[0] - _r - _l;
|
|
||||||
var _h = ss[1] - _b - _t;
|
|
||||||
|
|
||||||
var nr = ss[0] - (_xx + _w / 2);
|
|
||||||
var nl = _xx - _w / 2;
|
|
||||||
var nt = _yy - _h / 2;
|
|
||||||
var nb = ss[1] - (_yy + _h / 2);
|
|
||||||
|
|
||||||
_val = [ nr, nt, nl, nb, __at ];
|
|
||||||
|
|
||||||
if(setValue(_val))
|
|
||||||
UNDO_HOLDING = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(drag_type && mouse_release(mb_left)) {
|
|
||||||
drag_type = 0;
|
|
||||||
UNDO_HOLDING = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(drawSize && active && point_in_circle(_mx, _my, xc, y0, 16)) {
|
if(drawSize && active && point_in_circle(_mx, _my, xc, y0, 16)) {
|
||||||
|
@ -124,32 +104,25 @@ function preview_overlay_area_padding(interact, active, _x, _y, _s, _mx, _my, _s
|
||||||
drag_sx = _r;
|
drag_sx = _r;
|
||||||
drag_mx = _mx;
|
drag_mx = _mx;
|
||||||
}
|
}
|
||||||
} else if(drawPos && active && point_in_rectangle(_mx, _my, x0, y0, x1, y1)) {
|
|
||||||
draw_sprite_colored(THEME.anchor, 1, xc, yc);
|
|
||||||
hover = 4;
|
|
||||||
|
|
||||||
if(mouse_press(mb_left)) {
|
|
||||||
drag_type = 5;
|
|
||||||
drag_sx = _xc;
|
|
||||||
drag_sy = _yc;
|
|
||||||
drag_mx = _mx;
|
|
||||||
drag_my = _my;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return hover;
|
return hover;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function preview_overlay_area_two_point(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag) {
|
function preview_overlay_area_two_point(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag) { #region
|
||||||
var _val = array_clone(getValue());
|
var _val = array_clone(getValue());
|
||||||
var hover = -1;
|
var hover = -1;
|
||||||
|
|
||||||
|
var __ax = array_safe_get(_val, 0);
|
||||||
|
var __ay = array_safe_get(_val, 1);
|
||||||
|
var __aw = array_safe_get(_val, 2);
|
||||||
|
var __ah = array_safe_get(_val, 3);
|
||||||
var __at = array_safe_get(_val, 4);
|
var __at = array_safe_get(_val, 4);
|
||||||
|
|
||||||
var _x0 = array_safe_get(_val, 0);
|
var _x0 = __ax - __aw;
|
||||||
var _y0 = array_safe_get(_val, 1);
|
var _y0 = __ay - __ah;
|
||||||
var _x1 = array_safe_get(_val, 2);
|
var _x1 = __ax + __aw;
|
||||||
var _y1 = array_safe_get(_val, 3);
|
var _y1 = __ay + __ah;
|
||||||
|
|
||||||
var x0 = _x0 * _s + _x;
|
var x0 = _x0 * _s + _x;
|
||||||
var y0 = _y0 * _s + _y;
|
var y0 = _y0 * _s + _y;
|
||||||
|
@ -254,9 +227,9 @@ function preview_overlay_area_two_point(interact, active, _x, _y, _s, _mx, _my,
|
||||||
}
|
}
|
||||||
|
|
||||||
return hover;
|
return hover;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function preview_overlay_area_span(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag) {
|
function preview_overlay_area_span(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag) { #region
|
||||||
var _val = array_clone(getValue());
|
var _val = array_clone(getValue());
|
||||||
var hover = -1;
|
var hover = -1;
|
||||||
|
|
||||||
|
@ -357,7 +330,7 @@ function preview_overlay_area_span(interact, active, _x, _y, _s, _mx, _my, _snx,
|
||||||
}
|
}
|
||||||
|
|
||||||
return hover;
|
return hover;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function preview_overlay_area(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag, display_data) {
|
function preview_overlay_area(interact, active, _x, _y, _s, _mx, _my, _snx, _sny, _flag, display_data) {
|
||||||
var _val = array_clone(getValue());
|
var _val = array_clone(getValue());
|
||||||
|
|
|
@ -174,6 +174,13 @@ function surface_get_height_safe(s, crop = true) {
|
||||||
return surface_get_height(s);
|
return surface_get_height(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function surface_get_dimension(s) {
|
||||||
|
INLINE
|
||||||
|
|
||||||
|
if(!is_surface(s)) return [ 1, 1 ];
|
||||||
|
return [ surface_get_width_safe(s), surface_get_height_safe(s) ];
|
||||||
|
}
|
||||||
|
|
||||||
//check
|
//check
|
||||||
function is_surface(s) {
|
function is_surface(s) {
|
||||||
INLINE
|
INLINE
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
function __test_update_current_collections() {
|
function __test_update_current_collections() { #region
|
||||||
var st = ds_stack_create();
|
var st = ds_stack_create();
|
||||||
ds_stack_push(st, PANEL_COLLECTION.context);
|
ds_stack_push(st, PANEL_COLLECTION.context);
|
||||||
|
|
||||||
|
@ -25,9 +25,9 @@ function __test_update_current_collections() {
|
||||||
ds_stack_destroy(st);
|
ds_stack_destroy(st);
|
||||||
|
|
||||||
print("---------- COLLECTION UPDATING ENDED ----------");
|
print("---------- COLLECTION UPDATING ENDED ----------");
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function __test_update_sample_projects() {
|
function __test_update_sample_projects() { #region
|
||||||
print("---------- PROJECT UPDATING STARTED ----------");
|
print("---------- PROJECT UPDATING STARTED ----------");
|
||||||
|
|
||||||
for( var i = 0; i < ds_list_size(SAMPLE_PROJECTS); i++ ) {
|
for( var i = 0; i < ds_list_size(SAMPLE_PROJECTS); i++ ) {
|
||||||
|
@ -40,9 +40,9 @@ function __test_update_sample_projects() {
|
||||||
}
|
}
|
||||||
|
|
||||||
print("---------- PROJECT UPDATING ENDED ----------");
|
print("---------- PROJECT UPDATING ENDED ----------");
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function __test_load_current_collections() {
|
function __test_load_current_collections() { #region
|
||||||
var st = ds_stack_create();
|
var st = ds_stack_create();
|
||||||
ds_stack_push(st, PANEL_COLLECTION.context);
|
ds_stack_push(st, PANEL_COLLECTION.context);
|
||||||
|
|
||||||
|
@ -104,9 +104,9 @@ function __test_load_current_collections() {
|
||||||
ds_stack_destroy(st);
|
ds_stack_destroy(st);
|
||||||
|
|
||||||
print("---------- COLLECTION TESTING ENDED ----------");
|
print("---------- COLLECTION TESTING ENDED ----------");
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function __test_load_all_nodes() {
|
function __test_load_all_nodes() { #region
|
||||||
var amo = ds_map_size(ALL_NODES);
|
var amo = ds_map_size(ALL_NODES);
|
||||||
var k = ds_map_find_first(ALL_NODES);
|
var k = ds_map_find_first(ALL_NODES);
|
||||||
var xx = 0;
|
var xx = 0;
|
||||||
|
@ -148,9 +148,9 @@ function __test_load_all_nodes() {
|
||||||
k = ds_map_find_next(ALL_NODES, k);
|
k = ds_map_find_next(ALL_NODES, k);
|
||||||
}
|
}
|
||||||
LOADING = false;
|
LOADING = false;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function __test_metadata_current_collections() {
|
function __test_metadata_current_collections() { #region
|
||||||
var st = ds_stack_create();
|
var st = ds_stack_create();
|
||||||
ds_stack_push(st, PANEL_COLLECTION.context);
|
ds_stack_push(st, PANEL_COLLECTION.context);
|
||||||
|
|
||||||
|
@ -176,4 +176,15 @@ function __test_metadata_current_collections() {
|
||||||
ds_stack_destroy(st);
|
ds_stack_destroy(st);
|
||||||
|
|
||||||
print("---------- COLLECTION UPDATING ENDED ----------");
|
print("---------- COLLECTION UPDATING ENDED ----------");
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
|
function __test_generate_theme() { #region
|
||||||
|
var _txt = "function Theme() constructor {\n";
|
||||||
|
var _spr = struct_get_names(THEME);
|
||||||
|
|
||||||
|
for( var i = 0, n = array_length(_spr); i < n; i++ )
|
||||||
|
_txt += $"\t{_spr[i]} = noone;\n";
|
||||||
|
_txt += "}";
|
||||||
|
|
||||||
|
clipboard_set_text(_txt);
|
||||||
|
} #endregion
|
|
@ -1,290 +1,347 @@
|
||||||
function Theme() constructor {
|
function Theme() constructor {
|
||||||
color_picker_sample = noone;
|
pixel_builder = noone;
|
||||||
button_color_overlay = noone;
|
junc_visible = noone;
|
||||||
color_picker_box = noone;
|
tools_canvas_channel = noone;
|
||||||
dialog_active = noone;
|
ui_scrollbar = noone;
|
||||||
dialog_bg = noone;
|
control_remove = noone;
|
||||||
group_label = noone;
|
vct = noone;
|
||||||
shadow_drop_down_24 = noone;
|
node_frame_title = noone;
|
||||||
menu_bg = noone;
|
duplicate = noone;
|
||||||
|
group_label = noone;
|
||||||
accept = noone;
|
panel_graph = noone;
|
||||||
add = noone;
|
tunnel = noone;
|
||||||
animate_clock = noone;
|
icon_curve_connection = noone;
|
||||||
animate_node_go = noone;
|
timeline_clock = noone;
|
||||||
animate_onion_skin = noone;
|
animate_clock = noone;
|
||||||
animation_setting = noone;
|
prop_selecting = noone;
|
||||||
animation_timing = noone;
|
node_websocket_receive = noone;
|
||||||
animation_stretch = noone;
|
text_slider = noone;
|
||||||
arrow = noone;
|
preview_bone_IK = noone;
|
||||||
button_path_icon = noone;
|
tools_3d_transform_object = noone;
|
||||||
button_path_not_found_icon = noone;
|
prop_anchor = noone;
|
||||||
cache = noone;
|
node_draw_path = noone;
|
||||||
circle = noone;
|
node_pin_bg_active = noone;
|
||||||
color_picker_dropper = noone;
|
icon_splash_show_on_start = noone;
|
||||||
cursor_select = noone;
|
noti_icon_warning = noone;
|
||||||
file = noone;
|
pin = noone;
|
||||||
explorer = noone;
|
accept_16 = noone;
|
||||||
fill = noone;
|
animate_prop_go = noone;
|
||||||
filter_type = noone;
|
accept = noone;
|
||||||
fluid_sim = noone;
|
bone_tool_detach = noone;
|
||||||
folder = noone;
|
loading_s = noone;
|
||||||
folder_add = noone;
|
loop = noone;
|
||||||
folder_content = noone;
|
cursor_path_add = noone;
|
||||||
gear = noone;
|
addon_icon = noone;
|
||||||
grad_blend = noone;
|
inspector_text_halign = noone;
|
||||||
graph = noone;
|
anchor_scale_hori = noone;
|
||||||
group = noone;
|
noti_icon_file_save = noone;
|
||||||
group_s = noone;
|
minus_20 = noone;
|
||||||
hamburger = noone;
|
node_junctions_outline = noone;
|
||||||
visible = noone;
|
color_wheel = noone;
|
||||||
workshop_download = noone;
|
group_s = noone;
|
||||||
workshop_upload = noone;
|
add = noone;
|
||||||
workshop_update = noone;
|
panel_animation = noone;
|
||||||
icon_visibility = noone;
|
code_show_line = noone;
|
||||||
info = noone;
|
canvas_tools_rect_fill = noone;
|
||||||
junc_visible = noone;
|
path_tools_add = noone;
|
||||||
loading = noone;
|
node_rotator_knob = noone;
|
||||||
loading_s = noone;
|
discord = noone;
|
||||||
feedback = noone;
|
action_history = noone;
|
||||||
loop = noone;
|
onion_skin = noone;
|
||||||
unit_ref = noone;
|
|
||||||
vfx = noone;
|
|
||||||
minus = noone;
|
|
||||||
text = noone;
|
|
||||||
new_file = noone;
|
|
||||||
node_processor = noone;
|
|
||||||
value_link = noone;
|
|
||||||
pin = noone;
|
|
||||||
play_all = noone;
|
|
||||||
project = noone;
|
|
||||||
preset = noone;
|
|
||||||
refresh = noone;
|
|
||||||
refresh_s = noone;
|
|
||||||
reverse = noone;
|
|
||||||
rigidSim = noone;
|
|
||||||
scroll_box_arrow = noone;
|
|
||||||
search = noone;
|
|
||||||
sequence_control = noone;
|
|
||||||
sort = noone;
|
|
||||||
steam = noone;
|
|
||||||
steam_creator = noone;
|
|
||||||
text_bullet = noone;
|
|
||||||
text_slider = noone;
|
|
||||||
timeline_clock = noone;
|
|
||||||
timeline_graph = noone;
|
|
||||||
view_group = noone;
|
|
||||||
view_mode = noone;
|
|
||||||
icon_delete = noone;
|
|
||||||
addon_icon = noone;
|
|
||||||
youtube = noone;
|
|
||||||
wiki = noone;
|
|
||||||
itch = noone;
|
|
||||||
undo = noone;
|
|
||||||
redo = noone;
|
|
||||||
action_history = noone;
|
|
||||||
cross = noone;
|
|
||||||
duplicate = noone;
|
|
||||||
copy = noone;
|
|
||||||
paste = noone;
|
|
||||||
node_resize = noone;
|
|
||||||
icon_curve_connection = noone;
|
|
||||||
node_output_visible = noone;
|
|
||||||
icon_minimap = noone;
|
|
||||||
noti_icon_tick = noone;
|
|
||||||
noti_icon_error = noone;
|
|
||||||
noti_icon_warning = noone;
|
|
||||||
noti_icon_log = noone;
|
|
||||||
noti_icon_file_load = noone;
|
|
||||||
noti_icon_file_save = noone;
|
|
||||||
icon_center_canvas = noone;
|
|
||||||
icon_grid = noone;
|
|
||||||
icon_grid_setting = noone;
|
|
||||||
icon_preview_export = noone;
|
|
||||||
icon_reset_when_preview = noone;
|
|
||||||
icon_split_view = noone;
|
|
||||||
icon_tile_view = noone;
|
|
||||||
icon_active_split = noone;
|
|
||||||
save = noone;
|
|
||||||
save_auto = noone;
|
|
||||||
window_exit = noone;
|
|
||||||
window_minimize = noone;
|
|
||||||
window_maximize = noone;
|
|
||||||
window_fullscreen = noone;
|
|
||||||
icon_splash_show_on_start = noone;
|
|
||||||
icon_array_processor = noone;
|
|
||||||
tunnel = noone;
|
|
||||||
lock = noone;
|
|
||||||
node_move = noone;
|
|
||||||
splash_thumbnail = noone;
|
|
||||||
node_goto = noone;
|
|
||||||
node_create = noone;
|
|
||||||
node_use_global = noone;
|
|
||||||
node_use_expression = noone;
|
|
||||||
icon_toggle = noone;
|
|
||||||
strandSim = noone;
|
|
||||||
star = noone;
|
|
||||||
panel_graph = noone;
|
|
||||||
panel_preview = noone;
|
|
||||||
panel_inspector = noone;
|
|
||||||
panel_animation = noone;
|
|
||||||
color_wheel = noone;
|
|
||||||
node_name_type = noone;
|
|
||||||
checkbox_on_start = noone;
|
|
||||||
addon_setting = noone;
|
|
||||||
keyframe_override = noone;
|
|
||||||
play_sound = noone;
|
|
||||||
trophy = noone;
|
|
||||||
chat = noone;
|
|
||||||
arrow_back_32 = noone;
|
|
||||||
discord = noone;
|
|
||||||
heart = noone;
|
|
||||||
websocket = noone;
|
|
||||||
node_dropper = noone;
|
|
||||||
bone = noone;
|
|
||||||
tab_exit = noone;
|
|
||||||
icon_save_all = noone;
|
|
||||||
onion_skin = noone;
|
|
||||||
|
|
||||||
inspector_area = noone;
|
|
||||||
inspector_area_type = noone;
|
|
||||||
inspector_padding = noone;
|
|
||||||
inspector_surface_halign = noone;
|
|
||||||
inspector_surface_valign = noone;
|
|
||||||
inspector_text_halign = noone;
|
|
||||||
inspector_text_valign = noone;
|
|
||||||
prop_gradient = noone;
|
|
||||||
prop_keyframe = noone;
|
|
||||||
prop_on_end = noone;
|
|
||||||
prop_selecting = noone;
|
|
||||||
rotator_bg = noone;
|
|
||||||
rotator_knob = noone;
|
|
||||||
|
|
||||||
icon_24 = noone;
|
|
||||||
icon_32 = noone;
|
|
||||||
icon_64 = noone;
|
|
||||||
node_draw_area = noone;
|
|
||||||
node_draw_path = noone;
|
|
||||||
node_junction_inspector = noone;
|
|
||||||
node_junctions_array = noone;
|
|
||||||
node_junctions_array_hover = noone;
|
|
||||||
node_junctions_single = noone;
|
|
||||||
node_junctions_single_hover = noone;
|
|
||||||
node_new_badge = noone;
|
|
||||||
node_pin_bg = noone;
|
|
||||||
node_pin_bg_active = noone;
|
|
||||||
node_active = noone;
|
|
||||||
node_bg = noone;
|
|
||||||
node_bg_name = noone;
|
|
||||||
node_glow = noone;
|
|
||||||
node_frame_bg = noone;
|
|
||||||
node_frame_title = noone;
|
|
||||||
node_junction_name_bg = noone;
|
|
||||||
node_state = noone;
|
|
||||||
node_bg_pill = noone;
|
|
||||||
node_trigger = noone;
|
|
||||||
node_slider = noone;
|
|
||||||
node_rotator_bg = noone;
|
|
||||||
node_rotator_knob = noone;
|
|
||||||
node_checkbox = noone;
|
|
||||||
node_coor_pin = noone;
|
|
||||||
node_websocket_receive = noone;
|
|
||||||
node_websocket_send = noone;
|
|
||||||
|
|
||||||
menu_separator = noone;
|
|
||||||
menu_button = noone;
|
|
||||||
menu_button_mask = noone;
|
|
||||||
key_display = noone;
|
|
||||||
toolbar_shadow = noone;
|
|
||||||
ui_panel_active = noone;
|
|
||||||
ui_panel_tab = noone;
|
|
||||||
ui_panel_bg = noone;
|
|
||||||
ui_panel_fg = noone;
|
|
||||||
ui_panel_bg_cover = noone;
|
|
||||||
ui_scrollbar = noone;
|
|
||||||
ui_label_bg = noone;
|
|
||||||
toolbar = noone;
|
|
||||||
ui_selection = noone;
|
|
||||||
timeline_dopesheet_bg = noone;
|
|
||||||
|
|
||||||
cursor_path_add = noone;
|
|
||||||
cursor_path_anchor = noone;
|
|
||||||
cursor_path_move = noone;
|
|
||||||
cursor_path_remove = noone;
|
|
||||||
anchor = noone;
|
|
||||||
anchor_rotate = noone;
|
|
||||||
anchor_scale = noone;
|
|
||||||
anchor_solid_hori = noone;
|
|
||||||
anchor_scale_hori = noone;
|
|
||||||
anchor_selector = noone;
|
|
||||||
anchor_arrow = noone;
|
|
||||||
preview_crosshair = noone;
|
|
||||||
preview_bone_IK = noone;
|
|
||||||
anchor_bone_stick = noone;
|
|
||||||
|
|
||||||
timeline_ease = noone;
|
|
||||||
timeline_elastic = noone;
|
|
||||||
timeline_keyframe = noone;
|
|
||||||
timeline_keyframe_selecting = noone;
|
|
||||||
object_halign = noone;
|
|
||||||
object_valign = noone;
|
|
||||||
timeline_onion_skin = noone;
|
timeline_onion_skin = noone;
|
||||||
|
animate_onion_skin = noone;
|
||||||
obj_distribute_h = noone;
|
anchor_rotate = noone;
|
||||||
obj_distribute_v = noone;
|
button_left = noone;
|
||||||
|
obj_distribute_v = noone;
|
||||||
canvas_tools_bucket = noone;
|
node_goto = noone;
|
||||||
canvas_tools_ellip = noone;
|
star = noone;
|
||||||
canvas_tools_ellip_fill = noone;
|
bone_tool_scale = noone;
|
||||||
canvas_tools_eraser = noone;
|
node_junctions_single_hover = noone;
|
||||||
canvas_tools_pencil = noone;
|
node_note_selecting = noone;
|
||||||
canvas_tools_rect = noone;
|
obj_angle = noone;
|
||||||
canvas_tools_rect_fill = noone;
|
node_use_global = noone;
|
||||||
control_add = noone;
|
panel_inspector = noone;
|
||||||
control_remove = noone;
|
steam_creator = noone;
|
||||||
control_pin = noone;
|
animation_stretch = noone;
|
||||||
control_unpin = noone;
|
ui_panel_fg = noone;
|
||||||
mesh_tool_edit = noone;
|
toolbar = noone;
|
||||||
mesh_tool_delete = noone;
|
icon_visibility = noone;
|
||||||
path_tools_add = noone;
|
node_use_project = noone;
|
||||||
path_tools_anchor = noone;
|
ac_constant = noone;
|
||||||
path_tools_circle = noone;
|
redo = noone;
|
||||||
path_tools_rectangle = noone;
|
inspector_surface_valign = noone;
|
||||||
path_tools_draw = noone;
|
textbox_header = noone;
|
||||||
path_tools_transform = noone;
|
obj_direction = noone;
|
||||||
tools_canvas_channel = noone;
|
anchor_arrow = noone;
|
||||||
tools_3d_transform = noone;
|
rigidSim = noone;
|
||||||
tools_3d_rotate = noone;
|
button = noone;
|
||||||
tools_3d_scale = noone;
|
icon_64 = noone;
|
||||||
splice_draw = noone;
|
node_pin_bg = noone;
|
||||||
strand_comb = noone;
|
button_hide = noone;
|
||||||
strand_cut = noone;
|
window_maximize = noone;
|
||||||
strand_grab = noone;
|
animation_timing = noone;
|
||||||
strand_push = noone;
|
new_file = noone;
|
||||||
strand_stretch = noone;
|
play_action = noone;
|
||||||
bone_tool_add = noone;
|
canvas_tools_selection_rectangle = noone;
|
||||||
bone_tool_detach = noone;
|
splice_draw = noone;
|
||||||
bone_tool_remove = noone;
|
panel_preview = noone;
|
||||||
bone_tool_transform = noone;
|
tools_3d_rotate = noone;
|
||||||
bone_tool_IK = noone;
|
toolbar_shadow = noone;
|
||||||
|
inspector_area_type = noone;
|
||||||
button = noone;
|
noti_icon_log = noone;
|
||||||
button_hide = noone;
|
prop_on_end = noone;
|
||||||
button_hide_fill = noone;
|
export_package = noone;
|
||||||
button_hide_left = noone;
|
icon_split_view = noone;
|
||||||
button_hide_middle = noone;
|
grad_blend = noone;
|
||||||
button_hide_right = noone;
|
node_bg = noone;
|
||||||
button_left = noone;
|
strand_grab = noone;
|
||||||
button_lime = noone;
|
canvas_tools_ellip_fill = noone;
|
||||||
button_middle = noone;
|
vfx = noone;
|
||||||
button_right = noone;
|
mesh_tool_edit = noone;
|
||||||
checkbox = noone;
|
ui_panel_bg = noone;
|
||||||
slider = noone;
|
node_trigger = noone;
|
||||||
widget_selecting = noone;
|
timeline_ease = noone;
|
||||||
textbox = noone;
|
cache_group = noone;
|
||||||
textbox_header = noone;
|
chat = noone;
|
||||||
textbox_code = noone;
|
wiki = noone;
|
||||||
progress_bar = noone;
|
patreon = noone;
|
||||||
|
dialog_bg = noone;
|
||||||
|
color_picker_box = noone;
|
||||||
|
object_valign = noone;
|
||||||
|
addon_setting = noone;
|
||||||
|
sequence_control = noone;
|
||||||
|
node_junctions_array_hover = noone;
|
||||||
|
text = noone;
|
||||||
|
info = noone;
|
||||||
|
node_checkbox = noone;
|
||||||
|
splash_thumbnail = noone;
|
||||||
|
search = noone;
|
||||||
|
icon_active_split = noone;
|
||||||
|
timeline_node = noone;
|
||||||
|
textbox_code = noone;
|
||||||
|
file = noone;
|
||||||
|
undo = noone;
|
||||||
|
gear = noone;
|
||||||
|
bone_tool_IK = noone;
|
||||||
|
cursor_path_remove = noone;
|
||||||
|
lock = noone;
|
||||||
|
icon_24 = noone;
|
||||||
|
node_note_pin = noone;
|
||||||
|
minus_16 = noone;
|
||||||
|
window_exit = noone;
|
||||||
|
text_popup = noone;
|
||||||
|
animation_setting = noone;
|
||||||
|
folder = noone;
|
||||||
|
button_hide_circle_28 = noone;
|
||||||
|
feedback = noone;
|
||||||
|
tab_exit = noone;
|
||||||
|
timeline_graph = noone;
|
||||||
|
canvas_tools_pencil = noone;
|
||||||
|
path_tools_draw = noone;
|
||||||
|
refresh_s = noone;
|
||||||
|
menu_button = noone;
|
||||||
|
icon_save_all = noone;
|
||||||
|
button_hide_middle = noone;
|
||||||
|
icon_minimap = noone;
|
||||||
|
noti_icon_console = noone;
|
||||||
|
textbox = noone;
|
||||||
|
fluid_sim = noone;
|
||||||
|
ui_panel_tab = noone;
|
||||||
|
button_path_icon = noone;
|
||||||
|
strand_stretch = noone;
|
||||||
|
cursor_select = noone;
|
||||||
|
node_glow = noone;
|
||||||
|
control_pin = noone;
|
||||||
|
node_junction_name_bg = noone;
|
||||||
|
play_sound = noone;
|
||||||
|
view_group = noone;
|
||||||
|
copy = noone;
|
||||||
|
node_use_expression = noone;
|
||||||
|
ui_selection = noone;
|
||||||
|
color_picker_sample = noone;
|
||||||
|
ac_node = noone;
|
||||||
|
close_16 = noone;
|
||||||
|
anchor_bone_stick = noone;
|
||||||
|
cross = noone;
|
||||||
|
checkbox_on_start = noone;
|
||||||
|
node_new_badge = noone;
|
||||||
|
node_junction_inspector = noone;
|
||||||
|
icon_array_processor = noone;
|
||||||
|
icon_preview_export = noone;
|
||||||
|
play_all = noone;
|
||||||
|
timeline_folder = noone;
|
||||||
|
bone_tool_remove = noone;
|
||||||
|
cursor_path_anchor = noone;
|
||||||
|
workshop_project = noone;
|
||||||
|
explorer = noone;
|
||||||
|
inspector_text_valign = noone;
|
||||||
|
timeline_dopesheet_bg = noone;
|
||||||
|
node_dropper = noone;
|
||||||
|
icon_grid = noone;
|
||||||
|
node_note_title = noone;
|
||||||
|
widget_selecting = noone;
|
||||||
|
hamburger = noone;
|
||||||
|
menu_bg = noone;
|
||||||
|
code_show_auto = noone;
|
||||||
|
canvas_tools_rect = noone;
|
||||||
|
hamburger_s = noone;
|
||||||
|
path_tools_circle = noone;
|
||||||
|
node_bg_name = noone;
|
||||||
|
workshop_upload = noone;
|
||||||
|
node_websocket_send = noone;
|
||||||
|
heart = noone;
|
||||||
|
textbox_number_slider = noone;
|
||||||
|
node_resize = noone;
|
||||||
|
preview_light = noone;
|
||||||
|
button_color_overlay = noone;
|
||||||
|
button_path_not_found_icon = noone;
|
||||||
|
anchor_scale = noone;
|
||||||
|
button_right = noone;
|
||||||
|
timeline_keyframe_selecting = noone;
|
||||||
|
crop_tool = noone;
|
||||||
|
view_mode = noone;
|
||||||
|
strand_push = noone;
|
||||||
|
icon_delete = noone;
|
||||||
|
control_add = noone;
|
||||||
|
slider = noone;
|
||||||
|
bone_tool_move = noone;
|
||||||
|
node_frame_bg = noone;
|
||||||
|
paste = noone;
|
||||||
|
icon_toggle = noone;
|
||||||
|
text_bullet = noone;
|
||||||
|
ui_panel_active = noone;
|
||||||
|
visible = noone;
|
||||||
|
progress_bar = noone;
|
||||||
|
loading = noone;
|
||||||
|
fill = noone;
|
||||||
|
preview_crosshair = noone;
|
||||||
|
inspector_view = noone;
|
||||||
|
node_draw_area = noone;
|
||||||
|
window_fullscreen = noone;
|
||||||
|
icon_center_canvas = noone;
|
||||||
|
value_link = noone;
|
||||||
|
checkbox = noone;
|
||||||
|
bone_tool_add = noone;
|
||||||
|
workshop_update = noone;
|
||||||
|
tools_3d_transform = noone;
|
||||||
|
ui_label_bg = noone;
|
||||||
|
noti_icon_tick = noone;
|
||||||
|
inspector_padding = noone;
|
||||||
|
node_name_type = noone;
|
||||||
|
noti_icon_file_load = noone;
|
||||||
|
add_20 = noone;
|
||||||
|
icon_reset_when_preview = noone;
|
||||||
|
folder_16 = noone;
|
||||||
|
node_junctions_outline_hover = noone;
|
||||||
|
graph = noone;
|
||||||
|
inspector_corner = noone;
|
||||||
|
node_slider = noone;
|
||||||
|
new_line_shift = noone;
|
||||||
|
canvas_tools_ellip = noone;
|
||||||
|
cache = noone;
|
||||||
|
mesh_tool_delete = noone;
|
||||||
|
strandSim = noone;
|
||||||
|
save = noone;
|
||||||
|
node_rotator_bg = noone;
|
||||||
|
keyframe_override = noone;
|
||||||
|
arrow_back_32 = noone;
|
||||||
|
path_tools_anchor = noone;
|
||||||
|
itch = noone;
|
||||||
|
prop_keyframe = noone;
|
||||||
|
shadow_drop_down_24 = noone;
|
||||||
|
unit_angle = noone;
|
||||||
|
node_coor_pin = noone;
|
||||||
|
ac_function = noone;
|
||||||
|
obj_distribute_h = noone;
|
||||||
|
node_junctions_single = noone;
|
||||||
|
node_note_bg = noone;
|
||||||
|
anchor = noone;
|
||||||
|
node_create = noone;
|
||||||
|
sort = noone;
|
||||||
|
arrow = noone;
|
||||||
|
unit_audio = noone;
|
||||||
|
inspector_surface_halign = noone;
|
||||||
|
button_lime = noone;
|
||||||
|
anchor_solid_hori = noone;
|
||||||
|
preset = noone;
|
||||||
|
icon_32 = noone;
|
||||||
|
window_minimize = noone;
|
||||||
|
d3d_preview_settings = noone;
|
||||||
|
unit_ref = noone;
|
||||||
|
refresh = noone;
|
||||||
|
canvas_tools_selection_circle = noone;
|
||||||
|
path_tools_transform = noone;
|
||||||
|
timeline_keyframe = noone;
|
||||||
|
tools_3d_scale = noone;
|
||||||
|
key_display = noone;
|
||||||
|
display_palette = noone;
|
||||||
|
obj_hemicircle = noone;
|
||||||
|
inspector_area = noone;
|
||||||
|
button_hide_left = noone;
|
||||||
|
noti_icon_error = noone;
|
||||||
|
noti_icon_console_failed = noone;
|
||||||
|
ui_panel_bg_cover = noone;
|
||||||
|
icon_tile_view = noone;
|
||||||
|
node_junctions_bg = noone;
|
||||||
|
color_picker_dropper = noone;
|
||||||
|
folder_add = noone;
|
||||||
|
tool_side = noone;
|
||||||
|
strand_cut = noone;
|
||||||
|
canvas_tools_bucket = noone;
|
||||||
|
project = noone;
|
||||||
|
control_unpin = noone;
|
||||||
|
rotator_bg = noone;
|
||||||
|
node_bg_pill = noone;
|
||||||
|
smoke_sim = noone;
|
||||||
|
node_processor = noone;
|
||||||
|
object_halign = noone;
|
||||||
|
trophy = noone;
|
||||||
|
youtube = noone;
|
||||||
|
dialog_active = noone;
|
||||||
|
circle = noone;
|
||||||
|
bone = noone;
|
||||||
|
timeline_elastic = noone;
|
||||||
|
button_hide_fill = noone;
|
||||||
|
folder_content = noone;
|
||||||
|
node_deprecated_badge = noone;
|
||||||
|
node_junctions_array = noone;
|
||||||
|
node_note_resize = noone;
|
||||||
|
minus = noone;
|
||||||
|
node_move = noone;
|
||||||
|
workshop_collection = noone;
|
||||||
|
reverse = noone;
|
||||||
|
animate_node_go = noone;
|
||||||
|
menu_button_mask = noone;
|
||||||
|
obj_draw_line = noone;
|
||||||
|
bone_tool_transform = noone;
|
||||||
|
cursor_path_move = noone;
|
||||||
|
prop_gradient = noone;
|
||||||
|
add_16 = noone;
|
||||||
|
save_auto = noone;
|
||||||
|
d3d_snap_settings = noone;
|
||||||
|
scroll_box_arrow = noone;
|
||||||
|
rotator_random_mode = noone;
|
||||||
|
workshop_download = noone;
|
||||||
|
group = noone;
|
||||||
|
anchor_selector = noone;
|
||||||
|
node_active = noone;
|
||||||
|
code_syntax_highlight = noone;
|
||||||
|
inspector_channel = noone;
|
||||||
|
canvas_tools_eraser = noone;
|
||||||
|
node_state = noone;
|
||||||
|
path_tools_rectangle = noone;
|
||||||
|
rotator_knob = noone;
|
||||||
|
steam = noone;
|
||||||
|
menu_separator = noone;
|
||||||
|
timeline_color = noone;
|
||||||
|
websocket = noone;
|
||||||
|
button_hide_right = noone;
|
||||||
|
node_output_visible = noone;
|
||||||
|
reset_16 = noone;
|
||||||
|
icon_grid_setting = noone;
|
||||||
|
filter_type = noone;
|
||||||
|
button_middle = noone;
|
||||||
|
strand_comb = noone;
|
||||||
}
|
}
|
||||||
|
|
||||||
function ThemeColor() constructor {
|
function ThemeColor() constructor {
|
||||||
|
|
|
@ -3,8 +3,8 @@
|
||||||
"resourceVersion": "1.0",
|
"resourceVersion": "1.0",
|
||||||
"name": "sh_find_boundary",
|
"name": "sh_find_boundary",
|
||||||
"parent": {
|
"parent": {
|
||||||
"name": "misc",
|
"name": "find boundary",
|
||||||
"path": "folders/shader/misc.yy",
|
"path": "folders/shader/misc/find boundary.yy",
|
||||||
},
|
},
|
||||||
"type": 1,
|
"type": 1,
|
||||||
}
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
//
|
||||||
|
// Simple passthrough fragment shader
|
||||||
|
//
|
||||||
|
varying vec2 v_vTexcoord;
|
||||||
|
varying vec4 v_vColour;
|
||||||
|
|
||||||
|
uniform vec2 dimension;
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
vec4 col = texture2D( gm_BaseTexture, v_vTexcoord );
|
||||||
|
if(col.a > 0.) { gl_FragColor = vec4(1.); return; }
|
||||||
|
|
||||||
|
gl_FragColor = vec4(0.);
|
||||||
|
vec2 tx = 1. / dimension;
|
||||||
|
|
||||||
|
for(float i = 0.; i < dimension.y; i++) {
|
||||||
|
vec4 col = texture2D( gm_BaseTexture, vec2(v_vTexcoord.x, tx.y * i) );
|
||||||
|
if(col.a > 0.) {
|
||||||
|
gl_FragColor = vec4(1.);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,19 @@
|
||||||
|
//
|
||||||
|
// Simple passthrough vertex shader
|
||||||
|
//
|
||||||
|
attribute vec3 in_Position; // (x,y,z)
|
||||||
|
//attribute vec3 in_Normal; // (x,y,z) unused in this shader.
|
||||||
|
attribute vec4 in_Colour; // (r,g,b,a)
|
||||||
|
attribute vec2 in_TextureCoord; // (u,v)
|
||||||
|
|
||||||
|
varying vec2 v_vTexcoord;
|
||||||
|
varying vec4 v_vColour;
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
vec4 object_space_pos = vec4( in_Position.x, in_Position.y, in_Position.z, 1.0);
|
||||||
|
gl_Position = gm_Matrices[MATRIX_WORLD_VIEW_PROJECTION] * object_space_pos;
|
||||||
|
|
||||||
|
v_vColour = in_Colour;
|
||||||
|
v_vTexcoord = in_TextureCoord;
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
"resourceType": "GMShader",
|
||||||
|
"resourceVersion": "1.0",
|
||||||
|
"name": "sh_find_boundary_stretch_x",
|
||||||
|
"parent": {
|
||||||
|
"name": "find boundary",
|
||||||
|
"path": "folders/shader/misc/find boundary.yy",
|
||||||
|
},
|
||||||
|
"type": 1,
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
//
|
||||||
|
// Simple passthrough fragment shader
|
||||||
|
//
|
||||||
|
varying vec2 v_vTexcoord;
|
||||||
|
varying vec4 v_vColour;
|
||||||
|
|
||||||
|
uniform vec2 dimension;
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
vec4 col = texture2D( gm_BaseTexture, v_vTexcoord );
|
||||||
|
if(col.a > 0.) { gl_FragColor = vec4(1.); return; }
|
||||||
|
|
||||||
|
gl_FragColor = vec4(0.);
|
||||||
|
vec2 tx = 1. / dimension;
|
||||||
|
|
||||||
|
for(float i = 0.; i < dimension.x; i++) {
|
||||||
|
vec4 col = texture2D( gm_BaseTexture, vec2(tx.x * i, v_vTexcoord.y) );
|
||||||
|
if(col.a > 0.) {
|
||||||
|
gl_FragColor = vec4(1.);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,19 @@
|
||||||
|
//
|
||||||
|
// Simple passthrough vertex shader
|
||||||
|
//
|
||||||
|
attribute vec3 in_Position; // (x,y,z)
|
||||||
|
//attribute vec3 in_Normal; // (x,y,z) unused in this shader.
|
||||||
|
attribute vec4 in_Colour; // (r,g,b,a)
|
||||||
|
attribute vec2 in_TextureCoord; // (u,v)
|
||||||
|
|
||||||
|
varying vec2 v_vTexcoord;
|
||||||
|
varying vec4 v_vColour;
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
vec4 object_space_pos = vec4( in_Position.x, in_Position.y, in_Position.z, 1.0);
|
||||||
|
gl_Position = gm_Matrices[MATRIX_WORLD_VIEW_PROJECTION] * object_space_pos;
|
||||||
|
|
||||||
|
v_vColour = in_Colour;
|
||||||
|
v_vTexcoord = in_TextureCoord;
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
"resourceType": "GMShader",
|
||||||
|
"resourceVersion": "1.0",
|
||||||
|
"name": "sh_find_boundary_stretch_y",
|
||||||
|
"parent": {
|
||||||
|
"name": "find boundary",
|
||||||
|
"path": "folders/shader/misc/find boundary.yy",
|
||||||
|
},
|
||||||
|
"type": 1,
|
||||||
|
}
|
Loading…
Reference in a new issue