Colorize HSV, mask weight

This commit is contained in:
Tanasart 2023-02-17 17:31:33 +07:00
parent 92d33dc1ea
commit 0a79cf4456
27 changed files with 332 additions and 174 deletions

View file

@ -1446,9 +1446,10 @@
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Cards flipping.pxc","CopyToMask":-1,"filePath":"datafiles/Sample Projects",}, {"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Cards flipping.pxc","CopyToMask":-1,"filePath":"datafiles/Sample Projects",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Dice.pxc","CopyToMask":-1,"filePath":"datafiles/Sample Projects",}, {"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Dice.pxc","CopyToMask":-1,"filePath":"datafiles/Sample Projects",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Shiny gem.pxc","CopyToMask":-1,"filePath":"datafiles/Sample Projects",}, {"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Shiny gem.pxc","CopyToMask":-1,"filePath":"datafiles/Sample Projects",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"graphics x2.ai","CopyToMask":-1,"filePath":"datafiles/data/themes/default/graphics/icon",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"s_sort_24.png","CopyToMask":-1,"filePath":"datafiles/data/themes/default/graphics/icon",}, {"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"s_sort_24.png","CopyToMask":-1,"filePath":"datafiles/data/themes/default/graphics/icon",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"s_reverse.png","CopyToMask":-1,"filePath":"datafiles/data/themes/default/graphics/icon",}, {"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"s_reverse.png","CopyToMask":-1,"filePath":"datafiles/data/themes/default/graphics/icon",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"graphics x2.ai","CopyToMask":-1,"filePath":"datafiles/data/themes/default/graphics/icon",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"s_workshop_download.png","CopyToMask":-1,"filePath":"datafiles/data/themes/default/graphics/icon",},
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"default.zip","CopyToMask":-1,"filePath":"datafiles/data/themes",}, {"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"default.zip","CopyToMask":-1,"filePath":"datafiles/data/themes",},
], ],
"MetaData": { "MetaData": {

View file

@ -29,15 +29,19 @@
var txt = get_text("new_collection_create", "Create collection"); var txt = get_text("new_collection_create", "Create collection");
var icon = THEME.accept; var icon = THEME.accept;
var clr = COLORS._main_value_positive;
if(updating != noone) { if(updating != noone) {
txt = get_text("collection_update", "Update collection"); txt = get_text("collection_update", "Update collection");
} }
if(ugc == 1) { if(ugc == 1) {
txt = get_text("workshop_upload", "Upload to Steam Workshop"); txt = get_text("workshop_upload", "Upload to Steam Workshop");
icon = THEME.workshop_upload; icon = THEME.workshop_upload;
clr = c_white;
} else if(ugc == 2) { } else if(ugc == 2) {
txt = get_text("workshop_update", "Update Steam Workshop"); txt = get_text("workshop_update", "Update Steam Workshop");
icon = THEME.workshop_update; icon = THEME.workshop_update;
clr = c_white;
} }
if(ugc_loading) { if(ugc_loading) {
@ -48,7 +52,7 @@
if(STEAM_UGC_ITEM_UPLOADING == false) if(STEAM_UGC_ITEM_UPLOADING == false)
instance_destroy(); instance_destroy();
} else { } else {
if(buttonInstant(THEME.button_hide, bx, by, bw, bh, mouse_ui, sFOCUS, sHOVER, txt, icon, 0, COLORS._main_value_positive) == 2) { if(buttonInstant(THEME.button_hide, bx, by, bw, bh, mouse_ui, sFOCUS, sHOVER, txt, icon, 0, clr) == 2) {
if(meta.author_steam_id == 0) if(meta.author_steam_id == 0)
meta.author_steam_id = STEAM_USER_ID; meta.author_steam_id = STEAM_USER_ID;
@ -73,6 +77,7 @@
steam_ugc_create_collection(updating); steam_ugc_create_collection(updating);
ugc_loading = true; ugc_loading = true;
} else if(ugc == 2) { } else if(ugc == 2) {
PANEL_COLLECTION.saveCollection(updating.path, false, updating.meta);
steam_ugc_update_collection(updating); steam_ugc_update_collection(updating);
ugc_loading = true; ugc_loading = true;
} else } else

View file

@ -28,31 +28,30 @@ event_inherited();
draw_set_text(f_p0, fa_center, fa_center, COLORS._main_text); draw_set_text(f_p0, fa_center, fa_center, COLORS._main_text);
for(var i = 0; i < array_length(menu); i++) { for(var i = 0; i < array_length(menu); i++) {
if(!is_array(menu[i])) { var menuItem = menu[i];
if(!is_array(menuItem)) {
dialog_h += ui(8); dialog_h += ui(8);
continue; continue;
} }
draw_set_font(f_p0); draw_set_font(f_p0);
var ww = string_width(menu[i][0]) + ui(64); var ww = string_width(menuItem[0]) + ui(64);
if(array_length(menu[i]) > 2) { if(array_length(menuItem) > 2) {
if(menu[i][2] == ">") { if(is_array(menuItem[2])) {
var _key = find_hotkey(menuItem[2][0], menuItem[2][1]);
} else if(is_array(menu[i][2])) {
var _key = find_hotkey(menu[i][2][0], menu[i][2][1]);
if(_key) { if(_key) {
draw_set_font(f_p1); draw_set_font(f_p1);
var ss = key_get_name(_key.key, _key.modi); var ss = key_get_name(_key.key, _key.modi);
ww += string_width(ss) + ui(16); ww += string_width(ss) + ui(16);
} }
} }
} else if(is_array(menu[i][1])) { } else if(is_array(menuItem[1])) {
var amo = array_length(menu[i][1]); var amo = array_length(menuItem[1]);
ww = max(ww, ui(16) + amo * (hght + ui(4))); ww = max(ww, ui(16) + amo * (hght + ui(4)));
} }
dialog_w = max(dialog_w, ww); dialog_w = max(dialog_w, ww);
if(is_array(menu[i][1])) if(is_array(menuItem[1]))
dialog_h += hght; dialog_h += hght;
dialog_h += hght; dialog_h += hght;
} }

View file

@ -1,7 +1,16 @@
/// @description init /// @description init
#region pos #region pos
var hght = line_height(f_p0, 8); var hght = line_height(f_p0, 8);
var hh = array_length(scrollbox.data) * hght; var hh = 0;
for( var i = 0; i < array_length(scrollbox.data); i++ ) {
if(scrollbox.data[i] == -1) {
hh += ui(8);
continue;
}
hh += hght;
}
dialog_h = min(max_h, hh); dialog_h = min(max_h, hh);
sc_content.resize(dialog_w, dialog_h); sc_content.resize(dialog_w, dialog_h);

View file

@ -9,6 +9,7 @@ event_inherited();
selecting = -1; selecting = -1;
scrollbox = noone; scrollbox = noone;
initVal = 0;
anchor = ANCHOR.top | ANCHOR.left; anchor = ANCHOR.top | ANCHOR.left;
@ -16,21 +17,31 @@ event_inherited();
draw_clear_alpha(COLORS.panel_bg_clear, 0); draw_clear_alpha(COLORS.panel_bg_clear, 0);
var hght = line_height(f_p0, 8); var hght = line_height(f_p0, 8);
var data = scrollbox.data; var data = scrollbox.data;
var _h = array_length(data) * hght;
var _dw = sc_content.surface_w; var _dw = sc_content.surface_w;
var _h = 0;
var _ly = _y;
var hovering = -1;
for(var i = 0; i < array_length(data); i++) { for(var i = 0; i < array_length(data); i++) {
var _ly = _y + i * hght; if(data[i] == -1) {
draw_sprite_stretched(THEME.menu_separator, 0, ui(8), _ly, _dw - ui(16), ui(6));
_ly += ui(8);
_h += ui(8);
continue;
}
if(sHOVER && sc_content.hover && point_in_rectangle(_m[0], _m[1], 0, _ly + 1, _dw, _ly + hght - 1)) { if(sHOVER && sc_content.hover && point_in_rectangle(_m[0], _m[1], 0, _ly + 1, _dw, _ly + hght - 1)) {
selecting = i; selecting = i;
hovering = i;
} }
if(selecting == i) { if(selecting == i) {
draw_sprite_stretched_ext(THEME.textbox, 3, 0, _ly, _dw, hght, COLORS.dialog_menubox_highlight, 1); draw_sprite_stretched_ext(THEME.textbox, 3, 0, _ly, _dw, hght, COLORS.dialog_menubox_highlight, 1);
if(sFOCUS && (mouse_press(mb_left) || keyboard_check_pressed(vk_enter))) { if(sFOCUS && (mouse_press(mb_left) || keyboard_check_pressed(vk_enter))) {
scrollbox.onModify(i); initVal = i;
instance_destroy(); instance_destroy();
} }
} }
@ -40,8 +51,16 @@ event_inherited();
draw_text_cut(_dw / 2, _ly + hght / 2, data[i], _dw); draw_text_cut(_dw / 2, _ly + hght / 2, data[i], _dw);
else if(align == fa_left) else if(align == fa_left)
draw_text_cut(ui(8), _ly + hght / 2, data[i], _dw); draw_text_cut(ui(8), _ly + hght / 2, data[i], _dw);
_ly += hght;
_h += hght;
} }
UNDO_HOLDING = true;
if(hovering > -1) scrollbox.onModify(hovering);
else scrollbox.onModify(initVal);
UNDO_HOLDING = false;
if(sFOCUS) { if(sFOCUS) {
if(keyboard_check_pressed(vk_up)) { if(keyboard_check_pressed(vk_up)) {
selecting--; selecting--;

View file

@ -1,4 +1,5 @@
/// @description init /// @description init
event_inherited(); event_inherited();
scrollbox.onModify(initVal);
scrollbox.open = false; scrollbox.open = false;

View file

@ -81,8 +81,11 @@ if !ready exit;
var bx = x1 - ui(32); var bx = x1 - ui(32);
var by = y0 - ui(32); var by = y0 - ui(32);
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), mouse_ui, sFOCUS, sHOVER, "Open Steam Workshop", THEME.steam) == 2) { if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), mouse_ui, sFOCUS, sHOVER, "Open Steam Workshop", THEME.steam) == 2)
steam_activate_overlay_browser("https://steamcommunity.com/app/2299510/workshop/") steam_activate_overlay_browser("https://steamcommunity.com/app/2299510/workshop/");
}
bx -= ui(36);
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), mouse_ui, sFOCUS, sHOVER, "Refresh content", THEME.refresh) == 2)
steamUCGload();
} }
#endregion #endregion

View file

@ -185,6 +185,7 @@
globalvar STEAM_ENABLED, STEAM_APP_ID, STEAM_USER_ID, STEAM_USERNAME; globalvar STEAM_ENABLED, STEAM_APP_ID, STEAM_USER_ID, STEAM_USERNAME;
globalvar STEAM_UGC_ITEM_UPLOADING, STEAM_UGC_ITEM_ID, STEAM_UGC_ITEM_FILE, STEAM_UGC_UPDATE_HANDLE; globalvar STEAM_UGC_ITEM_UPLOADING, STEAM_UGC_ITEM_ID, STEAM_UGC_ITEM_FILE, STEAM_UGC_UPDATE_HANDLE;
globalvar STEAM_UGC_SUBMIT_ID, STEAM_UGC_UPDATE_MAP, STEAM_UGC_PUBLISH_ID, STEAM_UGC_UPDATE, STEAM_UGC_TYPE; globalvar STEAM_UGC_SUBMIT_ID, STEAM_UGC_UPDATE_MAP, STEAM_UGC_PUBLISH_ID, STEAM_UGC_UPDATE, STEAM_UGC_TYPE;
globalvar STEAM_SUB_ID;
enum STEAM_UGC_FILE_TYPE { enum STEAM_UGC_FILE_TYPE {
collection, collection,
@ -193,6 +194,7 @@
} }
STEAM_UGC_TYPE = STEAM_UGC_FILE_TYPE.collection; STEAM_UGC_TYPE = STEAM_UGC_FILE_TYPE.collection;
STEAM_SUB_ID = 0;
STEAM_USER_ID = 0; STEAM_USER_ID = 0;
STEAM_USERNAME = ""; STEAM_USERNAME = "";

View file

@ -12,9 +12,9 @@ if(string(ev_id) == string(STEAM_UGC_ITEM_ID) && ev_type == "ugc_create_item") {
var tgs = array_clone(STEAM_UGC_ITEM_FILE.meta.tags); var tgs = array_clone(STEAM_UGC_ITEM_FILE.meta.tags);
switch(STEAM_UGC_TYPE) { switch(STEAM_UGC_TYPE) {
case STEAM_UGC_FILE_TYPE.collection : array_insert(tgs, 0, "Collection"); break; case STEAM_UGC_FILE_TYPE.collection : array_insert_unique(tgs, 0, "Collection"); break;
case STEAM_UGC_FILE_TYPE.project : array_insert(tgs, 0, "Project"); break; case STEAM_UGC_FILE_TYPE.project : array_insert_unique(tgs, 0, "Project"); break;
case STEAM_UGC_FILE_TYPE.node_preset : array_insert(tgs, 0, "Node preset"); break; case STEAM_UGC_FILE_TYPE.node_preset : array_insert_unique(tgs, 0, "Node preset"); break;
} }
steam_ugc_set_item_tags(STEAM_UGC_UPDATE_HANDLE, tgs); steam_ugc_set_item_tags(STEAM_UGC_UPDATE_HANDLE, tgs);
@ -43,10 +43,12 @@ if(string(ev_id) == string(STEAM_UGC_SUBMIT_ID)) {
log_message("WORKSHOP", type + " uploaded", THEME.workshop_upload); log_message("WORKSHOP", type + " uploaded", THEME.workshop_upload);
PANEL_MENU.setNotiIcon(THEME.workshop_upload); PANEL_MENU.setNotiIcon(THEME.workshop_upload);
} }
STEAM_SUB_ID = steam_ugc_subscribe_item(STEAM_UGC_PUBLISH_ID);
exit; exit;
} }
switch(async_load[? "result"]) { switch(async_load[? "result"]) { #region error
case 2: log_warning("WORKSHOP", "Generic failure."); break; case 2: log_warning("WORKSHOP", "Generic failure."); break;
case 3: log_warning("WORKSHOP", "Your Steam client doesn't have a connection to the back-end."); break; case 3: log_warning("WORKSHOP", "Your Steam client doesn't have a connection to the back-end."); break;
case 5: log_warning("WORKSHOP", "Password/ticket is invalid."); break; case 5: log_warning("WORKSHOP", "Password/ticket is invalid."); break;
@ -153,5 +155,5 @@ if(string(ev_id) == string(STEAM_UGC_SUBMIT_ID)) {
case 106: log_warning("WORKSHOP", "This Game Server Login Token (GSLT) has expired from disuse; it can be reset for use."); break; case 106: log_warning("WORKSHOP", "This Game Server Login Token (GSLT) has expired from disuse; it can be reset for use."); break;
case 107: log_warning("WORKSHOP", "user doesn't have enough wallet funds to complete the action"); break; case 107: log_warning("WORKSHOP", "user doesn't have enough wallet funds to complete the action"); break;
case 108: log_warning("WORKSHOP", "There are too many of this thing pending already"); break; case 108: log_warning("WORKSHOP", "There are too many of this thing pending already"); break;
} } #endregion
} }

View file

@ -59,6 +59,12 @@ function array_push_unique(arr, val) {
array_push(arr, val); array_push(arr, val);
} }
function array_insert_unique(arr, ind, val) {
if(array_exists(arr, val)) return;
array_insert(arr, ind, val);
}
function array_append(arr, arr0) { function array_append(arr, arr0) {
for( var i = 0; i < array_length(arr0); i++ ) for( var i = 0; i < array_length(arr0); i++ )
array_push(arr, arr0[i]); array_push(arr, arr0[i]);

View file

@ -24,3 +24,10 @@ function menuCall(_x = mouse_mx, _y = mouse_my, menu = []) {
dia.setMenu(menu); dia.setMenu(menu);
return dia; return dia;
} }
function menuItem(name, func, spr = noone, hotkey = noone) constructor {
self.name = name;
self.func = func;
self.spr = spr;
self.hotkey = hotkey;
}

View file

@ -1,40 +1,24 @@
globalvar BLEND_TYPES; globalvar BLEND_TYPES;
BLEND_TYPES = [ "Normal", "Add", "Subtract", "Multiply", "Screen", "Contrast", "Overlay", "Hue", "Saturation", "Luminosity", "Maximum", "Minimum" ]; BLEND_TYPES = [ "Normal", "Add", "Subtract", "Multiply", "Screen", "Overlay", "Hue", "Saturation", "Luminosity", "Maximum", "Minimum" ];
enum BLEND_MODE {
normal,
add,
subtract,
multiply,
screen,
contrast,
overlay,
hue,
sat,
luma,
maxx,
minn,
}
function draw_surface_blend(background, foreground, blend, alpha, _pre_alp = true, _mask = 0, tile = 0) { function draw_surface_blend(background, foreground, blend, alpha, _pre_alp = true, _mask = 0, tile = 0) {
if(!is_surface(background)) return; if(!is_surface(background)) return;
var sh = sh_blend_normal var sh = sh_blend_normal
switch(blend) { switch(BLEND_TYPES[blend]) {
case BLEND_MODE.normal : sh = sh_blend_normal break; case "Normal" : sh = sh_blend_normal break;
case BLEND_MODE.add : sh = sh_blend_add; break; case "Add" : sh = sh_blend_add; break;
case BLEND_MODE.subtract : sh = sh_blend_subtract; break; case "Subtract" : sh = sh_blend_subtract; break;
case BLEND_MODE.multiply : sh = sh_blend_multiply; break; case "Multiply" : sh = sh_blend_multiply; break;
case BLEND_MODE.screen : sh = sh_blend_screen; break; case "Screen" : sh = sh_blend_screen; break;
case BLEND_MODE.contrast : sh = sh_blend_contrast; break; case "Overlay" : sh = sh_blend_overlay; break;
case BLEND_MODE.overlay : sh = sh_blend_overlay; break; case "Hue" : sh = sh_blend_hue; break;
case BLEND_MODE.hue : sh = sh_blend_hue; break; case "Saturation" : sh = sh_blend_sat; break;
case BLEND_MODE.sat : sh = sh_blend_sat; break; case "Luminosity" : sh = sh_blend_luma; break;
case BLEND_MODE.luma : sh = sh_blend_luma; break;
case BLEND_MODE.maxx : sh = sh_blend_max; break; case "Maximum" : sh = sh_blend_max; break;
case BLEND_MODE.minn : sh = sh_blend_min; break; case "Minimum" : sh = sh_blend_min; break;
default: return;
} }
var uniform_foreground = shader_get_sampler_index(sh, "fore"); var uniform_foreground = shader_get_sampler_index(sh, "fore");

View file

@ -30,7 +30,7 @@
globalvar VERSION, SAVEFILE_VERSION, VERSION_STRING; globalvar VERSION, SAVEFILE_VERSION, VERSION_STRING;
VERSION = 1130; VERSION = 1130;
SAVEFILE_VERSION = 1300; SAVEFILE_VERSION = 1300;
VERSION_STRING = "1.13.pr5"; VERSION_STRING = "1.13.pr7";
globalvar NODES, NODE_MAP, APPEND_MAP, HOTKEYS, HOTKEY_CONTEXT; globalvar NODES, NODE_MAP, APPEND_MAP, HOTKEYS, HOTKEY_CONTEXT;

View file

@ -1,5 +1,5 @@
function mask_apply(original, edited, mask, mix = 1) { function mask_apply(original, edited, mask, mix = 1) {
if(!is_surface(mask) || mix == 1) return edited; if(!is_surface(mask) && mix == 1) return edited;
var _s = surface_create_size(original); var _s = surface_create_size(original);

View file

@ -103,6 +103,23 @@ function MetaDataManager() constructor {
_w = max(_w, string_width_ext(_ver, -1, ww)); _w = max(_w, string_width_ext(_ver, -1, ww));
} }
if(array_length(tags)) {
draw_set_font(f_p0);
_h += ui(8);
var tx = 0;
var hh = line_height(f_p0, ui(4));
var th = hh;
for( var i = 0; i < array_length(tags); i++ ) {
var ww = string_width(tags[i]) + ui(16);
if(tx + ww + ui(2) > _w - ui(16)) {
tx = 0;
th += hh + ui(2);
}
tx += ww + ui(2);
}
_h += th;
}
var mx = min(mouse_mx + ui(16), WIN_W - (_w + ui(16))); var mx = min(mouse_mx + ui(16), WIN_W - (_w + ui(16)));
var my = min(mouse_my + ui(16), WIN_H - (_h + ui(16))); var my = min(mouse_my + ui(16), WIN_H - (_h + ui(16)));
@ -146,6 +163,27 @@ function MetaDataManager() constructor {
draw_text_ext(mx + ui(8), ty, _ver, -1, _w); draw_text_ext(mx + ui(8), ty, _ver, -1, _w);
ty += string_height_ext(_ver, -1, _w); ty += string_height_ext(_ver, -1, _w);
} }
if(array_length(tags)) {
draw_set_text(f_p0, fa_left, fa_center, COLORS._main_text);
ty += ui(8);
var tx = 0;
var hh = line_height(f_p0, ui(4));
for( var i = 0; i < array_length(tags); i++ ) {
var ww = string_width(tags[i]) + ui(16);
if(tx + ww + ui(2) > _w - ui(16)) {
tx = 0;
ty += hh + ui(2);
}
draw_sprite_stretched_ext(THEME.group_label, 0, mx + ui(8) + tx, ty, ww, hh, COLORS._main_icon, 1);
draw_text(mx + ui(8) + tx + ui(8), ty + hh / 2, tags[i]);
tx += ww + ui(2);
}
}
} }
} }

View file

@ -1,16 +1,5 @@
function Node_create_Blend(_x, _y, _group = -1, _param = "") { function Node_create_Blend(_x, _y, _group = -1, _param = "") {
var node = new Node_Blend(_x, _y, _group); var node = new Node_Blend(_x, _y, _group);
switch(_param) {
case "normal" : node.inputs[| 2].setValue(BLEND_MODE.normal) break;
case "add" : node.inputs[| 2].setValue(BLEND_MODE.add); break;
case "subtract" : node.inputs[| 2].setValue(BLEND_MODE.subtract); break;
case "multiply" : node.inputs[| 2].setValue(BLEND_MODE.multiply); break;
case "overlay" : node.inputs[| 2].setValue(BLEND_MODE.overlay); break;
case "screen" : node.inputs[| 2].setValue(BLEND_MODE.screen); break;
case "maxx" : node.inputs[| 2].setValue(BLEND_MODE.maxx); break;
case "minn" : node.inputs[| 2].setValue(BLEND_MODE.minn); break;
}
return node; return node;
} }
@ -81,7 +70,7 @@ function Node_Blend(_x, _y, _group = -1) : Node_Processor(_x, _y, _group) constr
inputs[| 10].setVisible(_tile == 0); inputs[| 10].setVisible(_tile == 0);
inputs[| 11].setVisible(_tile == 0); inputs[| 11].setVisible(_tile == 0);
if(_tile == 0) { if(_tile == 0 && is_surface(_fore)) {
ww = surface_get_width(_back); ww = surface_get_width(_back);
hh = surface_get_height(_back); hh = surface_get_height(_back);
@ -120,16 +109,18 @@ function Node_Blend(_x, _y, _group = -1) : Node_Processor(_x, _y, _group) constr
hh = surface_get_height(_back); hh = surface_get_height(_back);
break; break;
case 1 : case 1 :
if(is_surface(_foreDraw)) {
ww = surface_get_width(_foreDraw); ww = surface_get_width(_foreDraw);
hh = surface_get_height(_foreDraw); hh = surface_get_height(_foreDraw);
}
break; break;
case 2 : case 2 :
ww = surface_get_width(_mask); ww = surface_get_width(_mask);
hh = surface_get_height(_mask); hh = surface_get_height(_mask);
break; break;
case 3 : case 3 :
ww = max(surface_get_width(_back), surface_get_width(_fore), surface_get_width(_mask)); ww = max(surface_get_width(_back), is_surface(_fore)? surface_get_width(_fore) : 1, surface_get_width(_mask));
hh = max(surface_get_height(_back), surface_get_height(_fore), surface_get_height(_mask)); hh = max(surface_get_height(_back), is_surface(_fore)? surface_get_height(_fore) : 1, surface_get_height(_mask));
break; break;
case 4 : case 4 :
ww = _out_dim[0]; ww = _out_dim[0];

View file

@ -6,7 +6,7 @@ function Node_Colorize(_x, _y, _group = -1) : Node_Processor(_x, _y, _group) con
uniform_color = shader_get_uniform(shader, "gradient_color"); uniform_color = shader_get_uniform(shader, "gradient_color");
uniform_time = shader_get_uniform(shader, "gradient_time"); uniform_time = shader_get_uniform(shader, "gradient_time");
uniform_shift = shader_get_uniform(shader, "gradient_shift"); uniform_shift = shader_get_uniform(shader, "gradient_shift");
uniform_key = shader_get_uniform(shader, "keys"); uniform_key = shader_get_uniform(shader, "gradient_keys");
uniform_alpha = shader_get_uniform(shader, "multiply_alpha"); uniform_alpha = shader_get_uniform(shader, "multiply_alpha");
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);

View file

@ -9,7 +9,7 @@ function Node_Palette_Sort(_x, _y, _group = -1) : Node(_x, _y, _group) construct
.setVisible(true, true); .setVisible(true, true);
inputs[| 1] = nodeValue("Order", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0) inputs[| 1] = nodeValue("Order", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0)
.setDisplay(VALUE_DISPLAY.enum_button, [ "Brightness", "Hue (HSV)", "Saturation (SHV)", "Value (VHS)", "Red (RGB)", "Green (GBR)", "Blue (BRG)" ]) .setDisplay(VALUE_DISPLAY.enum_button, [ "Brightness", -1, "Hue (HSV)", "Saturation (SHV)", "Value (VHS)", -1, "Red (RGB)", "Green (GBR)", "Blue (BRG)" ])
.rejectArray(); .rejectArray();
inputs[| 2] = nodeValue("Reverse", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false); inputs[| 2] = nodeValue("Reverse", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);

View file

@ -30,6 +30,12 @@ function Panel_Collection() : PanelContent() constructor {
data_path = ""; data_path = "";
static initMenu = function() { static initMenu = function() {
if(_menu_node == noone) return;
var meta = _menu_node.getMetadata();
contentMenu = [];
if(meta == noone || !meta.steam) {
contentMenu = [ contentMenu = [
[ get_text("panel_collection_replace", "Replace with selected"), function() { [ get_text("panel_collection_replace", "Replace with selected"), function() {
saveCollection(_menu_node.path, false, _menu_node.meta); saveCollection(_menu_node.path, false, _menu_node.meta);
@ -47,15 +53,11 @@ function Panel_Collection() : PanelContent() constructor {
[ get_text("delete", "Delete"), function() { [ get_text("delete", "Delete"), function() {
file_delete(_menu_node.path); file_delete(_menu_node.path);
refreshContext(); refreshContext();
} ], } ]
]; ];
} else if(STEAM_ENABLED) {
if(DEMO) array_delete(contentMenu, 0, 3);
else if(_menu_node && STEAM_ENABLED) {
var meta = _menu_node.getMetadata();
if(!meta.steam) { if(!meta.steam) {
array_insert(contentMenu, 2, [ get_text("panel_collection_workshop_upload", "Upload to Steam Workshop") + "...", function() { array_push(contentMenu, [ get_text("panel_collection_workshop_upload", "Upload to Steam Workshop") + "...", function() {
var dia = dialogCall(o_dialog_file_name_collection, mouse_mx + ui(8), mouse_my + ui(-320)); var dia = dialogCall(o_dialog_file_name_collection, mouse_mx + ui(8), mouse_my + ui(-320));
var meta = _menu_node.getMetadata(); var meta = _menu_node.getMetadata();
if(meta != noone && meta != undefined) if(meta != noone && meta != undefined)
@ -65,10 +67,9 @@ function Panel_Collection() : PanelContent() constructor {
dia.updating = _menu_node; dia.updating = _menu_node;
dia.expand(); dia.expand();
} ]); } ]);
} } else {
if(meta.author_steam_id == STEAM_USER_ID && meta.file_id != 0) {
if(meta.steam && meta.author_steam_id == STEAM_USER_ID && meta.file_id != 0) { array_push(contentMenu, [get_text("panel_collection_workshop_update", "Update Steam Workshop content") + "...", function() {
array_insert(contentMenu, 2, [get_text("panel_collection_workshop_update", "Update Steam Workshop content") + "...", function() {
var dia = dialogCall(o_dialog_file_name_collection, mouse_mx + ui(8), mouse_my + ui(-320)); var dia = dialogCall(o_dialog_file_name_collection, mouse_mx + ui(8), mouse_my + ui(-320));
var meta = _menu_node.getMetadata(); var meta = _menu_node.getMetadata();
if(meta != noone && meta != undefined) if(meta != noone && meta != undefined)
@ -79,6 +80,21 @@ function Panel_Collection() : PanelContent() constructor {
dia.expand(); dia.expand();
} ]); } ]);
} }
array_push(contentMenu, ["Unsubscribe", function() {
var meta = _menu_node.getMetadata();
var del_id = meta.file_id;
for( var i = 0; i < ds_list_size(STEAM_COLLECTION); i++ ) {
print(STEAM_COLLECTION[| i].meta.file_id);
if(STEAM_COLLECTION[| i].getMetadata().file_id == del_id) {
ds_list_delete(STEAM_COLLECTION, i);
break;
}
}
steam_ugc_unsubscribe_item(del_id);
}]);
}
} }
} }
initMenu(); initMenu();
@ -146,7 +162,7 @@ function Panel_Collection() : PanelContent() constructor {
if(mouse_press(mb_left, pFOCUS)) if(mouse_press(mb_left, pFOCUS))
file_dragging = _node; file_dragging = _node;
if(mouse_press(mb_right, pFOCUS)) { if(!DEMO && mouse_press(mb_right, pFOCUS)) {
_menu_node = _node; _menu_node = _node;
initMenu(); initMenu();
var dia = dialogCall(o_dialog_menubox, mouse_mx + 8, mouse_my + 8); var dia = dialogCall(o_dialog_menubox, mouse_mx + 8, mouse_my + 8);
@ -220,7 +236,7 @@ function Panel_Collection() : PanelContent() constructor {
if(mouse_press(mb_left, pFOCUS)) if(mouse_press(mb_left, pFOCUS))
file_dragging = _node; file_dragging = _node;
if(mouse_press(mb_right, pFOCUS)) { if(!DEMO && mouse_press(mb_right, pFOCUS)) {
_menu_node = _node; _menu_node = _node;
initMenu(); initMenu();
var dia = dialogCall(o_dialog_menubox, mouse_mx + ui(8), mouse_my + ui(8)); var dia = dialogCall(o_dialog_menubox, mouse_mx + ui(8), mouse_my + ui(8));
@ -286,6 +302,9 @@ function Panel_Collection() : PanelContent() constructor {
function refreshContext() { function refreshContext() {
context.scan([".json", ".pxcc"]); context.scan([".json", ".pxcc"]);
if(STEAM_ENABLED)
steamUCGload();
} }
function saveCollection(_name, save_surface = true, metadata = noone) { function saveCollection(_name, save_surface = true, metadata = noone) {

View file

@ -48,6 +48,36 @@ function Panel_Menu() : PanelContent() constructor {
array_delete(menu_file, 1, 4); array_delete(menu_file, 1, 4);
} }
menu_help = [ get_text("panel_menu_help", "Help"), [
[ get_text("panel_menu_help_video", "Tutorial videos"), function() {
url_open("https://www.youtube.com/@makhamdev");
} ],
[ get_text("panel_menu_help_wiki", "Community Wiki"), function() {
url_open("https://pixel-composer.fandom.com/wiki/Pixel_Composer_Wiki");
} ],
-1,
[ get_text("panel_menu_itch", "itch.io page"), function() {
url_open("https://makham.itch.io/pixel-composer");
} ],
[ get_text("panel_menu_steam", "Steam page"), function() {
url_open("https://store.steampowered.com/app/2299510/Pixel_Composer");
} ],
-1,
[ get_text("panel_menu_directory", "Open local directory"), function() {
shellOpenExplorer(DIRECTORY);
} ],
[ get_text("panel_menu_reset_default", "Reset default collection, assets"), function() {
zip_unzip("data/Collections.zip", DIRECTORY + "Collections");
zip_unzip("data/Assets.zip", DIRECTORY + "Assets");
} ],
]];
menu_help_steam = array_clone(menu_help);
array_push(menu_help_steam[1], -1,
[ get_text("panel_menu_steam_workshop", "Steam Workshop"), function() {
steam_activate_overlay_browser("https://steamcommunity.com/app/2299510/workshop/");
} ]);
menus = [ menus = [
[ get_text("panel_menu_file", "File"), menu_file], [ get_text("panel_menu_file", "File"), menu_file],
[ get_text("panel_menu_edit", "Edit"), [ [ get_text("panel_menu_edit", "Edit"), [
@ -112,29 +142,7 @@ function Panel_Menu() : PanelContent() constructor {
PREF_SAVE(); PREF_SAVE();
} ], } ],
]], ]],
[ get_text("panel_menu_help", "Help"), [ menu_help,
[ get_text("panel_menu_help_video", "Tutorial videos"), function() {
url_open("https://www.youtube.com/@makhamdev");
} ],
[ get_text("panel_menu_help_wiki", "Community Wiki"), function() {
url_open("https://pixel-composer.fandom.com/wiki/Pixel_Composer_Wiki");
} ],
-1,
[ get_text("panel_menu_itch", "itch.io page"), function() {
url_open("https://makham.itch.io/pixel-composer");
} ],
[ get_text("panel_menu_steam", "Steam page"), function() {
url_open("https://store.steampowered.com/app/2299510/Pixel_Composer");
} ],
-1,
[ get_text("panel_menu_directory", "Open local directory"), function() {
shellOpenExplorer(DIRECTORY);
} ],
[ get_text("panel_menu_reset_default", "Reset default collection, assets"), function() {
zip_unzip("data/Collections.zip", DIRECTORY + "Collections");
zip_unzip("data/Assets.zip", DIRECTORY + "Assets");
} ],
]],
] ]
if(TESTING) { if(TESTING) {
@ -220,11 +228,12 @@ function Panel_Menu() : PanelContent() constructor {
draw_sprite_ui_uniform(THEME.icon_24, 0, h / 2, h / 2, 1, c_white); draw_sprite_ui_uniform(THEME.icon_24, 0, h / 2, h / 2, 1, c_white);
var xx = h; var xx = h;
menus[6] = STEAM_ENABLED? menu_help_steam : menu_help;
if(pHOVER && point_in_rectangle(mx, my, 0, 0, ui(40), ui(32))) { if(pHOVER && point_in_rectangle(mx, my, 0, 0, ui(40), ui(32))) {
if(mouse_press(mb_left, pFOCUS)) { if(mouse_press(mb_left, pFOCUS))
dialogCall(o_dialog_about); dialogCall(o_dialog_about);
} }
}
for(var i = 0; i < array_length(menus); i++) { for(var i = 0; i < array_length(menus); i++) {
draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text); draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text);

View file

@ -2,6 +2,7 @@ function scrollBox(_data, _onModify) : widget() constructor {
onModify = _onModify; onModify = _onModify;
data_list = _data; data_list = _data;
data = []; data = [];
curr_text = 0;
open = false; open = false;
open_rx = 0; open_rx = 0;
@ -11,14 +12,15 @@ function scrollBox(_data, _onModify) : widget() constructor {
extra_button = noone; extra_button = noone;
static trigger = function() { static trigger = function() {
if(is_method(data_list)) if(is_method(data_list)) data = data_list();
data = data_list(); else data = data_list;
else
data = data_list; var ind = array_find(data, curr_text);
open = true; open = true;
with(dialogCall(o_dialog_scrollbox, x + open_rx, y + open_ry)) { with(dialogCall(o_dialog_scrollbox, x + open_rx, y + open_ry)) {
scrollbox = other; scrollbox = other;
initVal = ind;
dialog_w = other.w; dialog_w = other.w;
align = other.align; align = other.align;
} }
@ -30,6 +32,7 @@ function scrollBox(_data, _onModify) : widget() constructor {
open_rx = _rx; open_rx = _rx;
open_ry = _ry; open_ry = _ry;
h = _h; h = _h;
curr_text = _text;
w = _w; w = _w;
if(extra_button != noone) { if(extra_button != noone) {

View file

@ -9,6 +9,7 @@ function steam_ugc_create_collection(file) {
directory_destroy(DIRECTORY + "steamUGC"); directory_destroy(DIRECTORY + "steamUGC");
directory_create(DIRECTORY + "steamUGC"); directory_create(DIRECTORY + "steamUGC");
file_copy(file.path, DIRECTORY + "steamUGC/" + filename_name(file.path)); file_copy(file.path, DIRECTORY + "steamUGC/" + filename_name(file.path));
if(array_safe_get(file.spr_path, 0, 0) != 0)
file_copy(file.spr_path[0], DIRECTORY + "steamUGC/" + filename_name(file.spr_path[0])); file_copy(file.spr_path[0], DIRECTORY + "steamUGC/" + filename_name(file.spr_path[0]));
steam_ugc_collection_generate(file); steam_ugc_collection_generate(file);
@ -26,6 +27,7 @@ function steam_ugc_update_collection(file, update_preview = false) {
directory_destroy(DIRECTORY + "steamUGC"); directory_destroy(DIRECTORY + "steamUGC");
directory_create(DIRECTORY + "steamUGC"); directory_create(DIRECTORY + "steamUGC");
file_copy(file.path, DIRECTORY + "steamUGC/" + filename_name(file.path)); file_copy(file.path, DIRECTORY + "steamUGC/" + filename_name(file.path));
if(array_safe_get(file.spr_path, 0, 0) != 0)
file_copy(file.spr_path[0], DIRECTORY + "steamUGC/" + filename_name(file.spr_path[0])); file_copy(file.spr_path[0], DIRECTORY + "steamUGC/" + filename_name(file.spr_path[0]));
STEAM_UGC_PUBLISH_ID = file.meta.file_id; STEAM_UGC_PUBLISH_ID = file.meta.file_id;

View file

@ -7,6 +7,14 @@ function __initSteamUGC() {
if(DEMO) return; if(DEMO) return;
if(!STEAM_ENABLED) return; if(!STEAM_ENABLED) return;
steamUCGload();
}
function steamUCGload() {
ds_list_clear(STEAM_SUBS);
ds_list_clear(STEAM_COLLECTION);
ds_list_clear(STEAM_PROJECTS);
steam_ugc_get_subscribed_items(STEAM_SUBS); steam_ugc_get_subscribed_items(STEAM_SUBS);
for( var i = 0; i < ds_list_size(STEAM_SUBS); i++ ) { for( var i = 0; i < ds_list_size(STEAM_SUBS); i++ ) {
@ -56,7 +64,7 @@ function __loadSteamUGC(file_id, item_map) {
} }
function __loadSteamUGCCollection(file_id, f, path) { function __loadSteamUGCCollection(file_id, f, path) {
var name = string_replace(filename_name(f), ".pxc", ""); var name = string_replace(filename_name(f), ".pxcc", "");
var file = new FileObject(name, path + "\\" + f); var file = new FileObject(name, path + "\\" + f);
var icon_path = string_replace(path + "\\" + f, ".pxcc", ".png"); var icon_path = string_replace(path + "\\" + f, ".pxcc", ".png");
if(file_exists(icon_path)) { if(file_exists(icon_path)) {

View file

@ -33,6 +33,8 @@ function string_partial_match(str, key) {
function string_real(val) { function string_real(val) {
if(is_string(val)) return val; if(is_string(val)) return val;
if(is_struct(val)) return string(val);
if(is_array(val)) { if(is_array(val)) {
var s = "["; var s = "[";
for( var i = 0; i < array_length(val); i++ ) for( var i = 0; i < array_length(val); i++ )

View file

@ -19,6 +19,11 @@ function draw_surface_part_ext_safe(surface, _l, _t, _w, _h, _x, _y, _xs = 1, _y
draw_surface_part_ext(surface, _l, _t, _w, _h, _x, _y, _xs, _ys, _col, _alpha); draw_surface_part_ext(surface, _l, _t, _w, _h, _x, _y, _xs, _ys, _col, _alpha);
} }
function surface_create_size(surf) {
if(!is_surface(surf)) return surface_create(1, 1);
return surface_create_valid(surface_get_width(surf), surface_get_height(surf));
}
function surface_size_to(surface, width, height) { function surface_size_to(surface, width, height) {
if(!surface_exists(surface)) return false; if(!surface_exists(surface)) return false;
if(width < 1 && height < 1) return false; if(width < 1 && height < 1) return false;

View file

@ -7,10 +7,74 @@ varying vec4 v_vColour;
uniform int gradient_blend; uniform int gradient_blend;
uniform vec4 gradient_color[16]; uniform vec4 gradient_color[16];
uniform float gradient_time[16]; uniform float gradient_time[16];
uniform int keys; uniform int gradient_keys;
uniform float gradient_shift; uniform float gradient_shift;
uniform int multiply_alpha; uniform int multiply_alpha;
vec3 rgb2hsv(vec3 c) {
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 q = mix(vec4(p.xyw, c.r), vec4(c.r, p.yzx), step(p.x, c.r));
float d = q.x - min(q.w, q.y);
float e = 0.0000000001;
return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);
}
vec3 hsv2rgb(vec3 c) {
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);
return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);
}
float hueDist(float a0, float a1, float t) {
float da = fract(a1 - a0);
float ds = fract(2. * da) - da;
return a0 + ds * t;
}
vec3 hsvMix(vec3 c1, vec3 c2, float t) {
vec3 h1 = rgb2hsv(c1);
vec3 h2 = rgb2hsv(c2);
vec3 h = vec3(0.);
h.x = h.x + hueDist(h1.x, h2.x, t);
h.y = mix(h1.y, h2.y, t);
h.z = mix(h1.z, h2.z, t);
return hsv2rgb(h);
}
vec4 gradientEval(in float prog) {
vec4 col = vec4(0.);
for(int i = 0; i < 16; i++) {
if(gradient_time[i] == prog) {
col = gradient_color[i];
break;
} else if(gradient_time[i] > prog) {
if(i == 0)
col = gradient_color[i];
else {
float t = (prog - gradient_time[i - 1]) / (gradient_time[i] - gradient_time[i - 1]);
if(gradient_blend == 0)
col = mix(gradient_color[i - 1], gradient_color[i], t);
else if(gradient_blend == 1)
col = gradient_color[i - 1];
else if(gradient_blend == 2)
col = vec4(hsvMix(gradient_color[i - 1].rgb, gradient_color[i].rgb, t), 1.);
}
break;
}
if(i >= gradient_keys - 1) {
col = gradient_color[gradient_keys - 1];
break;
}
}
return col;
}
void main() { void main() {
vec4 _col = v_vColour * texture2D( gm_BaseTexture, v_vTexcoord ); vec4 _col = v_vColour * texture2D( gm_BaseTexture, v_vTexcoord );
float prog = abs(dot(_col.rgb, vec3(0.2126, 0.7152, 0.0722)) + gradient_shift); float prog = abs(dot(_col.rgb, vec3(0.2126, 0.7152, 0.0722)) + gradient_shift);
@ -24,28 +88,7 @@ void main() {
prog = fract(prog); prog = fract(prog);
} }
vec4 col = vec4(0.); vec4 col = gradientEval(prog);
for(int i = 0; i < 16; i++) {
if(gradient_time[i] == prog) {
col = gradient_color[i];
break;
} else if(gradient_time[i] > prog) {
if(i == 0)
col = gradient_color[i];
else {
if(gradient_blend == 0)
col = mix(gradient_color[i - 1], gradient_color[i], (prog - gradient_time[i - 1]) / (gradient_time[i] - gradient_time[i - 1]));
else if(gradient_blend == 1)
col = gradient_color[i - 1];
}
break;
}
if(i >= keys - 1) {
col = gradient_color[keys - 1];
break;
}
}
col.a = _col.a; col.a = _col.a;
gl_FragColor = col; gl_FragColor = col;