Transform, composite optimization

This commit is contained in:
MakhamDev 2023-10-03 16:27:36 +07:00
parent 864e79d8a4
commit d32fc6130a
23 changed files with 171 additions and 158 deletions

View file

@ -7,7 +7,6 @@
{"name":"Math","order":1,"path":"folders/_extensions/BBMOD/Math.yy",}, {"name":"Math","order":1,"path":"folders/_extensions/BBMOD/Math.yy",},
{"name":"GMD3D11","order":11,"path":"folders/_extensions/GMD3D11.yy",}, {"name":"GMD3D11","order":11,"path":"folders/_extensions/GMD3D11.yy",},
{"name":"MAC","order":6,"path":"folders/_extensions/MAC.yy",}, {"name":"MAC","order":6,"path":"folders/_extensions/MAC.yy",},
{"name":"Shader replace","order":12,"path":"folders/_extensions/Shader replace.yy",},
{"name":"addons","order":10,"path":"folders/addons.yy",}, {"name":"addons","order":10,"path":"folders/addons.yy",},
{"name":"custom","order":4,"path":"folders/addons/custom.yy",}, {"name":"custom","order":4,"path":"folders/addons/custom.yy",},
{"name":"key displayer","order":2,"path":"folders/addons/key displayer.yy",}, {"name":"key displayer","order":2,"path":"folders/addons/key displayer.yy",},
@ -129,6 +128,7 @@
{"name":"value","order":4,"path":"folders/nodes/data/value.yy",}, {"name":"value","order":4,"path":"folders/nodes/data/value.yy",},
{"name":"array","order":1,"path":"folders/nodes/data/value/array.yy",}, {"name":"array","order":1,"path":"folders/nodes/data/value/array.yy",},
{"name":"atlas","order":10,"path":"folders/nodes/data/value/atlas.yy",}, {"name":"atlas","order":10,"path":"folders/nodes/data/value/atlas.yy",},
{"name":"audio","order":13,"path":"folders/nodes/data/value/audio.yy",},
{"name":"bool","order":2,"path":"folders/nodes/data/value/bool.yy",}, {"name":"bool","order":2,"path":"folders/nodes/data/value/bool.yy",},
{"name":"buffer","order":12,"path":"folders/nodes/data/value/buffer.yy",}, {"name":"buffer","order":12,"path":"folders/nodes/data/value/buffer.yy",},
{"name":"color","order":3,"path":"folders/nodes/data/value/color.yy",}, {"name":"color","order":3,"path":"folders/nodes/data/value/color.yy",},
@ -215,7 +215,6 @@
{"name":"biterator","order":2,"path":"folders/VCT/biterator.yy",}, {"name":"biterator","order":2,"path":"folders/VCT/biterator.yy",},
{"name":"widget","order":3,"path":"folders/VCT/widget.yy",}, {"name":"widget","order":3,"path":"folders/VCT/widget.yy",},
{"name":"widgets","order":5,"path":"folders/widgets.yy",}, {"name":"widgets","order":5,"path":"folders/widgets.yy",},
{"name":"audio","order":13,"path":"folders/nodes/data/value/audio.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",},
@ -433,7 +432,6 @@
{"name":"fd_rectangle_update_view","order":5,"path":"scripts/fd_rectangle_update_view/fd_rectangle_update_view.yy",}, {"name":"fd_rectangle_update_view","order":5,"path":"scripts/fd_rectangle_update_view/fd_rectangle_update_view.yy",},
{"name":"s_node_rigidSim_renderer","order":1,"path":"sprites/s_node_rigidSim_renderer/s_node_rigidSim_renderer.yy",}, {"name":"s_node_rigidSim_renderer","order":1,"path":"sprites/s_node_rigidSim_renderer/s_node_rigidSim_renderer.yy",},
{"name":"__init_background","order":4,"path":"scripts/__init_background/__init_background.yy",}, {"name":"__init_background","order":4,"path":"scripts/__init_background/__init_background.yy",},
{"name":"shader_replace_simple_macros","order":2,"path":"scripts/shader_replace_simple_macros/shader_replace_simple_macros.yy",},
{"name":"s_textbox","order":1,"path":"sprites/s_textbox/s_textbox.yy",}, {"name":"s_textbox","order":1,"path":"sprites/s_textbox/s_textbox.yy",},
{"name":"__node","order":8,"path":"scripts/__node/__node.yy",}, {"name":"__node","order":8,"path":"scripts/__node/__node.yy",},
{"name":"fd_rectangle_add_velocity","order":5,"path":"scripts/fd_rectangle_add_velocity/fd_rectangle_add_velocity.yy",}, {"name":"fd_rectangle_add_velocity","order":5,"path":"scripts/fd_rectangle_add_velocity/fd_rectangle_add_velocity.yy",},
@ -955,7 +953,6 @@
{"name":"s_node_noise_fbm","order":26,"path":"sprites/s_node_noise_fbm/s_node_noise_fbm.yy",}, {"name":"s_node_noise_fbm","order":26,"path":"sprites/s_node_noise_fbm/s_node_noise_fbm.yy",},
{"name":"sh_color_select_content","order":1,"path":"shaders/sh_color_select_content/sh_color_select_content.yy",}, {"name":"sh_color_select_content","order":1,"path":"shaders/sh_color_select_content/sh_color_select_content.yy",},
{"name":"s_node_hlsl","order":32,"path":"sprites/s_node_hlsl/s_node_hlsl.yy",}, {"name":"s_node_hlsl","order":32,"path":"sprites/s_node_hlsl/s_node_hlsl.yy",},
{"name":"scr_cmd_arg","order":3,"path":"scripts/scr_cmd_arg/scr_cmd_arg.yy",},
{"name":"sh_outline","order":18,"path":"shaders/sh_outline/sh_outline.yy",}, {"name":"sh_outline","order":18,"path":"shaders/sh_outline/sh_outline.yy",},
{"name":"s_node_strandSim_break","order":8,"path":"sprites/s_node_strandSim_break/s_node_strandSim_break.yy",}, {"name":"s_node_strandSim_break","order":8,"path":"sprites/s_node_strandSim_break/s_node_strandSim_break.yy",},
{"name":"s_node_scatter_point","order":4,"path":"sprites/s_node_scatter_point/s_node_scatter_point.yy",}, {"name":"s_node_scatter_point","order":4,"path":"sprites/s_node_scatter_point/s_node_scatter_point.yy",},
@ -1532,7 +1529,6 @@
{"name":"sprite_loader","order":11,"path":"scripts/sprite_loader/sprite_loader.yy",}, {"name":"sprite_loader","order":11,"path":"scripts/sprite_loader/sprite_loader.yy",},
{"name":"fd_rectangle_get_material_surface","order":12,"path":"scripts/fd_rectangle_get_material_surface/fd_rectangle_get_material_surface.yy",}, {"name":"fd_rectangle_get_material_surface","order":12,"path":"scripts/fd_rectangle_get_material_surface/fd_rectangle_get_material_surface.yy",},
{"name":"fd_rectangle_clear","order":6,"path":"scripts/fd_rectangle_clear/fd_rectangle_clear.yy",}, {"name":"fd_rectangle_clear","order":6,"path":"scripts/fd_rectangle_clear/fd_rectangle_clear.yy",},
{"name":"shader_replace_simple","order":1,"path":"extensions/shader_replace_simple/shader_replace_simple.yy",},
{"name":"d3d_cone","order":5,"path":"scripts/d3d_cone/d3d_cone.yy",}, {"name":"d3d_cone","order":5,"path":"scripts/d3d_cone/d3d_cone.yy",},
{"name":"__rectangle","order":7,"path":"scripts/__rectangle/__rectangle.yy",}, {"name":"__rectangle","order":7,"path":"scripts/__rectangle/__rectangle.yy",},
{"name":"node_PCX_fn_random","order":1,"path":"scripts/node_PCX_fn_random/node_PCX_fn_random.yy",}, {"name":"node_PCX_fn_random","order":1,"path":"scripts/node_PCX_fn_random/node_PCX_fn_random.yy",},

View file

@ -28,7 +28,6 @@
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"Gameframe","folderPath":"folders/_extensions/Gameframe.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"Gameframe","folderPath":"folders/_extensions/Gameframe.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"GMD3D11","folderPath":"folders/_extensions/GMD3D11.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"GMD3D11","folderPath":"folders/_extensions/GMD3D11.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"MAC","folderPath":"folders/_extensions/MAC.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"MAC","folderPath":"folders/_extensions/MAC.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"Shader replace","folderPath":"folders/_extensions/Shader replace.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"addons","folderPath":"folders/addons.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"addons","folderPath":"folders/addons.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"custom","folderPath":"folders/addons/custom.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"custom","folderPath":"folders/addons/custom.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"key displayer","folderPath":"folders/addons/key displayer.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"key displayer","folderPath":"folders/addons/key displayer.yy",},
@ -157,6 +156,7 @@
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"value","folderPath":"folders/nodes/data/value.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"value","folderPath":"folders/nodes/data/value.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"array","folderPath":"folders/nodes/data/value/array.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"array","folderPath":"folders/nodes/data/value/array.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"atlas","folderPath":"folders/nodes/data/value/atlas.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"atlas","folderPath":"folders/nodes/data/value/atlas.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"audio","folderPath":"folders/nodes/data/value/audio.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"bool","folderPath":"folders/nodes/data/value/bool.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"bool","folderPath":"folders/nodes/data/value/bool.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"buffer","folderPath":"folders/nodes/data/value/buffer.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"buffer","folderPath":"folders/nodes/data/value/buffer.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"color","folderPath":"folders/nodes/data/value/color.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"color","folderPath":"folders/nodes/data/value/color.yy",},
@ -248,7 +248,6 @@
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"biterator","folderPath":"folders/VCT/biterator.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"biterator","folderPath":"folders/VCT/biterator.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"widget","folderPath":"folders/VCT/widget.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"widget","folderPath":"folders/VCT/widget.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"widgets","folderPath":"folders/widgets.yy",}, {"resourceType":"GMFolder","resourceVersion":"1.0","name":"widgets","folderPath":"folders/widgets.yy",},
{"resourceType":"GMFolder","resourceVersion":"1.0","name":"audio","folderPath":"folders/nodes/data/value/audio.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",},
@ -987,7 +986,6 @@
{"id":{"name":"fd_rectangle_update_view","path":"scripts/fd_rectangle_update_view/fd_rectangle_update_view.yy",},}, {"id":{"name":"fd_rectangle_update_view","path":"scripts/fd_rectangle_update_view/fd_rectangle_update_view.yy",},},
{"id":{"name":"s_node_rigidSim_renderer","path":"sprites/s_node_rigidSim_renderer/s_node_rigidSim_renderer.yy",},}, {"id":{"name":"s_node_rigidSim_renderer","path":"sprites/s_node_rigidSim_renderer/s_node_rigidSim_renderer.yy",},},
{"id":{"name":"__init_background","path":"scripts/__init_background/__init_background.yy",},}, {"id":{"name":"__init_background","path":"scripts/__init_background/__init_background.yy",},},
{"id":{"name":"shader_replace_simple_macros","path":"scripts/shader_replace_simple_macros/shader_replace_simple_macros.yy",},},
{"id":{"name":"s_textbox","path":"sprites/s_textbox/s_textbox.yy",},}, {"id":{"name":"s_textbox","path":"sprites/s_textbox/s_textbox.yy",},},
{"id":{"name":"__node","path":"scripts/__node/__node.yy",},}, {"id":{"name":"__node","path":"scripts/__node/__node.yy",},},
{"id":{"name":"fd_rectangle_add_velocity","path":"scripts/fd_rectangle_add_velocity/fd_rectangle_add_velocity.yy",},}, {"id":{"name":"fd_rectangle_add_velocity","path":"scripts/fd_rectangle_add_velocity/fd_rectangle_add_velocity.yy",},},
@ -1585,7 +1583,6 @@
{"id":{"name":"s_node_noise_fbm","path":"sprites/s_node_noise_fbm/s_node_noise_fbm.yy",},}, {"id":{"name":"s_node_noise_fbm","path":"sprites/s_node_noise_fbm/s_node_noise_fbm.yy",},},
{"id":{"name":"sh_color_select_content","path":"shaders/sh_color_select_content/sh_color_select_content.yy",},}, {"id":{"name":"sh_color_select_content","path":"shaders/sh_color_select_content/sh_color_select_content.yy",},},
{"id":{"name":"s_node_hlsl","path":"sprites/s_node_hlsl/s_node_hlsl.yy",},}, {"id":{"name":"s_node_hlsl","path":"sprites/s_node_hlsl/s_node_hlsl.yy",},},
{"id":{"name":"scr_cmd_arg","path":"scripts/scr_cmd_arg/scr_cmd_arg.yy",},},
{"id":{"name":"sh_outline","path":"shaders/sh_outline/sh_outline.yy",},}, {"id":{"name":"sh_outline","path":"shaders/sh_outline/sh_outline.yy",},},
{"id":{"name":"s_node_strandSim_break","path":"sprites/s_node_strandSim_break/s_node_strandSim_break.yy",},}, {"id":{"name":"s_node_strandSim_break","path":"sprites/s_node_strandSim_break/s_node_strandSim_break.yy",},},
{"id":{"name":"s_node_scatter_point","path":"sprites/s_node_scatter_point/s_node_scatter_point.yy",},}, {"id":{"name":"s_node_scatter_point","path":"sprites/s_node_scatter_point/s_node_scatter_point.yy",},},
@ -1699,7 +1696,6 @@
{"id":{"name":"number_function","path":"scripts/number_function/number_function.yy",},}, {"id":{"name":"number_function","path":"scripts/number_function/number_function.yy",},},
{"id":{"name":"s_node_array_shift","path":"sprites/s_node_array_shift/s_node_array_shift.yy",},}, {"id":{"name":"s_node_array_shift","path":"sprites/s_node_array_shift/s_node_array_shift.yy",},},
{"id":{"name":"s_node_statistic","path":"sprites/s_node_statistic/s_node_statistic.yy",},}, {"id":{"name":"s_node_statistic","path":"sprites/s_node_statistic/s_node_statistic.yy",},},
{"id":{"name":"execute_program_pipe","path":"extensions/execute_program_pipe/execute_program_pipe.yy",},},
{"id":{"name":"s_node_cache_array","path":"sprites/s_node_cache_array/s_node_cache_array.yy",},}, {"id":{"name":"s_node_cache_array","path":"sprites/s_node_cache_array/s_node_cache_array.yy",},},
{"id":{"name":"sh_blend_alpha_addition","path":"shaders/sh_blend_alpha_addition/sh_blend_alpha_addition.yy",},}, {"id":{"name":"sh_blend_alpha_addition","path":"shaders/sh_blend_alpha_addition/sh_blend_alpha_addition.yy",},},
{"id":{"name":"widget","path":"scripts/widget/widget.yy",},}, {"id":{"name":"widget","path":"scripts/widget/widget.yy",},},
@ -2254,7 +2250,6 @@
{"id":{"name":"fd_rectangle_get_material_surface","path":"scripts/fd_rectangle_get_material_surface/fd_rectangle_get_material_surface.yy",},}, {"id":{"name":"fd_rectangle_get_material_surface","path":"scripts/fd_rectangle_get_material_surface/fd_rectangle_get_material_surface.yy",},},
{"id":{"name":"fd_rectangle_clear","path":"scripts/fd_rectangle_clear/fd_rectangle_clear.yy",},}, {"id":{"name":"fd_rectangle_clear","path":"scripts/fd_rectangle_clear/fd_rectangle_clear.yy",},},
{"id":{"name":"instance_create","path":"scripts/instance_create/instance_create.yy",},}, {"id":{"name":"instance_create","path":"scripts/instance_create/instance_create.yy",},},
{"id":{"name":"shader_replace_simple","path":"extensions/shader_replace_simple/shader_replace_simple.yy",},},
{"id":{"name":"d3d_cone","path":"scripts/d3d_cone/d3d_cone.yy",},}, {"id":{"name":"d3d_cone","path":"scripts/d3d_cone/d3d_cone.yy",},},
{"id":{"name":"__rectangle","path":"scripts/__rectangle/__rectangle.yy",},}, {"id":{"name":"__rectangle","path":"scripts/__rectangle/__rectangle.yy",},},
{"id":{"name":"node_PCX_fn_random","path":"scripts/node_PCX_fn_random/node_PCX_fn_random.yy",},}, {"id":{"name":"node_PCX_fn_random","path":"scripts/node_PCX_fn_random/node_PCX_fn_random.yy",},},

View file

@ -90,7 +90,7 @@ function buttonClass(_onClick, _icon = noone) : widget() constructor {
var aa = interactable * 0.25 + 0.75; var aa = interactable * 0.25 + 0.75;
if(icon) { if(icon) {
var ind = is_real(icon_index)? icon_index : icon_index(); var ind = is_array(icon_index)? icon_index[0]() : icon_index;
draw_sprite_ui_uniform(icon, ind, _x + _w / 2, _y + _h / 2,, icon_blend, aa); draw_sprite_ui_uniform(icon, ind, _x + _w / 2, _y + _h / 2,, icon_blend, aa);
} }

View file

@ -112,7 +112,7 @@ function buttonColor(_onApply, dialog = noone) : widget() constructor {
if(is_array(current_color)) if(is_array(current_color))
drawPalette(current_color, _x + ui(6), _y + ui(6), _cw - ui(12), _h - ui(12)); drawPalette(current_color, _x + ui(6), _y + ui(6), _cw - ui(12), _h - ui(12));
else else if(is_real(current_color))
draw_sprite_stretched_ext(THEME.button_color_overlay, 0, _x + ui(4), _y + ui(4), _cw - ui(8), _h - ui(8), current_color, 1); draw_sprite_stretched_ext(THEME.button_color_overlay, 0, _x + ui(4), _y + ui(4), _cw - ui(8), _h - ui(8), current_color, 1);
if(WIDGET_CURRENT == self) if(WIDGET_CURRENT == self)

View file

@ -45,14 +45,13 @@ function draw_surface_blend(background, foreground, blend = 0, alpha = 1, _pre_a
} }
function draw_surface_blend_ext(bg, fg, _x, _y, _sx = 1, _sy = 1, _rot = 0, _col = c_white, _alpha = 1, _blend = 0) { function draw_surface_blend_ext(bg, fg, _x, _y, _sx = 1, _sy = 1, _rot = 0, _col = c_white, _alpha = 1, _blend = 0) {
var _tmpS = surface_create_size(bg); static _tempS = surface_create(1, 1);
_tempS = surface_verify(_tempS, surface_get_width_safe(bg), surface_get_height_safe(bg));
surface_set_shader(_tmpS); surface_set_shader(_tempS);
shader_set_interpolation(fg); shader_set_interpolation(fg);
draw_surface_ext_safe(fg, _x, _y, _sx, _sy, _rot, _col, 1); draw_surface_ext_safe(fg, _x, _y, _sx, _sy, _rot, _col, 1);
surface_reset_shader(); surface_reset_shader();
draw_surface_blend(bg, _tmpS, _blend, _alpha, false); draw_surface_blend(bg, _tempS, _blend, _alpha, false);
surface_free(_tmpS);
} }

View file

@ -10,7 +10,7 @@ function gradientKey(time, value) constructor {
static clone = function() { return new gradientKey(time, value); } static clone = function() { return new gradientKey(time, value); }
static serialize = function() { return {time, value}; } static serialize = function() { return { time, value }; }
} }
function gradientObject(color = c_black) constructor { function gradientObject(color = c_black) constructor {
@ -175,7 +175,7 @@ function gradientObject(color = c_black) constructor {
} }
static serialize = function() { static serialize = function() {
var s = {type}; var s = { type: type };
s.keys = []; s.keys = [];
for( var i = 0, n = array_length(keys); i < n; i++ ) for( var i = 0, n = array_length(keys); i < n; i++ )
s.keys[i] = keys[i].serialize(); s.keys[i] = keys[i].serialize();
@ -198,10 +198,14 @@ function gradientObject(color = c_black) constructor {
return self; return self;
} }
type = s.type; type = struct_try_get(s, "type");
keys = []; keys = array_create(array_length(s.keys));
for( var i = 0, n = array_length(s.keys); i < n; i++ ) for( var i = 0, n = array_length(s.keys); i < n; i++ ) {
keys[i] = new gradientKey(s.keys[i].time, s.keys[i].value); var _time = real(s.keys[i].time);
var _value = real(s.keys[i].value);
keys[i] = new gradientKey(_time, _value);
}
return self; return self;
} }

View file

@ -62,6 +62,7 @@
function attribute_interpolation(label = false) { function attribute_interpolation(label = false) {
attributes.interpolation = 0; attributes.interpolation = 0;
attributes.oversample = 0;
if(label) array_push(attributeEditors, "Surface"); if(label) array_push(attributeEditors, "Surface");
array_push(attributeEditors, ["Texture interpolation", function() { return attributes.interpolation; }, array_push(attributeEditors, ["Texture interpolation", function() { return attributes.interpolation; },
@ -72,6 +73,7 @@
} }
function attribute_oversample(label = false) { function attribute_oversample(label = false) {
attributes.interpolation = 0;
attributes.oversample = 0; attributes.oversample = 0;
if(label) array_push(attributeEditors, "Surface"); if(label) array_push(attributeEditors, "Surface");

View file

@ -17,7 +17,7 @@ function Node_Audio_Window(_x, _y, _group = noone) : Node(_x, _y, _group) constr
inputs[| 2].display_data.side_button.tooltip.index = inputs[| 2].display_data.unit; inputs[| 2].display_data.side_button.tooltip.index = inputs[| 2].display_data.unit;
update(); update();
}).setTooltip( new tooltipSelector("Unit", [ "Bit", "Second", "Progress" ]) ) }).setTooltip( new tooltipSelector("Unit", [ "Bit", "Second", "Progress" ]) )
.setIcon( THEME.unit_audio, function() { return inputs[| 2].display_data.unit; }, COLORS._main_icon ) .setIcon( THEME.unit_audio, [ function() { return inputs[| 2].display_data.unit; } ], COLORS._main_icon )
} }
); );

View file

@ -458,7 +458,7 @@ function Node(_x, _y, _group = PANEL_GRAPH.getCurrentContext()) : __Node_Base(_x
cached_manual = false; cached_manual = false;
if(!use_cache && PROJECT.onion_skin) { if(!use_cache && PROJECT.onion_skin.enabled) {
for( var i = 0; i < ds_list_size(outputs); i++ ) { for( var i = 0; i < ds_list_size(outputs); i++ ) {
if(outputs[| i].type != VALUE_TYPE.surface) continue; if(outputs[| i].type != VALUE_TYPE.surface) continue;
cacheCurrentFrame(outputs[| i].getValue()); cacheCurrentFrame(outputs[| i].getValue());

View file

@ -39,16 +39,19 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
/*Boolean*/ [ "Default" ], /*Boolean*/ [ "Default" ],
/*Color*/ [ "Default", "Gradient", "Palette" ], /*Color*/ [ "Default", "Gradient", "Palette" ],
/*Surface*/ [ "Default", ], /*Surface*/ [ "Default", ],
/*Path*/ [ "Default", ], /*Path*/ [ "Default", ],
/*Curve*/ [ "Default", ], /*Curve*/ [ "Default", ],
/*Text*/ [ "Default", ], /*Text*/ [ "Default", ],
/*Object*/ [ "Default", ], /*Object*/ [ "Default", ],
/*Node*/ [ "Default", ], /*Node*/ [ "Default", ],
/*3D*/ [ "Default", ], /*3D*/ [ "Default", ],
/*Any*/ [ "Default", ], /*Any*/ [ "Default", ],
/*Pathnode*/[ "Default", ], /*Pathnode*/[ "Default", ],
/*Particle*/[ "Default", ], /*Particle*/[ "Default", ],
/*Rigid*/ [ "Default", ], /*Rigid*/ [ "Default", ],
/*Fdomain*/ [ "Default", ], /*Fdomain*/ [ "Default", ],
/*Struct*/ [ "Default", ], /*Struct*/ [ "Default", ],
/*Strand*/ [ "Default", ], /*Strand*/ [ "Default", ],
@ -143,10 +146,7 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
_to.removeFrom(); _to.removeFrom();
} }
inputs[| 0].display_data.data = array_safe_get(display_list, _val_type);
inputs[| 0].editWidget.data_list = array_safe_get(display_list, _val_type);
inputs[| 0].setValue(0); inputs[| 0].setValue(0);
_dtype = 0;
} }
_dtype = array_safe_get(array_safe_get(display_list, _val_type, []), _dtype); _dtype = array_safe_get(array_safe_get(display_list, _val_type, []), _dtype);
@ -276,6 +276,11 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
static step = function() { #region static step = function() { #region
if(is_undefined(inParent)) return; if(is_undefined(inParent)) return;
var _type = getInputData(2);
var _val_type = data_type_map[_type];
inputs[| 0].display_data.data = array_safe_get(display_list, _val_type);
inputs[| 0].editWidget.data_list = array_safe_get(display_list, _val_type);
if(inParent.name != display_name) { if(inParent.name != display_name) {
inParent.name = display_name; inParent.name = display_name;
group.inputMap[? string_replace_all(display_name, " ", "_")] = inParent; group.inputMap[? string_replace_all(display_name, " ", "_")] = inParent;
@ -301,12 +306,6 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
doTrigger = 0; doTrigger = 0;
} }
} }
} #endregion
PATCH_STATIC
static update = function(frame = PROJECT.animator.current_frame) { #region
if(is_undefined(inParent)) return;
var _dstype = getInputData(0); var _dstype = getInputData(0);
var _data = getInputData(2); var _data = getInputData(2);
@ -338,30 +337,21 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
} }
} #endregion } #endregion
static postDeserialize = function() { #region PATCH_STATIC
createInput(false);
var _inputs = load_map.inputs; static update = function(frame = PROJECT.animator.current_frame) { #region
inputs[| 5].applyDeserialize(_inputs[5], load_scale); if(is_undefined(inParent)) return;
if(PROJECT.version < 11520) attributes.input_priority = getInputData(5);
group.sortIO();
inputs[| 2].applyDeserialize(_inputs[2], load_scale);
onValueUpdate(2);
} #endregion } #endregion
static applyDeserialize = function() { #region static postDeserialize = function() { createInput(false); }
var _inputs = load_map.inputs;
var amo = min(array_length(_inputs), ds_list_size(inputs));
for(var i = 0; i < amo; i++) {
if(i == 2 || i == 5) continue;
inputs[| i].applyDeserialize(_inputs[i], load_scale);
}
static doApplyDeserialize = function() {
inParent.name = name; inParent.name = name;
onValueUpdate(0); getInputs();
} #endregion if(PROJECT.version < 11520) attributes.input_priority = getInputData(5);
onValueUpdate();
group.sortIO();
}
static onDestroy = function() { #region static onDestroy = function() { #region
if(is_undefined(inParent)) return; if(is_undefined(inParent)) return;

View file

@ -15,7 +15,7 @@ function Node_Pixel_Sort(_x, _y, _group = noone) : Node_Processor(_x, _y, _group
.setDisplay(VALUE_DISPLAY.slider); .setDisplay(VALUE_DISPLAY.slider);
inputs[| 3] = nodeValue("Direction", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0) inputs[| 3] = nodeValue("Direction", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
.setDisplay(VALUE_DISPLAY.rotation, 90); .setDisplay(VALUE_DISPLAY.rotation, { step: 90 });
inputs[| 4] = nodeValue("Mask", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0); inputs[| 4] = nodeValue("Mask", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, 0);

View file

@ -32,6 +32,9 @@ function Node_Processor(_x, _y, _group = noone) : Node(_x, _y, _group) construct
static getInputData = function(index, def = 0) { return array_safe_get(inputs_data, index, def); } static getInputData = function(index, def = 0) { return array_safe_get(inputs_data, index, def); }
static processData_prebatch = function() {}
static processData_postbatch = function() {}
static processData = function(_outSurf, _data, _output_index, _array_index = 0) { return _outSurf; } static processData = function(_outSurf, _data, _output_index, _array_index = 0) { return _outSurf; }
static getSingleValue = function(_index, _arr = 0, output = false) { #region static getSingleValue = function(_index, _arr = 0, output = false) { #region
@ -270,8 +273,10 @@ function Node_Processor(_x, _y, _group = noone) : Node(_x, _y, _group) construct
} #endregion } #endregion
static update = function(frame = PROJECT.animator.current_frame) { #region static update = function(frame = PROJECT.animator.current_frame) { #region
processData_prebatch();
if(batch_output) processBatchOutput(); if(batch_output) processBatchOutput();
else processOutput(); else processOutput();
processData_postbatch();
postUpdate(); postUpdate();
} #endregion } #endregion

View file

@ -20,11 +20,14 @@ function Node_Texture_Remap(_x, _y, _group = noone) : Node_Processor(_x, _y, _gr
attribute_surface_depth(); attribute_surface_depth();
attribute_interpolation(); attribute_interpolation();
static processData_prebatch = function() { shader_preset_interpolation(shader); }
static processData_postbatch = function() { shader_postset_interpolation(); }
static processData = function(_outSurf, _data, _output_index, _array_index) { #region static processData = function(_outSurf, _data, _output_index, _array_index) { #region
if(!is_surface(_data[1])) return _outSurf; if(!is_surface(_data[1])) return _outSurf;
surface_set_shader(_outSurf, shader); surface_set_shader(_outSurf, shader);
shader_set_interpolation(_data[0]); shader_set_interpolation_surface(_data[0]);
texture_set_stage(uniform_map, surface_get_texture(_data[1])); texture_set_stage(uniform_map, surface_get_texture(_data[1]));
draw_surface_safe(_data[0], 0, 0); draw_surface_safe(_data[0], 0, 0);
surface_reset_shader(); surface_reset_shader();

View file

@ -122,16 +122,19 @@ function Node_Transform(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
} }
} #endregion } #endregion
static processData_prebatch = function() { shader_preset_interpolation(); }
static processData_postbatch = function() { shader_postset_interpolation(); }
static processData = function(_outSurf, _data, _output_index, _array_index) { #region static processData = function(_outSurf, _data, _output_index, _array_index) { #region
var ins = _data[0]; var ins = _data[0];
var out_type = _data[9]; var out_type = _data[9];
var out = _data[1]; var out = _data[1];
var pos = array_clone(_data[2]); var pos = [ _data[2][0], _data[2][1] ];
var pos_exact = _data[10]; var pos_exact = _data[10];
var anc = array_clone(_data[3]); var anc = [ _data[3][0], _data[3][1] ];
var rot_vel = vel * _data[8]; var rot_vel = vel * _data[8];
var rot = _data[5] + rot_vel; var rot = _data[5] + rot_vel;
@ -205,7 +208,7 @@ function Node_Transform(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _cc = point_rotate(-_px, -_py, _ww / 2, _hh / 2, rot); var _cc = point_rotate(-_px, -_py, _ww / 2, _hh / 2, rot);
surface_set_shader(_outSurf); surface_set_shader(_outSurf);
shader_set_interpolation(_s); shader_set_interpolation_surface(_s);
draw_surface_ext_safe(_s, _cc[0], _cc[1], 1, 1, rot, c_white, 1); draw_surface_ext_safe(_s, _cc[0], _cc[1], 1, 1, rot, c_white, 1);
surface_reset_shader(); surface_reset_shader();
@ -221,7 +224,7 @@ function Node_Transform(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
} }
surface_set_shader(_outSurf); surface_set_shader(_outSurf);
shader_set_interpolation(ins); shader_set_interpolation_surface(ins);
draw_surface_ext_safe(ins, draw_x, draw_y, sca[0], sca[1], rot, c_white, 1); draw_surface_ext_safe(ins, draw_x, draw_y, sca[0], sca[1], rot, c_white, 1);
if(mode == 2) { if(mode == 2) {
@ -268,11 +271,13 @@ function Node_Transform(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
_surf_out = _surf_out[preview_index]; _surf_out = _surf_out[preview_index];
} }
var pos = array_clone(getInputData(2)); var __pos = getInputData(2)
var _pos = [ pos[0], pos[1] ]; var pos = [ __pos[0], __pos[1] ];
var _pos = [ __pos[0], __pos[1] ];
var anc = array_clone(getInputData(3)); var __anc = getInputData(3);
var _anc = [ anc[0], anc[1] ]; var anc = [ __anc[0], __anc[1] ];
var _anc = [ __anc[0], __anc[1] ];
var rot = getInputData(5); var rot = getInputData(5);
var sca = getInputData(6); var sca = getInputData(6);

View file

@ -812,9 +812,11 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
break; #endregion break; #endregion
case VALUE_DISPLAY.rotation : #region case VALUE_DISPLAY.rotation : #region
var _step = struct_try_get(display_data, "step", -1);
editWidget = new rotator(function(val) { editWidget = new rotator(function(val) {
return setValueDirect(val); return setValueDirect(val);
}, display_data ); }, _step );
extract_node = "Node_Number"; extract_node = "Node_Number";
break; #endregion break; #endregion
@ -1183,8 +1185,9 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
#region color compatibility [ color, palette, gradient ] #region color compatibility [ color, palette, gradient ]
if(type == VALUE_TYPE.gradient && typeFrom == VALUE_TYPE.color) { if(type == VALUE_TYPE.gradient && typeFrom == VALUE_TYPE.color) {
if(is_struct(value) && instanceof(value) == "gradientObject") if(is_instanceof(value, gradientObject))
return value; return value;
if(is_array(value)) { if(is_array(value)) {
var amo = array_length(value); var amo = array_length(value);
var grad = array_create(amo); var grad = array_create(amo);
@ -1195,8 +1198,8 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
return g; return g;
} }
var grad = new gradientObject(value); if(is_real(value)) return new gradientObject(value);
return grad; return new gradientObject(0);
} }
if(display_type == VALUE_DISPLAY.palette && !is_array(value)) { if(display_type == VALUE_DISPLAY.palette && !is_array(value)) {
@ -1470,8 +1473,15 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
} #endregion } #endregion
static isAnimated = function() { #region static isAnimated = function() { #region
gml_pragma("forceinline");
if(value_from == noone) return __anim(); if(value_from == noone) return __anim();
else return value_from.isAnimated() || value_from.__anim() || value_from.node.anim_last_step;
var from_anim = value_from.isAnimated();
var from_self_anim = value_from.__anim();
var from_node_anim = value_from.node.anim_last_step;
return from_anim || from_self_anim || from_node_anim;
} #endregion } #endregion
static showValue = function() { #region static showValue = function() { #region

View file

@ -106,11 +106,11 @@ function Render(partial = false, runAction = false) { #region
if(!_node.active) continue; if(!_node.active) continue;
if(!_node.isRenderActive()) continue; if(!_node.isRenderActive()) continue;
if(_node.rendered && !_node.isAnimated()) { if(_node.rendered && !_node.isAnimated()) {
_node.anim_last_step = false;
LOG_IF(global.FLAG.render, $"Skip rendered {_node.internalName}"); LOG_IF(global.FLAG.render, $"Skip rendered {_node.internalName}");
continue; continue;
} }
//if(__nodeInLoop(_node)) continue;
if(_node.group != noone) continue; if(_node.group != noone) continue;
LOG_BLOCK_START(); LOG_BLOCK_START();

View file

@ -1,7 +0,0 @@
/// @param string
function scr_cmd_arg(argument0) {
var s = argument0;
if (string_pos(" ", s)) {
return @'"' + s + @'"';
} else return s;
}

View file

@ -1,11 +0,0 @@
{
"resourceType": "GMScript",
"resourceVersion": "1.0",
"name": "scr_cmd_arg",
"isCompatibility": false,
"isDnD": false,
"parent": {
"name": "Shader replace",
"path": "folders/_extensions/Shader replace.yy",
},
}

View file

@ -1,4 +1,6 @@
function shader_set_i(uniform, value) { function shader_set_i(uniform, value) {
gml_pragma("forceinline");
var shader = shader_current(); var shader = shader_current();
if(shader == -1) return; if(shader == -1) return;
@ -7,22 +9,27 @@ function shader_set_i(uniform, value) {
return; return;
} }
if(argument_count > 2) { switch(argument_count) {
var array = []; case 2 : shader_set_uniform_i(shader_get_uniform(shader, uniform), value); break;
case 3 : shader_set_uniform_i(shader_get_uniform(shader, uniform), value, argument[2]); break;
case 4 : shader_set_uniform_i(shader_get_uniform(shader, uniform), value, argument[2], argument[3]); break;
default:
var array = array_create(argument_count - 1);
for( var i = 1; i < argument_count; i++ ) for( var i = 1; i < argument_count; i++ )
array_push(array, argument[i]); array[i - 1] = argument[i];
shader_set_i_array(shader, uniform, array) shader_set_i_array(shader, uniform, array)
return;
} }
shader_set_uniform_i(shader_get_uniform(shader, uniform), value);
} }
function shader_set_i_array(shader, uniform, array) { function shader_set_i_array(shader, uniform, array) {
gml_pragma("forceinline");
shader_set_uniform_i_array(shader_get_uniform(shader, uniform), array); shader_set_uniform_i_array(shader_get_uniform(shader, uniform), array);
} }
function shader_set_f(uniform, value) { function shader_set_f(uniform, value) {
gml_pragma("forceinline");
var shader = shader_current(); var shader = shader_current();
if(shader == -1) return; if(shader == -1) return;
@ -31,27 +38,48 @@ function shader_set_f(uniform, value) {
return; return;
} }
if(argument_count > 2) { switch(argument_count) {
var array = []; case 2 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value); break;
case 3 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2]); break;
case 4 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2], argument[3]); break;
case 5 : shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2], argument[3], argument[4]); break;
default:
var array = array_create(argument_count - 1);
for( var i = 1; i < argument_count; i++ ) for( var i = 1; i < argument_count; i++ )
array_push(array, argument[i]); array[i - 1] = argument[i];
shader_set_uniform_f_array_safe(shader_get_uniform(shader, uniform), array) shader_set_uniform_f_array(shader_get_uniform(shader, uniform), array)
return;
} }
if(argument_count == 2)
shader_set_uniform_f(shader_get_uniform(shader, uniform), value); shader_set_uniform_f(shader_get_uniform(shader, uniform), value);
else if(argument_count == 3)
shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2]);
else if(argument_count == 4)
shader_set_uniform_f(shader_get_uniform(shader, uniform), value, argument[2], argument[3]);
else {
var array = array_create(argument_count - 1);
for( var i = 1; i < argument_count; i++ )
array[i - 1] = argument[i];
shader_set_uniform_f_array(shader_get_uniform(shader, uniform), array);
}
} }
function shader_set_uniform_f_array_safe(uniform, array, max_length = 128) { function shader_set_uniform_f_array_safe(uniform, array, max_length = 128) {
gml_pragma("forceinline");
if(!is_array(array)) return; if(!is_array(array)) return;
if(array_length(array) == 0) return;
if(array_length(array) > max_length) var _len = array_length(array);
if(_len == 0) return;
if(_len > max_length)
array_resize(array, max_length) array_resize(array, max_length)
shader_set_uniform_f_array(uniform, array); shader_set_uniform_f_array(uniform, array);
} }
function shader_set_surface(sampler, surface, linear = false, _repeat = false) { function shader_set_surface(sampler, surface, linear = false, _repeat = false) {
gml_pragma("forceinline");
var shader = shader_current(); var shader = shader_current();
if(shader == -1) return; if(shader == -1) return;
@ -83,6 +111,8 @@ function shader_set_surface(sampler, surface, linear = false, _repeat = false) {
//} //}
function shader_set_surface_dimension(uniform, surface) { function shader_set_surface_dimension(uniform, surface) {
gml_pragma("forceinline");
var shader = shader_current(); var shader = shader_current();
if(!is_surface(surface)) return; if(!is_surface(surface)) return;
if(shader == -1) return; if(shader == -1) return;
@ -98,16 +128,22 @@ function shader_set_surface_dimension(uniform, surface) {
} }
function shader_set_dim(uniform = "dimension", surf = noone) { function shader_set_dim(uniform = "dimension", surf = noone) {
gml_pragma("forceinline");
if(!is_surface(surf)) return; if(!is_surface(surf)) return;
shader_set_f(uniform, surface_get_width_safe(surf), surface_get_height_safe(surf)); shader_set_f(uniform, surface_get_width_safe(surf), surface_get_height_safe(surf));
} }
function shader_set_color(uniform, col, alpha = 1) { function shader_set_color(uniform, col, alpha = 1) {
gml_pragma("forceinline");
shader_set_f(uniform, colToVec4(col, alpha)); shader_set_f(uniform, colToVec4(col, alpha));
} }
function shader_set_palette(pal, pal_uni = "palette", amo_uni = "paletteAmount", max_length = 128) { function shader_set_palette(pal, pal_uni = "palette", amo_uni = "paletteAmount", max_length = 128) {
gml_pragma("forceinline");
shader_set_i(amo_uni, min(max_length, array_length(pal))); shader_set_i(amo_uni, min(max_length, array_length(pal)));
var _pal = []; var _pal = [];
@ -127,13 +163,37 @@ function shader_set_palette(pal, pal_uni = "palette", amo_uni = "paletteAmount",
alphamulp, alphamulp,
} }
function shader_preset_interpolation(shader = sh_sample) {
gml_pragma("forceinline");
var intp = attributes.interpolation;
gpu_set_tex_filter(intp);
shader_set_uniform_i(shader_get_uniform(shader, "interpolation"), intp);
shader_set_uniform_i(shader_get_uniform(shader, "sampleMode"), attributes.oversample);
}
function shader_postset_interpolation() {
gml_pragma("forceinline");
gpu_set_tex_filter(false);
}
function shader_set_interpolation_surface(surface) {
gml_pragma("forceinline");
shader_set_f("sampleDimension", surface_get_width_safe(surface), surface_get_height_safe(surface));
}
function shader_set_interpolation(surface) { function shader_set_interpolation(surface) {
gml_pragma("forceinline");
var intp = attributes.interpolation; var intp = attributes.interpolation;
gpu_set_tex_filter(intp); gpu_set_tex_filter(intp);
shader_set_i("interpolation", intp); shader_set_i("interpolation", intp);
shader_set_f("sampleDimension", surface_get_width_safe(surface), surface_get_height_safe(surface)); shader_set_f("sampleDimension", surface_get_width_safe(surface), surface_get_height_safe(surface));
shader_set_i("sampleMode", struct_try_get(attributes, "oversample")); shader_set_i("sampleMode", attributes.oversample);
} }
function surface_set_shader(surface, shader = sh_sample, clear = true, blend = BLEND.alpha) { function surface_set_shader(surface, shader = sh_sample, clear = true, blend = BLEND.alpha) {
@ -164,7 +224,6 @@ function shader_set_palette(pal, pal_uni = "palette", amo_uni = "paletteAmount",
function surface_reset_shader() { function surface_reset_shader() {
if(!__surface_set) return; if(!__surface_set) return;
gpu_set_tex_filter(false);
BLEND_NORMAL; BLEND_NORMAL;
surface_reset_target(); surface_reset_target();

View file

@ -1,18 +0,0 @@
#macro shader_set shader_replace_simple_set_hook
#macro shader_replace_simple_set_base shader_set
#macro shader_reset shader_replace_simple_reset_hook
#macro shader_replace_simple_reset_base shader_reset
function shader_replace_simple_reset_hook() {
shader_replace_simple_reset_base();
shader_replace_simple_sync(-1);
}
function shader_replace_simple_set_hook() {
shader_replace_simple_set_base(argument0);
shader_replace_simple_sync(argument0);
}
function shader_replace_simple_macros(){
if (false) {
shader_replace_simple_set_base(0);
shader_replace_simple_reset_base();
}
}

View file

@ -1,11 +0,0 @@
{
"resourceType": "GMScript",
"resourceVersion": "1.0",
"name": "shader_replace_simple_macros",
"isCompatibility": false,
"isDnD": false,
"parent": {
"name": "Shader replace",
"path": "folders/_extensions/Shader replace.yy",
},
}

View file

@ -36,6 +36,8 @@ function struct_try_get(struct, key, def = 0) {
function struct_try_override(original, override, key) { function struct_try_override(original, override, key) {
gml_pragma("forceinline"); gml_pragma("forceinline");
if(!is_struct(original) || !is_struct(override)) return;
if(!struct_has(override, key)) return; if(!struct_has(override, key)) return;
original[$ key] = override[$ key]; original[$ key] = override[$ key];
} }

View file

@ -147,24 +147,15 @@ function surface_get_height_safe(s) {
function is_surface(s) { function is_surface(s) {
gml_pragma("forceinline"); gml_pragma("forceinline");
if(is_undefined(s)) return false;
if(is_array(s)) return false;
if(is_struct(s) && is_instanceof(s, dynaSurf)) return true; if(is_struct(s) && is_instanceof(s, dynaSurf)) return true;
if(!is_real(s)) return false; if(is_real(s) && s > 0 && surface_exists(s)) return true;
if(!s) return false; return false;
if(!surface_exists(s)) return false;
return true;
} }
function surface_verify(surf, w, h, format = surface_rgba8unorm) { function surface_verify(surf, w, h, format = surface_rgba8unorm) {
gml_pragma("forceinline"); gml_pragma("forceinline");
w = max(1, round(w)); if(!is_surface(surf)) return surface_create_valid(w, h, format);
h = max(1, round(h));
var s = is_surface(surf);
if(!s) return surface_create_valid(w, h, format);
return surface_size_to(surf, w, h, format, true); return surface_size_to(surf, w, h, format, true);
} }
@ -402,9 +393,8 @@ function surface_copy_size(dest, source, format = noone) {
function surface_valid_size(s) { function surface_valid_size(s) {
gml_pragma("forceinline"); gml_pragma("forceinline");
if(is_infinity(s)) return 1;
s = toNumber(s);
if(!is_real(s)) return 1; if(!is_real(s)) return 1;
if(is_infinity(s)) return 1;
return clamp(s, 1, 8196); return clamp(s, 1, 8196);
} }