mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-11 23:06:51 +01:00
Palette, gradient dialog fix. Line optimize. Sprite stack fix.
This commit is contained in:
parent
ff5124b551
commit
7bfecbf6a5
20 changed files with 239 additions and 198 deletions
|
@ -40,7 +40,7 @@ if !ready exit;
|
||||||
var by = dialog_y + ui(12);
|
var by = dialog_y + ui(12);
|
||||||
|
|
||||||
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txt("Refresh"), THEME.refresh) == 2)
|
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txt("Refresh"), THEME.refresh) == 2)
|
||||||
presetCollect();
|
__initPalette();
|
||||||
bx -= ui(32);
|
bx -= ui(32);
|
||||||
|
|
||||||
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txtx("color_selector_open_palette", "Open palette folder"), THEME.folder) == 2) {
|
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txtx("color_selector_open_palette", "Open palette folder"), THEME.folder) == 2) {
|
||||||
|
|
|
@ -45,9 +45,7 @@ if !ready exit;
|
||||||
var bx = presets_x + presets_w - ui(44);
|
var bx = presets_x + presets_w - ui(44);
|
||||||
var by = dialog_y + ui(12);
|
var by = dialog_y + ui(12);
|
||||||
|
|
||||||
var _b = buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txtx("add_preset", "Add to preset"));
|
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txtx("add_preset", "Add to preset")) == 2) {
|
||||||
|
|
||||||
if(_b == 2) {
|
|
||||||
var dia = dialogCall(o_dialog_file_name, mouse_mx + ui(8), mouse_my + ui(8));
|
var dia = dialogCall(o_dialog_file_name, mouse_mx + ui(8), mouse_my + ui(8));
|
||||||
dia.onModify = function (txt) {
|
dia.onModify = function (txt) {
|
||||||
var gradStr = "";
|
var gradStr = "";
|
||||||
|
@ -62,7 +60,7 @@ if !ready exit;
|
||||||
var file = file_text_open_write(txt + ".txt");
|
var file = file_text_open_write(txt + ".txt");
|
||||||
file_text_write_string(file, gradStr);
|
file_text_write_string(file, gradStr);
|
||||||
file_text_close(file);
|
file_text_close(file);
|
||||||
presetCollect();
|
__initGradient();
|
||||||
};
|
};
|
||||||
dia.path = DIRECTORY + "Gradients/"
|
dia.path = DIRECTORY + "Gradients/"
|
||||||
}
|
}
|
||||||
|
@ -70,7 +68,7 @@ if !ready exit;
|
||||||
bx -= ui(32);
|
bx -= ui(32);
|
||||||
|
|
||||||
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txt("Refresh"), THEME.refresh) == 2)
|
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txt("Refresh"), THEME.refresh) == 2)
|
||||||
presetCollect();
|
__initGradient();
|
||||||
bx -= ui(32);
|
bx -= ui(32);
|
||||||
|
|
||||||
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txtx("graident_editor_open_folder", "Open gradient folder"), THEME.folder) == 2) {
|
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txtx("graident_editor_open_folder", "Open gradient folder"), THEME.folder) == 2) {
|
||||||
|
|
|
@ -2,17 +2,17 @@
|
||||||
event_inherited();
|
event_inherited();
|
||||||
|
|
||||||
#region data
|
#region data
|
||||||
dialog_w = ui(812);
|
dialog_w = ui(812);
|
||||||
dialog_h = ui(440);
|
dialog_h = ui(440);
|
||||||
title_height = 52;
|
title_height = 52;
|
||||||
destroy_on_click_out = true;
|
destroy_on_click_out = true;
|
||||||
|
|
||||||
name = __txtx("palette_editor_title", "Palette editor");
|
name = __txtx("palette_editor_title", "Palette editor");
|
||||||
palette = 0;
|
palette = 0;
|
||||||
|
|
||||||
index_selecting = 0;
|
index_selecting = 0;
|
||||||
index_dragging = -1;
|
index_dragging = -1;
|
||||||
interactable = true;
|
interactable = true;
|
||||||
|
|
||||||
setColor = function(color) {
|
setColor = function(color) {
|
||||||
if(index_selecting == -1 || palette == 0) return;
|
if(index_selecting == -1 || palette == 0) return;
|
||||||
|
@ -22,9 +22,9 @@ event_inherited();
|
||||||
onApply(palette);
|
onApply(palette);
|
||||||
}
|
}
|
||||||
|
|
||||||
onApply = noone;
|
onApply = noone;
|
||||||
selector = new colorSelector(setColor);
|
selector = new colorSelector(setColor);
|
||||||
selector.dropper_close = false;
|
selector.dropper_close = false;
|
||||||
selector.discretize_pal = false;
|
selector.discretize_pal = false;
|
||||||
|
|
||||||
previous_palette = c_black;
|
previous_palette = c_black;
|
||||||
|
@ -58,7 +58,7 @@ event_inherited();
|
||||||
|
|
||||||
sp_preset_w = ui(240 - 32 - 16);
|
sp_preset_w = ui(240 - 32 - 16);
|
||||||
sp_presets = new scrollPane(sp_preset_w, dialog_h - ui(62), function(_y, _m) {
|
sp_presets = new scrollPane(sp_preset_w, dialog_h - ui(62), function(_y, _m) {
|
||||||
var ww = sp_preset_w - ui(40);
|
var ww = sp_preset_w - ui(40);
|
||||||
var hh = ui(32);
|
var hh = ui(32);
|
||||||
var yy = _y + ui(8);
|
var yy = _y + ui(8);
|
||||||
var hg = ui(52);
|
var hg = ui(52);
|
||||||
|
@ -87,7 +87,7 @@ event_inherited();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mouse_press(mb_right, interactable && sFOCUS)) {
|
if(mouse_press(mb_right, interactable && sFOCUS)) {
|
||||||
hovering_name = pal.name;
|
hovering_name = pal.path;
|
||||||
menuCall("palette_window_preset_menu",,, [
|
menuCall("palette_window_preset_menu",,, [
|
||||||
menuItem(__txtx("palette_editor_delete", "Delete palette"), function() {
|
menuItem(__txtx("palette_editor_delete", "Delete palette"), function() {
|
||||||
file_delete(hovering_name);
|
file_delete(hovering_name);
|
||||||
|
|
|
@ -53,15 +53,15 @@ if palette == 0 exit;
|
||||||
file_text_writeln(file);
|
file_text_writeln(file);
|
||||||
}
|
}
|
||||||
file_text_close(file);
|
file_text_close(file);
|
||||||
presetCollect();
|
__initPalette();
|
||||||
};
|
};
|
||||||
dia.path = DIRECTORY + "Palettes/"
|
dia.path = DIRECTORY + "Palettes/"
|
||||||
}
|
}
|
||||||
bx -= ui(32);
|
bx -= ui(32);
|
||||||
|
|
||||||
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txt("Refresh"), THEME.refresh) == 2) {
|
if(buttonInstant(THEME.button_hide, bx, by, ui(28), ui(28), mouse_ui, sFOCUS, sHOVER, __txt("Refresh"), THEME.refresh) == 2)
|
||||||
presetCollect();
|
__initPalette();
|
||||||
}
|
|
||||||
draw_sprite_ui_uniform(THEME.refresh, 0, bx + ui(14), by + ui(14), 1, COLORS._main_icon);
|
draw_sprite_ui_uniform(THEME.refresh, 0, bx + ui(14), by + ui(14), 1, COLORS._main_icon);
|
||||||
bx -= ui(32);
|
bx -= ui(32);
|
||||||
|
|
||||||
|
|
|
@ -100,7 +100,6 @@ function __part(_node) constructor {
|
||||||
life_total = life;
|
life_total = life;
|
||||||
if(node.onPartCreate != noone) node.onPartCreate(self);
|
if(node.onPartCreate != noone) node.onPartCreate(self);
|
||||||
|
|
||||||
trailActive = true;
|
|
||||||
trailLife = 0;
|
trailLife = 0;
|
||||||
x_history = array_create(life);
|
x_history = array_create(life);
|
||||||
y_history = array_create(life);
|
y_history = array_create(life);
|
||||||
|
@ -176,6 +175,7 @@ function __part(_node) constructor {
|
||||||
|
|
||||||
static step = function(frame = 0) { #region
|
static step = function(frame = 0) { #region
|
||||||
gml_pragma("forceinline");
|
gml_pragma("forceinline");
|
||||||
|
//if(life_total > 0) print($"Step {seed}: {trailLife}");
|
||||||
trailLife++;
|
trailLife++;
|
||||||
|
|
||||||
if(!active) return;
|
if(!active) return;
|
||||||
|
@ -201,7 +201,11 @@ function __part(_node) constructor {
|
||||||
dirr += wig_dir.get(seed + life);
|
dirr += wig_dir.get(seed + life);
|
||||||
|
|
||||||
if(turning != 0) {
|
if(turning != 0) {
|
||||||
var trn = turnSpd? turning * diss : turning;
|
var trn = turning;
|
||||||
|
|
||||||
|
if(turnSpd > 0) trn = turning * diss * turnSpd;
|
||||||
|
else if(turnSpd < 0) trn = turning / diss * turnSpd;
|
||||||
|
|
||||||
dirr += trn
|
dirr += trn
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,7 +116,7 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
||||||
inputs[| 35] = nodeValue("Turn both directions", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false, "Apply randomized 1, -1 multiplier to the turning speed." )
|
inputs[| 35] = nodeValue("Turn both directions", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false, "Apply randomized 1, -1 multiplier to the turning speed." )
|
||||||
.rejectArray();
|
.rejectArray();
|
||||||
|
|
||||||
inputs[| 36] = nodeValue("Turn scale with speed", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false )
|
inputs[| 36] = nodeValue("Turn scale with speed", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, false )
|
||||||
.rejectArray();
|
.rejectArray();
|
||||||
|
|
||||||
inputs[| 37] = nodeValue("Collide ground", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false )
|
inputs[| 37] = nodeValue("Collide ground", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false )
|
||||||
|
@ -426,6 +426,7 @@ function Node_VFX_Spawner_Base(_x, _y, _group = noone) : Node(_x, _y, _group) co
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//print($"\n===== Running VFX {_time} =====")
|
||||||
//var activeParts = 0;
|
//var activeParts = 0;
|
||||||
for(var i = 0; i < array_length(parts); i++) {
|
for(var i = 0; i < array_length(parts); i++) {
|
||||||
//activeParts++;
|
//activeParts++;
|
||||||
|
|
|
@ -23,30 +23,60 @@ function draw_line_width2(x0, y0, x1, y1, w0, w1, cap = false) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function draw_line_width2_angle(x0, y0, x1, y1, w0, w1, a0 = 0, a1 = 0, _oc = c_white, _nc = c_white, widColor = false) {
|
function draw_line_width2_angle(x0, y0, x1, y1, w0, w1, a0 = 0, a1 = 0, _oc = c_white, _nc = c_white) {
|
||||||
var _x0 = x0 + lengthdir_x(w0 / 2, a0);
|
var _d0x = lengthdir_x(w0 / 2, a0);
|
||||||
var _y0 = y0 + lengthdir_y(w0 / 2, a0);
|
var _d0y = lengthdir_y(w0 / 2, a0);
|
||||||
var _x1 = x1 + lengthdir_x(w1 / 2, a1);
|
var _d1x = lengthdir_x(w1 / 2, a1);
|
||||||
var _y1 = y1 + lengthdir_y(w1 / 2, a1);
|
var _d1y = lengthdir_y(w1 / 2, a1);
|
||||||
|
|
||||||
|
var _x0 = x0 + _d0x;
|
||||||
|
var _y0 = y0 + _d0y;
|
||||||
|
var _x1 = x1 + _d1x;
|
||||||
|
var _y1 = y1 + _d1y;
|
||||||
|
|
||||||
//draw_set_color(c_red);
|
//draw_set_color(c_red);
|
||||||
draw_primitive_begin(pr_trianglestrip);
|
draw_vertex_color( x0, y0, _oc, 1);
|
||||||
draw_vertex_color( x0, y0, widColor? merge_color(_oc, c_black, 0.5) : _oc, 1);
|
draw_vertex_color( x1, y1, _nc, 1);
|
||||||
draw_vertex_color( x1, y1, widColor? merge_color(_nc, c_black, 0.5) : _nc, 1);
|
draw_vertex_color(_x0, _y0, _oc, 1);
|
||||||
draw_vertex_color(_x0, _y0, widColor? merge_color(_oc, c_black, 0.0) : _oc, 1);
|
draw_vertex_color(_x1, _y1, _nc, 1);
|
||||||
draw_vertex_color(_x1, _y1, widColor? merge_color(_nc, c_black, 0.0) : _nc, 1);
|
|
||||||
draw_primitive_end();
|
|
||||||
|
|
||||||
var _x0 = x0 + lengthdir_x(w0 / 2, a0 + 180);
|
var _x0 = x0 - _d0x;
|
||||||
var _y0 = y0 + lengthdir_y(w0 / 2, a0 + 180);
|
var _y0 = y0 - _d0y;
|
||||||
var _x1 = x1 + lengthdir_x(w1 / 2, a1 + 180);
|
var _x1 = x1 - _d1x;
|
||||||
var _y1 = y1 + lengthdir_y(w1 / 2, a1 + 180);
|
var _y1 = y1 - _d1y;
|
||||||
|
|
||||||
//draw_set_color(c_blue);
|
//draw_set_color(c_blue);
|
||||||
draw_primitive_begin(pr_trianglestrip);
|
draw_vertex_color( x0, y0, _oc, 1);
|
||||||
draw_vertex_color( x0, y0, widColor? merge_color(_oc, c_black, 0.5) : _oc, 1);
|
draw_vertex_color( x1, y1, _nc, 1);
|
||||||
draw_vertex_color( x1, y1, widColor? merge_color(_nc, c_black, 0.5) : _nc, 1);
|
draw_vertex_color(_x0, _y0, _oc, 1);
|
||||||
draw_vertex_color(_x0, _y0, widColor? merge_color(_oc, c_black, 1.0) : _oc, 1);
|
draw_vertex_color(_x1, _y1, _nc, 1);
|
||||||
draw_vertex_color(_x1, _y1, widColor? merge_color(_nc, c_black, 1.0) : _nc, 1);
|
}
|
||||||
draw_primitive_end();
|
|
||||||
|
function draw_line_width2_angle_width(x0, y0, x1, y1, w0, w1, a0 = 0, a1 = 0, _oc = c_white, _nc = c_white) {
|
||||||
|
var _d0x = lengthdir_x(w0 / 2, a0);
|
||||||
|
var _d0y = lengthdir_y(w0 / 2, a0);
|
||||||
|
var _d1x = lengthdir_x(w1 / 2, a1);
|
||||||
|
var _d1y = lengthdir_y(w1 / 2, a1);
|
||||||
|
|
||||||
|
var _x0 = x0 + _d0x;
|
||||||
|
var _y0 = y0 + _d0y;
|
||||||
|
var _x1 = x1 + _d1x;
|
||||||
|
var _y1 = y1 + _d1y;
|
||||||
|
|
||||||
|
//draw_set_color(c_red);
|
||||||
|
draw_vertex_color( x0, y0, _oc, 1);
|
||||||
|
draw_vertex_color( x1, y1, _nc, 1);
|
||||||
|
draw_vertex_color(_x0, _y0, 0, 1);
|
||||||
|
draw_vertex_color(_x1, _y1, 0, 1);
|
||||||
|
|
||||||
|
var _x0 = x0 - _d0x;
|
||||||
|
var _y0 = y0 - _d0y;
|
||||||
|
var _x1 = x1 - _d1x;
|
||||||
|
var _y1 = y1 - _d1y;
|
||||||
|
|
||||||
|
//draw_set_color(c_blue);
|
||||||
|
draw_vertex_color( x0, y0, _oc, 1);
|
||||||
|
draw_vertex_color( x1, y1, _nc, 1);
|
||||||
|
draw_vertex_color(_x0, _y0, c_black, 1);
|
||||||
|
draw_vertex_color(_x1, _y1, c_black, 1);
|
||||||
}
|
}
|
|
@ -5,7 +5,9 @@ function Node_VFX_Spawner(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y
|
||||||
reloop = true;
|
reloop = true;
|
||||||
|
|
||||||
attributes.Output_pool = false;
|
attributes.Output_pool = false;
|
||||||
|
array_push(attributeEditors, ["Output all particles", function() { return attributes.Output_pool; },
|
||||||
|
new checkBox(function() { attributes.Output_pool = !attributes.Output_pool; }) ]);
|
||||||
|
|
||||||
inputs[| 21].setVisible(false, false);
|
inputs[| 21].setVisible(false, false);
|
||||||
|
|
||||||
inputs[| input_len + 0] = nodeValue("Spawn trigger", self, JUNCTION_CONNECT.input, VALUE_TYPE.node, false)
|
inputs[| input_len + 0] = nodeValue("Spawn trigger", self, JUNCTION_CONNECT.input, VALUE_TYPE.node, false)
|
||||||
|
@ -23,7 +25,8 @@ function Node_VFX_Spawner(_x, _y, _group = noone) : Node_VFX_Spawner_Base(_x, _y
|
||||||
UPDATE_PART_FORWARD
|
UPDATE_PART_FORWARD
|
||||||
|
|
||||||
static onUpdate = function(frame = CURRENT_FRAME) { #region
|
static onUpdate = function(frame = CURRENT_FRAME) { #region
|
||||||
runVFX(frame);
|
if(PROJECT.animator.frame_progress)
|
||||||
|
runVFX(frame);
|
||||||
|
|
||||||
if(attributes.Output_pool) {
|
if(attributes.Output_pool) {
|
||||||
outputs[| 0].setValue(parts);
|
outputs[| 0].setValue(parts);
|
||||||
|
|
|
@ -98,6 +98,7 @@ function Node_VFX_Trail(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
||||||
var _trail_st = max(1, _vfx.trailLife - _life);
|
var _trail_st = max(1, _vfx.trailLife - _life);
|
||||||
var _trail_len = _trail_ed - _trail_st;
|
var _trail_len = _trail_ed - _trail_st;
|
||||||
|
|
||||||
|
//if(_vfx.life_total > 0) print($"{_vfx.active} | {_vfx.seed} : {_vfx.trailLife}")
|
||||||
if(_trail_len <= 0) continue;
|
if(_trail_len <= 0) continue;
|
||||||
|
|
||||||
var _lngh = 0;
|
var _lngh = 0;
|
||||||
|
|
|
@ -367,6 +367,7 @@ function Node_Group_Input(_x, _y, _group = noone) : Node(_x, _y, _group) constru
|
||||||
static onDestroy = function() { #region
|
static onDestroy = function() { #region
|
||||||
if(is_undefined(inParent)) return;
|
if(is_undefined(inParent)) return;
|
||||||
ds_list_remove(group.inputs, inParent);
|
ds_list_remove(group.inputs, inParent);
|
||||||
|
group.sortIO();
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
static ungroup = function() { #region
|
static ungroup = function() { #region
|
||||||
|
|
|
@ -122,7 +122,8 @@ function Node_Group_Output(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
||||||
|
|
||||||
static onDestroy = function() { #region
|
static onDestroy = function() { #region
|
||||||
if(is_undefined(outParent)) return;
|
if(is_undefined(outParent)) return;
|
||||||
ds_list_delete(group.outputs, ds_list_find_index(group.outputs, outParent));
|
ds_list_remove(group.outputs, outParent);
|
||||||
|
group.sortIO();
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
static ungroup = function() { #region
|
static ungroup = function() { #region
|
||||||
|
@ -139,7 +140,7 @@ function Node_Group_Output(_x, _y, _group = noone) : Node(_x, _y, _group) constr
|
||||||
static onLoadGroup = function() { #region
|
static onLoadGroup = function() { #region
|
||||||
if(group == noone) nodeDelete(self);
|
if(group == noone) nodeDelete(self);
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
//static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { #region
|
//static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { #region
|
||||||
// var bbox = drawGetBbox(xx, yy, _s);
|
// var bbox = drawGetBbox(xx, yy, _s);
|
||||||
// draw_set_text(f_h5, fa_center, fa_center, c_white);
|
// draw_set_text(f_h5, fa_center, fa_center, c_white);
|
||||||
|
|
|
@ -77,6 +77,8 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
|
|
||||||
lines = [];
|
lines = [];
|
||||||
|
|
||||||
|
widthMap = ds_map_create();
|
||||||
|
|
||||||
attribute_surface_depth();
|
attribute_surface_depth();
|
||||||
attribute_interpolation();
|
attribute_interpolation();
|
||||||
|
|
||||||
|
@ -122,39 +124,42 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
static processData = function(_outSurf, _data, _output_index, _array_index) {
|
static processData = function(_outSurf, _data, _output_index, _array_index) {
|
||||||
var _dim = _data[0];
|
#region data
|
||||||
var _bg = _data[1];
|
var _dim = _data[0];
|
||||||
var _seg = _data[2];
|
var _bg = _data[1];
|
||||||
var _wid = _data[3];
|
var _seg = _data[2];
|
||||||
var _wig = _data[4];
|
var _wid = _data[3];
|
||||||
var _sed = _data[5];
|
var _wig = _data[4];
|
||||||
var _ang = _data[6] % 360;
|
var _sed = _data[5];
|
||||||
var _pat = _data[7];
|
var _ang = _data[6] % 360;
|
||||||
var _ratio = _data[8];
|
var _pat = _data[7];
|
||||||
var _shift = _data[9];
|
var _ratio = _data[8];
|
||||||
|
var _shift = _data[9];
|
||||||
|
|
||||||
var _color = _data[10];
|
var _color = _data[10];
|
||||||
var _widc = _data[11];
|
var _widc = _data[11];
|
||||||
var _widap = _data[12];
|
var _widap = _data[12];
|
||||||
|
|
||||||
var _cap = _data[13];
|
var _cap = _data[13];
|
||||||
var _capP = _data[14];
|
var _capP = _data[14];
|
||||||
var _colP = _data[15];
|
var _colP = _data[15];
|
||||||
var _colW = _data[16];
|
var _colW = _data[16];
|
||||||
var _1px = _data[17];
|
var _1px = _data[17];
|
||||||
|
|
||||||
var _fixL = _data[19];
|
var _fixL = _data[19];
|
||||||
var _segL = _data[20];
|
var _segL = _data[20];
|
||||||
|
|
||||||
var _tex = _data[18];
|
var _tex = _data[18];
|
||||||
var _texPos = _data[21];
|
var _texPos = _data[21];
|
||||||
var _texRot = _data[22];
|
var _texRot = _data[22];
|
||||||
var _texSca = _data[23];
|
var _texSca = _data[23];
|
||||||
|
|
||||||
var _colb = _data[24];
|
var _colb = _data[24];
|
||||||
|
#endregion
|
||||||
inputs[| 14].setVisible(_cap);
|
|
||||||
|
|
||||||
|
if(CURRENT_FRAME == 0 || inputs[| 11].is_anim)
|
||||||
|
ds_map_clear(widthMap);
|
||||||
|
|
||||||
var _rangeMin = min(_ratio[0], _ratio[1]);
|
var _rangeMin = min(_ratio[0], _ratio[1]);
|
||||||
var _rangeMax = max(_ratio[0], _ratio[1]);
|
var _rangeMax = max(_ratio[0], _ratio[1]);
|
||||||
if(_rangeMax == 1) _rangeMax = 0.99999;
|
if(_rangeMax == 1) _rangeMax = 0.99999;
|
||||||
|
@ -334,6 +339,10 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
lines = [ points ];
|
lines = [ points ];
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
|
#region draw
|
||||||
|
|
||||||
|
//print($"==== Drawing frame {CURRENT_FRAME} ====")
|
||||||
|
|
||||||
surface_set_target(_outSurf);
|
surface_set_target(_outSurf);
|
||||||
if(_bg) draw_clear_alpha(0, 1);
|
if(_bg) draw_clear_alpha(0, 1);
|
||||||
else DRAW_CLEAR
|
else DRAW_CLEAR
|
||||||
|
@ -347,14 +356,15 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
shader_set_f("scale", _texSca);
|
shader_set_f("scale", _texSca);
|
||||||
|
|
||||||
shader_set_interpolation(_tex);
|
shader_set_interpolation(_tex);
|
||||||
draw_primitive_begin_texture(pr_trianglestrip, tex);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
for( var i = 0, n = array_length(lines); i < n; i++ ) {
|
for( var i = 0, n = array_length(lines); i < n; i++ ) {
|
||||||
var points = lines[i];
|
var points = lines[i];
|
||||||
if(array_length(points) < 2) continue;
|
if(array_length(points) < 2) continue;
|
||||||
|
|
||||||
|
if(_useTex) draw_primitive_begin_texture(pr_trianglestrip, tex);
|
||||||
|
else draw_primitive_begin(pr_trianglestrip);
|
||||||
|
|
||||||
random_set_seed(_sed + i);
|
random_set_seed(_sed + i);
|
||||||
var pxs = [];
|
var pxs = [];
|
||||||
var dat = array_safe_get(_pathData, i, noone);
|
var dat = array_safe_get(_pathData, i, noone);
|
||||||
|
@ -369,12 +379,16 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
var prgc = p0.progCrop;
|
var prgc = p0.progCrop;
|
||||||
|
|
||||||
if(_1px) {
|
if(_1px) {
|
||||||
_nx = _nx - 0.5;
|
_nx = _nx - 0.5;
|
||||||
_ny = _ny - 0.5;
|
_ny = _ny - 0.5;
|
||||||
}
|
}
|
||||||
|
|
||||||
_nw = random_range(_wid[0], _wid[1]);
|
var widProg = value_snap_real(_widap? prog : prgc, 0.01);
|
||||||
_nw *= eval_curve_x(_widc, _widap? prog : prgc);
|
|
||||||
|
_nw = random_range(_wid[0], _wid[1]);
|
||||||
|
if(!ds_map_exists(widthMap, widProg))
|
||||||
|
widthMap[? widProg] = eval_curve_x(_widc, widProg, 0.1);
|
||||||
|
_nw *= widthMap[? widProg];
|
||||||
_nw *= p0.weight;
|
_nw *= p0.weight;
|
||||||
|
|
||||||
_nc = colorMultiply(_col_base, _color.eval(_colP? prog : prgc));
|
_nc = colorMultiply(_col_base, _color.eval(_colP? prog : prgc));
|
||||||
|
@ -443,8 +457,10 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
draw_vertex_texture_color(ox1, oy1, 1, (j - 1) / _len, _oc, 1);
|
draw_vertex_texture_color(ox1, oy1, 1, (j - 1) / _len, _oc, 1);
|
||||||
draw_vertex_texture_color(nx0, ny0, 0, (j - 0) / _len, _nc, 1);
|
draw_vertex_texture_color(nx0, ny0, 0, (j - 0) / _len, _nc, 1);
|
||||||
draw_vertex_texture_color(nx1, ny1, 1, (j - 0) / _len, _nc, 1);
|
draw_vertex_texture_color(nx1, ny1, 1, (j - 0) / _len, _nc, 1);
|
||||||
} else
|
} else if(_colW)
|
||||||
draw_line_width2_angle(_ox, _oy, _nx, _ny, _ow, _nw, _od + 90, _nd + 90, _oc, _nc, _colW);
|
draw_line_width2_angle_width(_ox, _oy, _nx, _ny, _ow, _nw, _od + 90, _nd + 90, merge_color(_oc, c_black, 0.5), merge_color(_nc, c_black, 0.5));
|
||||||
|
else
|
||||||
|
draw_line_width2_angle(_ox, _oy, _nx, _ny, _ow, _nw, _od + 90, _nd + 90, _oc, _nc);
|
||||||
} else {
|
} else {
|
||||||
var p1 = points[j + 1];
|
var p1 = points[j + 1];
|
||||||
_nd = point_direction(_nx, _ny, p1.x, p1.y);
|
_nd = point_direction(_nx, _ny, p1.x, p1.y);
|
||||||
|
@ -458,12 +474,12 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(_useTex) {
|
draw_primitive_end();
|
||||||
draw_primitive_end();
|
|
||||||
shader_reset();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(_useTex) shader_reset();
|
||||||
surface_reset_target();
|
surface_reset_target();
|
||||||
|
#endregion
|
||||||
|
|
||||||
return _outSurf;
|
return _outSurf;
|
||||||
}
|
}
|
||||||
|
|
|
@ -425,20 +425,20 @@ function NodeObject(_name, _spr, _node, _create, tags = []) constructor { #regio
|
||||||
///**/ addNodeObject(d3d, "3D Instancer", s_node_3d_set_material, "Node_3D_Instancer", [1, Node_3D_Instancer]).setVersion(11560);
|
///**/ addNodeObject(d3d, "3D Instancer", s_node_3d_set_material, "Node_3D_Instancer", [1, Node_3D_Instancer]).setVersion(11560);
|
||||||
///**/ addNodeObject(d3d, "3D Particle", s_node_3d_set_material, "Node_3D_Particle", [1, Node_3D_Particle]).setVersion(11560);
|
///**/ addNodeObject(d3d, "3D Particle", s_node_3d_set_material, "Node_3D_Particle", [1, Node_3D_Particle]).setVersion(11560);
|
||||||
|
|
||||||
ds_list_add(d3d, "Legacy"); //////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
//ds_list_add(d3d, "Legacy"); //////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
addNodeObject(d3d, "3D Plane", s_node_3d_plane, "__Node_3D_Plane", [1, __Node_3D_Plane],, "Put 2D image on a plane in 3D space.").isDeprecated();
|
//addNodeObject(d3d, "3D Plane", s_node_3d_plane, "__Node_3D_Plane", [1, __Node_3D_Plane],, "Put 2D image on a plane in 3D space.").isDeprecated();
|
||||||
addNodeObject(d3d, "3D Cube", s_node_3d_cube, "__Node_3D_Cube", [1, __Node_3D_Cube]).isDeprecated();
|
//addNodeObject(d3d, "3D Cube", s_node_3d_cube, "__Node_3D_Cube", [1, __Node_3D_Cube]).isDeprecated();
|
||||||
addNodeObject(d3d, "3D Cylinder", s_node_3d_cylinder, "__Node_3D_Cylinder", [1, __Node_3D_Cylinder]).isDeprecated();
|
//addNodeObject(d3d, "3D Cylinder", s_node_3d_cylinder, "__Node_3D_Cylinder", [1, __Node_3D_Cylinder]).isDeprecated();
|
||||||
addNodeObject(d3d, "3D Sphere", s_node_3d_sphere, "__Node_3D_Sphere", [1, __Node_3D_Sphere]).setVersion(1090).isDeprecated();
|
//addNodeObject(d3d, "3D Sphere", s_node_3d_sphere, "__Node_3D_Sphere", [1, __Node_3D_Sphere]).setVersion(1090).isDeprecated();
|
||||||
addNodeObject(d3d, "3D Cone", s_node_3d_cone, "__Node_3D_Cone", [1, __Node_3D_Cone]).setVersion(1090).isDeprecated();
|
//addNodeObject(d3d, "3D Cone", s_node_3d_cone, "__Node_3D_Cone", [1, __Node_3D_Cone]).setVersion(1090).isDeprecated();
|
||||||
addNodeObject(d3d, "3D Extrude", s_node_3d_extrude, "__Node_3D_Extrude", [1, __Node_3D_Extrude],, "Extrude 2D image into 3D object.").isDeprecated();
|
//addNodeObject(d3d, "3D Extrude", s_node_3d_extrude, "__Node_3D_Extrude", [1, __Node_3D_Extrude],, "Extrude 2D image into 3D object.").isDeprecated();
|
||||||
|
|
||||||
addNodeObject(d3d, "3D Transform", s_node_3d_transform, "__Node_3D_Transform", [1, __Node_3D_Transform]).setVersion(1080).isDeprecated();
|
//addNodeObject(d3d, "3D Transform", s_node_3d_transform, "__Node_3D_Transform", [1, __Node_3D_Transform]).setVersion(1080).isDeprecated();
|
||||||
addNodeObject(d3d, "3D Combine", s_node_3d_obj_combine, "__Node_3D_Combine", [1, __Node_3D_Combine],, "Combine multiple 3D object to a single scene,").setVersion(1080).isDeprecated();
|
//addNodeObject(d3d, "3D Combine", s_node_3d_obj_combine, "__Node_3D_Combine", [1, __Node_3D_Combine],, "Combine multiple 3D object to a single scene,").setVersion(1080).isDeprecated();
|
||||||
addNodeObject(d3d, "3D Repeat", s_node_3d_array, "__Node_3D_Repeat", [1, __Node_3D_Repeat], ["3d array"], "Repeat 3D object multiple times.").setVersion(1080).isDeprecated();
|
//addNodeObject(d3d, "3D Repeat", s_node_3d_array, "__Node_3D_Repeat", [1, __Node_3D_Repeat], ["3d array"], "Repeat 3D object multiple times.").setVersion(1080).isDeprecated();
|
||||||
addNodeObject(d3d, "3D Displace", s_node_3d_displace, "__Node_3D_Displace", [1, __Node_3D_Displace]).setVersion(1143).isDeprecated();
|
//addNodeObject(d3d, "3D Displace", s_node_3d_displace, "__Node_3D_Displace", [1, __Node_3D_Displace]).setVersion(1143).isDeprecated();
|
||||||
|
|
||||||
addNodeObject(d3d, "3D Export", s_node_3d_export, "__Node_3D_Export", [1, __Node_3D_Export]).setVersion(1143).isDeprecated();
|
//addNodeObject(d3d, "3D Export", s_node_3d_export, "__Node_3D_Export", [1, __Node_3D_Export]).setVersion(1143).isDeprecated();
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
var generator = ds_list_create(); #region
|
var generator = ds_list_create(); #region
|
||||||
|
|
|
@ -127,7 +127,7 @@ function Node_Sprite_Stack(_x, _y, _group = noone) : Node_Processor(_x, _y, _gro
|
||||||
var _surf = getInputData(0);
|
var _surf = getInputData(0);
|
||||||
var _arry = getInputData(12);
|
var _arry = getInputData(12);
|
||||||
|
|
||||||
inputs[| 2].setVisible(_arry && is_array(_surf));
|
inputs[| 2].setVisible(_arry == 0 || !is_array(_surf));
|
||||||
|
|
||||||
inputs[| 10].setVisible(_high);
|
inputs[| 10].setVisible(_high);
|
||||||
inputs[| 11].setVisible(_high);
|
inputs[| 11].setVisible(_high);
|
||||||
|
|
|
@ -1,23 +1,6 @@
|
||||||
function Node_Stripe(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
function Node_Stripe(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) constructor {
|
||||||
name = "Stripe";
|
name = "Stripe";
|
||||||
|
|
||||||
shader = sh_stripe;
|
|
||||||
uniform_grad_use = shader_get_uniform(shader, "gradient_use");
|
|
||||||
uniform_grad_blend = shader_get_uniform(shader, "gradient_blend");
|
|
||||||
uniform_grad = shader_get_uniform(shader, "gradient_color");
|
|
||||||
uniform_grad_time = shader_get_uniform(shader, "gradient_time");
|
|
||||||
uniform_grad_key = shader_get_uniform(shader, "gradient_keys");
|
|
||||||
|
|
||||||
uniform_dim = shader_get_uniform(shader, "dimension");
|
|
||||||
uniform_pos = shader_get_uniform(shader, "position");
|
|
||||||
uniform_angle = shader_get_uniform(shader, "angle");
|
|
||||||
uniform_amount = shader_get_uniform(shader, "amount");
|
|
||||||
uniform_blend = shader_get_uniform(shader, "blend");
|
|
||||||
uniform_rand = shader_get_uniform(shader, "rand");
|
|
||||||
|
|
||||||
uniform_clr0 = shader_get_uniform(shader, "color0");
|
|
||||||
uniform_clr1 = shader_get_uniform(shader, "color1");
|
|
||||||
|
|
||||||
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF )
|
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF )
|
||||||
.setDisplay(VALUE_DISPLAY.vector);
|
.setDisplay(VALUE_DISPLAY.vector);
|
||||||
|
|
||||||
|
@ -44,26 +27,29 @@ function Node_Stripe(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
|
||||||
|
|
||||||
inputs[| 9] = nodeValue("Color 2", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_black);
|
inputs[| 9] = nodeValue("Color 2", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_black);
|
||||||
|
|
||||||
|
inputs[| 10] = nodeValue("Strip ratio", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0.5)
|
||||||
|
.setDisplay(VALUE_DISPLAY.slider);
|
||||||
|
|
||||||
outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
|
outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
|
||||||
|
|
||||||
input_display_list = [
|
input_display_list = [
|
||||||
["Output", true], 0,
|
["Output", true], 0,
|
||||||
["Pattern", false], 1, 2, 4, 5,
|
["Pattern", false], 1, 10, 2, 4, 5,
|
||||||
["Render", false], 6, 7, 8, 9, 3
|
["Render", false], 6, 7, 8, 9, 3
|
||||||
];
|
];
|
||||||
|
|
||||||
attribute_surface_depth();
|
attribute_surface_depth();
|
||||||
|
|
||||||
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
|
||||||
var pos = getInputData(4);
|
var pos = getInputData(4);
|
||||||
var px = _x + pos[0] * _s;
|
var px = _x + pos[0] * _s;
|
||||||
var py = _y + pos[1] * _s;
|
var py = _y + pos[1] * _s;
|
||||||
|
|
||||||
inputs[| 4].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
inputs[| 4].drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
||||||
inputs[| 2].drawOverlay(active, px, py, _s, _mx, _my, _snx, _sny);
|
inputs[| 2].drawOverlay(active, px, py, _s, _mx, _my, _snx, _sny);
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static processData = function(_outSurf, _data, _output_index, _array_index) {
|
static processData = function(_outSurf, _data, _output_index, _array_index) { #region
|
||||||
var _dim = _data[0];
|
var _dim = _data[0];
|
||||||
var _amo = _data[1];
|
var _amo = _data[1];
|
||||||
var _ang = _data[2];
|
var _ang = _data[2];
|
||||||
|
@ -71,8 +57,9 @@ function Node_Stripe(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
|
||||||
var _pos = _data[4];
|
var _pos = _data[4];
|
||||||
var _rnd = _data[5];
|
var _rnd = _data[5];
|
||||||
|
|
||||||
var _clr0 = _data[8];
|
var _clr0 = _data[ 8];
|
||||||
var _clr1 = _data[9];
|
var _clr1 = _data[ 9];
|
||||||
|
var _rat = _data[10];
|
||||||
|
|
||||||
var _grad_use = _data[6];
|
var _grad_use = _data[6];
|
||||||
inputs[| 7].setVisible(_grad_use);
|
inputs[| 7].setVisible(_grad_use);
|
||||||
|
@ -87,28 +74,27 @@ function Node_Stripe(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) co
|
||||||
|
|
||||||
_outSurf = surface_verify(_outSurf, _dim[0], _dim[1], attrDepth());
|
_outSurf = surface_verify(_outSurf, _dim[0], _dim[1], attrDepth());
|
||||||
|
|
||||||
surface_set_target(_outSurf);
|
surface_set_shader(_outSurf, sh_stripe);
|
||||||
shader_set(shader);
|
shader_set_f("dimension", _dim[0], _dim[1]);
|
||||||
shader_set_uniform_f(uniform_dim, _dim[0], _dim[1]);
|
shader_set_f("position", _pos[0] / _dim[0], _pos[1] / _dim[1]);
|
||||||
shader_set_uniform_f(uniform_pos, _pos[0] / _dim[0], _pos[1] / _dim[1]);
|
shader_set_f("angle", degtorad(_ang));
|
||||||
shader_set_uniform_f(uniform_angle, degtorad(_ang));
|
shader_set_f("amount", _amo);
|
||||||
shader_set_uniform_f(uniform_amount, _amo);
|
shader_set_f("blend", _bnd);
|
||||||
shader_set_uniform_f(uniform_blend, _bnd);
|
shader_set_f("randomAmount", _rnd);
|
||||||
shader_set_uniform_f(uniform_rand, _rnd);
|
shader_set_f("ratio", _rat);
|
||||||
|
|
||||||
shader_set_uniform_f_array_safe(uniform_clr0, colToVec4(_clr0));
|
shader_set_f("color0", colToVec4(_clr0));
|
||||||
shader_set_uniform_f_array_safe(uniform_clr1, colToVec4(_clr1));
|
shader_set_f("color1", colToVec4(_clr1));
|
||||||
|
|
||||||
shader_set_uniform_i(uniform_grad_use, _grad_use);
|
shader_set_i("gradient_use", _grad_use);
|
||||||
shader_set_uniform_i(uniform_grad_blend, _gra.type);
|
shader_set_i("gradient_blend", _gra.type);
|
||||||
shader_set_uniform_f_array_safe(uniform_grad, _grad_color);
|
shader_set_f("gradient_color", _grad_color);
|
||||||
shader_set_uniform_f_array_safe(uniform_grad_time, _grad_time);
|
shader_set_f("gradient_time", _grad_time);
|
||||||
shader_set_uniform_i(uniform_grad_key, array_length(_gra.keys));
|
shader_set_i("gradient_keys", array_length(_gra.keys));
|
||||||
|
|
||||||
draw_sprite_ext(s_fx_pixel, 0, 0, 0, _dim[0], _dim[1], 0, c_white, 1);
|
draw_sprite_ext(s_fx_pixel, 0, 0, 0, _dim[0], _dim[1], 0, c_white, 1);
|
||||||
shader_reset();
|
surface_reset_shader();
|
||||||
surface_reset_target();
|
|
||||||
|
|
||||||
return _outSurf;
|
return _outSurf;
|
||||||
}
|
} #endregion
|
||||||
}
|
}
|
|
@ -409,8 +409,8 @@ function Panel_Collection() : PanelContent() constructor {
|
||||||
|
|
||||||
rootx = _x;
|
rootx = _x;
|
||||||
|
|
||||||
var bx = w - ui(44);
|
var bx = w - ui(40);
|
||||||
var by = ui(12);
|
var by = ui(9);
|
||||||
var bs = ui(32);
|
var bs = ui(32);
|
||||||
|
|
||||||
if(search_string == "") {
|
if(search_string == "") {
|
||||||
|
|
|
@ -99,7 +99,7 @@ function Panel_Palette() : PanelContent() constructor {
|
||||||
var by = title_height / 2 - ui(16 + !in_dialog * 2);
|
var by = title_height / 2 - ui(16 + !in_dialog * 2);
|
||||||
|
|
||||||
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, __txt("Refresh"), THEME.refresh, 1, COLORS._main_icon) == 2)
|
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, __txt("Refresh"), THEME.refresh, 1, COLORS._main_icon) == 2)
|
||||||
presetCollect();
|
__initPalette();
|
||||||
|
|
||||||
bx -= ui(32)
|
bx -= ui(32)
|
||||||
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, __txtx("palette_change_preview_size", "Change preview size"), THEME.icon_visibility, 1, COLORS._main_icon) == 2)
|
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, __txtx("palette_change_preview_size", "Change preview size"), THEME.icon_visibility, 1, COLORS._main_icon) == 2)
|
||||||
|
|
|
@ -8,12 +8,12 @@ function shell_execute(path, command, ref = noone) {
|
||||||
gml_pragma("forceinline");
|
gml_pragma("forceinline");
|
||||||
|
|
||||||
var txt = $"{path} {command}";
|
var txt = $"{path} {command}";
|
||||||
noti_status(txt, THEME.noti_icon_console,, ref);
|
if(global.PROC_ID == 0) noti_status(txt, THEME.noti_icon_console,, ref);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
var res = execute_shell(path, command);
|
var res = execute_shell(path, command);
|
||||||
noti_status("Execute shell complete", THEME.noti_icon_console,, ref);
|
if(global.PROC_ID == 0) noti_status("Execute shell complete", THEME.noti_icon_console,, ref);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
noti_warning($"Execute shell failed: {e}", THEME.noti_icon_console_failed, COLORS._main_value_negative, ref);
|
if(global.PROC_ID == 0) noti_warning($"Execute shell failed: {e}", THEME.noti_icon_console_failed, COLORS._main_value_negative, ref);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,13 +1,16 @@
|
||||||
|
function value_snap_real(val, snap = 1) {
|
||||||
|
gml_pragma("forceinline")
|
||||||
|
return snap == 0? val : round(val / snap) * snap;
|
||||||
|
}
|
||||||
|
|
||||||
function value_snap(val, snap = 1) {
|
function value_snap(val, snap = 1) {
|
||||||
gml_pragma("forceinline")
|
gml_pragma("forceinline")
|
||||||
|
|
||||||
if(!is_array(val)) {
|
if(!is_array(val))
|
||||||
if(snap == 0) return val;
|
return value_snap_real(val, snap);
|
||||||
return round(val / snap) * snap;
|
|
||||||
}
|
|
||||||
|
|
||||||
var _val = [];
|
var _val = [];
|
||||||
for( var i = 0, n = array_length(val); i < n; i++ )
|
for( var i = 0, n = array_length(val); i < n; i++ )
|
||||||
_val[i] = snap == 0? val[i] : round(val[i] / snap) * snap;
|
_val[i] = value_snap(val[i], snap);
|
||||||
return _val;
|
return _val;
|
||||||
}
|
}
|
|
@ -4,29 +4,28 @@
|
||||||
varying vec2 v_vTexcoord;
|
varying vec2 v_vTexcoord;
|
||||||
varying vec4 v_vColour;
|
varying vec4 v_vColour;
|
||||||
|
|
||||||
#define GRADIENT_LIMIT 128
|
|
||||||
|
|
||||||
uniform int gradient_use;
|
|
||||||
uniform int gradient_blend;
|
|
||||||
uniform vec4 gradient_color[GRADIENT_LIMIT];
|
|
||||||
uniform float gradient_time[GRADIENT_LIMIT];
|
|
||||||
uniform int gradient_keys;
|
|
||||||
|
|
||||||
uniform vec4 color0;
|
|
||||||
uniform vec4 color1;
|
|
||||||
|
|
||||||
uniform vec2 dimension;
|
|
||||||
uniform vec2 position;
|
|
||||||
uniform float angle;
|
|
||||||
uniform float amount;
|
|
||||||
uniform float rand;
|
|
||||||
uniform int blend;
|
|
||||||
|
|
||||||
#define PI 3.14159265359
|
#define PI 3.14159265359
|
||||||
|
|
||||||
float random (in vec2 st) { return fract(sin(dot(st.xy, vec2(12.9898, 78.233))) * 43758.5453123); }
|
uniform vec2 dimension;
|
||||||
|
uniform vec2 position;
|
||||||
|
uniform float angle;
|
||||||
|
uniform float amount;
|
||||||
|
uniform float ratio;
|
||||||
|
uniform float randomAmount;
|
||||||
|
uniform int blend;
|
||||||
|
|
||||||
vec3 rgb2hsv(vec3 c) {
|
#define GRADIENT_LIMIT 128
|
||||||
|
|
||||||
|
uniform int gradient_use;
|
||||||
|
uniform int gradient_blend;
|
||||||
|
uniform vec4 gradient_color[GRADIENT_LIMIT];
|
||||||
|
uniform float gradient_time[GRADIENT_LIMIT];
|
||||||
|
uniform int gradient_keys;
|
||||||
|
|
||||||
|
uniform vec4 color0;
|
||||||
|
uniform vec4 color1;
|
||||||
|
|
||||||
|
vec3 rgb2hsv(vec3 c) { #region
|
||||||
vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);
|
vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);
|
||||||
vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));
|
vec4 p = mix(vec4(c.bg, K.wz), vec4(c.gb, K.xy), step(c.b, c.g));
|
||||||
vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));
|
vec4 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));
|
||||||
|
@ -34,21 +33,21 @@ vec3 rgb2hsv(vec3 c) {
|
||||||
float d = q.x - min(q.w, q.y);
|
float d = q.x - min(q.w, q.y);
|
||||||
float e = 0.0000000001;
|
float e = 0.0000000001;
|
||||||
return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);
|
return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
vec3 hsv2rgb(vec3 c) {
|
vec3 hsv2rgb(vec3 c) { #region
|
||||||
vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);
|
vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);
|
||||||
vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);
|
vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);
|
||||||
return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);
|
return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
float hueDist(float a0, float a1, float t) {
|
float hueDist(float a0, float a1, float t) { #region
|
||||||
float da = fract(a1 - a0);
|
float da = fract(a1 - a0);
|
||||||
float ds = fract(2. * da) - da;
|
float ds = fract(2. * da) - da;
|
||||||
return a0 + ds * t;
|
return a0 + ds * t;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
vec3 hsvMix(vec3 c1, vec3 c2, float t) {
|
vec3 hsvMix(vec3 c1, vec3 c2, float t) { #region
|
||||||
vec3 h1 = rgb2hsv(c1);
|
vec3 h1 = rgb2hsv(c1);
|
||||||
vec3 h2 = rgb2hsv(c2);
|
vec3 h2 = rgb2hsv(c2);
|
||||||
|
|
||||||
|
@ -58,9 +57,9 @@ vec3 hsvMix(vec3 c1, vec3 c2, float t) {
|
||||||
h.z = mix(h1.z, h2.z, t);
|
h.z = mix(h1.z, h2.z, t);
|
||||||
|
|
||||||
return hsv2rgb(h);
|
return hsv2rgb(h);
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
vec4 gradientEval(in float prog) {
|
vec4 gradientEval(in float prog) { #region
|
||||||
vec4 col = vec4(0.);
|
vec4 col = vec4(0.);
|
||||||
|
|
||||||
for(int i = 0; i < GRADIENT_LIMIT; i++) {
|
for(int i = 0; i < GRADIENT_LIMIT; i++) {
|
||||||
|
@ -88,28 +87,26 @@ vec4 gradientEval(in float prog) {
|
||||||
}
|
}
|
||||||
|
|
||||||
return col;
|
return col;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
void main() {
|
float random (in vec2 st) { return fract(sin(dot(st.xy, vec2(12.9898, 78.233))) * 43758.5453123); }
|
||||||
vec2 pos = v_vTexcoord - position;
|
|
||||||
float ratio = dimension.x / dimension.y;
|
void main() { #region
|
||||||
float prog = pos.x * ratio * cos(angle) - pos.y * sin(angle);
|
vec2 pos = v_vTexcoord - position;
|
||||||
float _a = 1. / amount;
|
float aspect = dimension.x / dimension.y;
|
||||||
|
float prog = pos.x * aspect * cos(angle) - pos.y * sin(angle);
|
||||||
|
float _a = 1. / amount;
|
||||||
|
|
||||||
float slot = floor(prog / _a);
|
float slot = floor(prog / _a);
|
||||||
float ground = (slot + (random(vec2(slot + 0.)) * 2. - 1.) * rand * 0.5 + 0.) * _a;
|
float ground = (slot + (random(vec2(slot + 0.)) * 2. - 1.) * randomAmount * 0.5 + 0.) * _a;
|
||||||
float ceiling = (slot + (random(vec2(slot + 1.)) * 2. - 1.) * rand * 0.5 + 1.) * _a;
|
float ceiling = (slot + (random(vec2(slot + 1.)) * 2. - 1.) * randomAmount * 0.5 + 1.) * _a;
|
||||||
float _s = (prog - ground) / (ceiling - ground);
|
float _s = (prog - ground) / (ceiling - ground);
|
||||||
|
|
||||||
if(gradient_use == 0) {
|
if(gradient_use == 0) {
|
||||||
if(blend == 0) {
|
if(blend == 0) gl_FragColor = _s > ratio? color0 : color1;
|
||||||
gl_FragColor = _s > .5? color0 : color1;
|
else gl_FragColor = vec4(vec3(sin(_s * 2. * PI) * 0.5 + 0.5), 1.);
|
||||||
} else
|
|
||||||
gl_FragColor = vec4(vec3(sin(_s * 2. * PI) * 0.5 + 0.5), 1.);
|
|
||||||
} else {
|
} else {
|
||||||
if(_s > .5)
|
if(_s > ratio) gl_FragColor = vec4(gradientEval(random(vec2(slot))).rgb, 1.);
|
||||||
gl_FragColor = vec4(gradientEval(random(vec2(slot))).rgb, 1.);
|
else gl_FragColor = vec4(gradientEval(random(vec2(slot + 1.))).rgb, 1.);
|
||||||
else
|
|
||||||
gl_FragColor = vec4(gradientEval(random(vec2(slot + 1.))).rgb, 1.);
|
|
||||||
}
|
}
|
||||||
}
|
} #endregion
|
||||||
|
|
Loading…
Reference in a new issue