mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-12 23:37:10 +01:00
Globalize Palette, Gradient data. png palette.
This commit is contained in:
parent
468ebbd5f3
commit
d8c5fd2d3d
17 changed files with 229 additions and 240 deletions
|
@ -625,7 +625,7 @@
|
||||||
{"name":"__node_custom","order":14,"path":"scripts/__node_custom/__node_custom.yy",},
|
{"name":"__node_custom","order":14,"path":"scripts/__node_custom/__node_custom.yy",},
|
||||||
{"name":"s_node_note","order":35,"path":"sprites/s_node_note/s_node_note.yy",},
|
{"name":"s_node_note","order":35,"path":"sprites/s_node_note/s_node_note.yy",},
|
||||||
{"name":"node_strand_gravity","order":4,"path":"scripts/node_strand_gravity/node_strand_gravity.yy",},
|
{"name":"node_strand_gravity","order":4,"path":"scripts/node_strand_gravity/node_strand_gravity.yy",},
|
||||||
{"name":"load_palette","order":3,"path":"scripts/load_palette/load_palette.yy",},
|
{"name":"palette_functions","order":3,"path":"scripts/palette_functions/palette_functions.yy",},
|
||||||
{"name":"luaHighlight","order":1,"path":"scripts/luaHighlight/luaHighlight.yy",},
|
{"name":"luaHighlight","order":1,"path":"scripts/luaHighlight/luaHighlight.yy",},
|
||||||
{"name":"d3d_rot3","order":3,"path":"scripts/d3d_rot3/d3d_rot3.yy",},
|
{"name":"d3d_rot3","order":3,"path":"scripts/d3d_rot3/d3d_rot3.yy",},
|
||||||
{"name":"sh_sample_points","order":26,"path":"shaders/sh_sample_points/sh_sample_points.yy",},
|
{"name":"sh_sample_points","order":26,"path":"shaders/sh_sample_points/sh_sample_points.yy",},
|
||||||
|
|
|
@ -1228,7 +1228,7 @@
|
||||||
{"id":{"name":"node_surface_data","path":"scripts/node_surface_data/node_surface_data.yy",},},
|
{"id":{"name":"node_surface_data","path":"scripts/node_surface_data/node_surface_data.yy",},},
|
||||||
{"id":{"name":"s_node_note","path":"sprites/s_node_note/s_node_note.yy",},},
|
{"id":{"name":"s_node_note","path":"sprites/s_node_note/s_node_note.yy",},},
|
||||||
{"id":{"name":"node_strand_gravity","path":"scripts/node_strand_gravity/node_strand_gravity.yy",},},
|
{"id":{"name":"node_strand_gravity","path":"scripts/node_strand_gravity/node_strand_gravity.yy",},},
|
||||||
{"id":{"name":"load_palette","path":"scripts/load_palette/load_palette.yy",},},
|
{"id":{"name":"palette_functions","path":"scripts/palette_functions/palette_functions.yy",},},
|
||||||
{"id":{"name":"sh_alpha_cutoff","path":"shaders/sh_alpha_cutoff/sh_alpha_cutoff.yy",},},
|
{"id":{"name":"sh_alpha_cutoff","path":"shaders/sh_alpha_cutoff/sh_alpha_cutoff.yy",},},
|
||||||
{"id":{"name":"luaHighlight","path":"scripts/luaHighlight/luaHighlight.yy",},},
|
{"id":{"name":"luaHighlight","path":"scripts/luaHighlight/luaHighlight.yy",},},
|
||||||
{"id":{"name":"d3d_rot3","path":"scripts/d3d_rot3/d3d_rot3.yy",},},
|
{"id":{"name":"d3d_rot3","path":"scripts/d3d_rot3/d3d_rot3.yy",},},
|
||||||
|
|
|
@ -32,27 +32,7 @@ event_inherited();
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region presets
|
#region presets
|
||||||
presets = ds_list_create();
|
preset_selecting = -1;
|
||||||
preset_name = ds_list_create();
|
|
||||||
preset_selecting = 0;
|
|
||||||
|
|
||||||
function presetCollect() {
|
|
||||||
ds_list_clear(presets);
|
|
||||||
ds_list_clear(preset_name);
|
|
||||||
|
|
||||||
ds_list_add(presets, DEF_PALETTE);
|
|
||||||
ds_list_add(preset_name, "Project");
|
|
||||||
|
|
||||||
var path = DIRECTORY + "Palettes/"
|
|
||||||
var file = file_find_first(path + "*", 0);
|
|
||||||
while(file != "") {
|
|
||||||
ds_list_add(presets, loadPalette(path + file));
|
|
||||||
ds_list_add(preset_name, filename_name(file));
|
|
||||||
file = file_find_next();
|
|
||||||
}
|
|
||||||
file_find_close();
|
|
||||||
}
|
|
||||||
presetCollect();
|
|
||||||
|
|
||||||
sp_preset_w = ui(240 - 32 - 16);
|
sp_preset_w = ui(240 - 32 - 16);
|
||||||
sp_preset_size = ui(24);
|
sp_preset_size = ui(24);
|
||||||
|
@ -67,8 +47,13 @@ event_inherited();
|
||||||
var _hover = sHOVER && sp_presets.hover;
|
var _hover = sHOVER && sp_presets.hover;
|
||||||
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
||||||
|
|
||||||
for(var i = 0; i < ds_list_size(presets); i++) {
|
for(var i = -1; i < array_length(PALETTES); i++) {
|
||||||
pre_amo = array_length(presets[| i]);
|
var pal = i == -1? {
|
||||||
|
name: "project",
|
||||||
|
palette: PROJECT.attributes.palette,
|
||||||
|
path: ""
|
||||||
|
} : PALETTES[i];
|
||||||
|
pre_amo = array_length(pal.palette);
|
||||||
var col = floor(ww / _gs);
|
var col = floor(ww / _gs);
|
||||||
var row = ceil(pre_amo / col);
|
var row = ceil(pre_amo / col);
|
||||||
|
|
||||||
|
@ -83,19 +68,19 @@ event_inherited();
|
||||||
if(isHover)
|
if(isHover)
|
||||||
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), _height, COLORS._main_accent, 1);
|
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), _height, COLORS._main_accent, 1);
|
||||||
|
|
||||||
var x0 = ui(16) + (i == 0) * ui(8 + 6);
|
var x0 = ui(16) + (i == -1) * ui(8 + 6);
|
||||||
var cc = i == preset_selecting? COLORS._main_accent : COLORS._main_text_sub;
|
var cc = i == preset_selecting? COLORS._main_accent : COLORS._main_text_sub;
|
||||||
draw_set_text(f_p2, fa_left, fa_top, cc);
|
draw_set_text(f_p2, fa_left, fa_top, cc);
|
||||||
draw_text(x0, yy + ui(8), preset_name[| i]);
|
draw_text(x0, yy + ui(8), pal.name);
|
||||||
if(i == 0) {
|
if(i == -1) {
|
||||||
draw_set_color(cc);
|
draw_set_color(cc);
|
||||||
draw_circle_prec(ui(16) + ui(4), yy + ui(16), ui(4), false);
|
draw_circle_prec(ui(16) + ui(4), yy + ui(16), ui(4), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(preset_selecting == i)
|
if(preset_selecting == i)
|
||||||
drawPaletteGrid(presets[| i], ui(16), yy + ui(28), ww, _gs, selector.current_color);
|
drawPaletteGrid(pal.palette, ui(16), yy + ui(28), ww, _gs, selector.current_color);
|
||||||
else
|
else
|
||||||
drawPalette(presets[| i], ui(16), yy + ui(28), ww, ui(20));
|
drawPalette(pal.palette, ui(16), yy + ui(28), ww, ui(20));
|
||||||
|
|
||||||
if(!click_block && mouse_click(mb_left, interactable && sFOCUS)) {
|
if(!click_block && mouse_click(mb_left, interactable && sFOCUS)) {
|
||||||
if(preset_selecting == i && _hover && point_in_rectangle(_m[0], _m[1], ui(16), yy + ui(28), ui(16) + ww, yy + ui(28) + _height)) {
|
if(preset_selecting == i && _hover && point_in_rectangle(_m[0], _m[1], ui(16), yy + ui(28), ui(16) + ww, yy + ui(28) + _height)) {
|
||||||
|
@ -107,7 +92,7 @@ event_inherited();
|
||||||
|
|
||||||
var _index = m_gy * col + m_gx;
|
var _index = m_gy * col + m_gx;
|
||||||
if(_index < pre_amo && _index >= 0) {
|
if(_index < pre_amo && _index >= 0) {
|
||||||
selector.setColor(presets[| i][_index]);
|
selector.setColor(pal.palette[_index]);
|
||||||
selector.setHSV();
|
selector.setHSV();
|
||||||
}
|
}
|
||||||
} else if(isHover) {
|
} else if(isHover) {
|
||||||
|
|
|
@ -60,7 +60,7 @@ if !ready exit;
|
||||||
var col_y = dialog_y + ui(52);
|
var col_y = dialog_y + ui(52);
|
||||||
|
|
||||||
if(preset_selecting > -1)
|
if(preset_selecting > -1)
|
||||||
selector.palette = presets[| preset_selecting];
|
selector.palette = PALETTES[preset_selecting].palette;
|
||||||
selector.draw(col_x, col_y, sFOCUS, sHOVER);
|
selector.draw(col_x, col_y, sFOCUS, sHOVER);
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
|
@ -83,24 +83,6 @@ event_inherited();
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region preset
|
#region preset
|
||||||
presets = ds_list_create();
|
|
||||||
preset_name = ds_list_create();
|
|
||||||
|
|
||||||
function presetCollect() {
|
|
||||||
ds_list_clear(presets);
|
|
||||||
ds_list_clear(preset_name);
|
|
||||||
|
|
||||||
var path = DIRECTORY + "Gradients/"
|
|
||||||
var file = file_find_first(path + "*", 0);
|
|
||||||
while(file != "") {
|
|
||||||
ds_list_add(presets, loadGradient(path + file));
|
|
||||||
ds_list_add(preset_name, filename_name(file));
|
|
||||||
file = file_find_next();
|
|
||||||
}
|
|
||||||
file_find_close();
|
|
||||||
}
|
|
||||||
presetCollect();
|
|
||||||
|
|
||||||
hovering_name = "";
|
hovering_name = "";
|
||||||
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) {
|
||||||
|
@ -111,7 +93,8 @@ event_inherited();
|
||||||
var _hover = sHOVER && sp_presets.hover;
|
var _hover = sHOVER && sp_presets.hover;
|
||||||
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
||||||
|
|
||||||
for(var i = 0; i < ds_list_size(presets); i++) {
|
for(var i = 0; i < array_length(GRADIENTS); i++) {
|
||||||
|
var _gradient = GRADIENTS[i];
|
||||||
var isHover = point_in_rectangle(_m[0], _m[1], ui(4), yy, ui(4) + sp_preset_w - ui(16), yy + hg);
|
var isHover = point_in_rectangle(_m[0], _m[1], ui(4), yy, ui(4) + sp_preset_w - ui(16), yy + hg);
|
||||||
|
|
||||||
draw_sprite_stretched(THEME.ui_panel_bg, 1, ui(4), yy, sp_preset_w - ui(16), hg);
|
draw_sprite_stretched(THEME.ui_panel_bg, 1, ui(4), yy, sp_preset_w - ui(16), hg);
|
||||||
|
@ -119,21 +102,21 @@ event_inherited();
|
||||||
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), hg, COLORS._main_accent, 1);
|
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), hg, COLORS._main_accent, 1);
|
||||||
|
|
||||||
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
|
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
|
||||||
draw_text(ui(16), yy + ui(8), filename_name_only(preset_name[| i]));
|
draw_text(ui(16), yy + ui(8), _gradient.name);
|
||||||
presets[| i].draw(ui(16), yy + ui(28), ww, ui(16));
|
_gradient.gradient.draw(ui(16), yy + ui(28), ww, ui(16));
|
||||||
|
|
||||||
if(_hover && isHover) {
|
if(_hover && isHover) {
|
||||||
if(mouse_press(mb_left, interactable && sFOCUS))
|
if(mouse_press(mb_left, interactable && sFOCUS))
|
||||||
gradient.keys = presets[| i].keys;
|
gradient.keys = _gradient.gradient.keys;
|
||||||
|
|
||||||
if(mouse_press(mb_right, interactable && sFOCUS)) {
|
if(mouse_press(mb_right, interactable && sFOCUS)) {
|
||||||
hovering_name = preset_name[| i];
|
hovering_name = _gradient.path;
|
||||||
menuCall("gradient_window_preset_menu",,, [
|
menuCall("gradient_window_preset_menu",,, [
|
||||||
menuItem(__txtx("gradient_editor_delete", "Delete gradient"), function() {
|
menuItem(__txtx("gradient_editor_delete", "Delete gradient"), function() {
|
||||||
file_delete( DIRECTORY + "Gradients/" + hovering_name);
|
file_delete(hovering_name);
|
||||||
presetCollect();
|
__initGradient();
|
||||||
})
|
})
|
||||||
],, { name: hovering_name })
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -146,27 +129,7 @@ event_inherited();
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region palette
|
#region palette
|
||||||
palettes = ds_list_create();
|
palette_selecting = -1;
|
||||||
palette_name = ds_list_create();
|
|
||||||
palette_selecting = 0;
|
|
||||||
|
|
||||||
function paletteCollect() {
|
|
||||||
ds_list_clear(palettes);
|
|
||||||
ds_list_clear(palette_name);
|
|
||||||
|
|
||||||
ds_list_add(palettes, DEF_PALETTE);
|
|
||||||
ds_list_add(palette_name, "Project");
|
|
||||||
|
|
||||||
var path = DIRECTORY + "Palettes/"
|
|
||||||
var file = file_find_first(path + "*", 0);
|
|
||||||
while(file != "") {
|
|
||||||
ds_list_add(palettes, loadPalette(path + file));
|
|
||||||
ds_list_add(palette_name, filename_name(file));
|
|
||||||
file = file_find_next();
|
|
||||||
}
|
|
||||||
file_find_close();
|
|
||||||
}
|
|
||||||
paletteCollect();
|
|
||||||
|
|
||||||
sp_palette_w = ui(240 - 32 - 16);
|
sp_palette_w = ui(240 - 32 - 16);
|
||||||
sp_palette_size = ui(24);
|
sp_palette_size = ui(24);
|
||||||
|
@ -181,8 +144,14 @@ event_inherited();
|
||||||
var _hover = sHOVER && sp_palettes.hover;
|
var _hover = sHOVER && sp_palettes.hover;
|
||||||
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
||||||
|
|
||||||
for(var i = 0; i < ds_list_size(palettes); i++) {
|
for(var i = -1; i < array_length(PALETTES); i++) {
|
||||||
pre_amo = array_length(palettes[| i]);
|
var pal = i == -1? {
|
||||||
|
name: "project",
|
||||||
|
palette: PROJECT.attributes.palette,
|
||||||
|
path: ""
|
||||||
|
} : PALETTES[i];
|
||||||
|
|
||||||
|
pre_amo = array_length(pal.palette);
|
||||||
var col = floor(ww / _gs);
|
var col = floor(ww / _gs);
|
||||||
var row = ceil(pre_amo / col);
|
var row = ceil(pre_amo / col);
|
||||||
|
|
||||||
|
@ -197,19 +166,19 @@ event_inherited();
|
||||||
if(isHover)
|
if(isHover)
|
||||||
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_palette_w - ui(16), _height, COLORS._main_accent, 1);
|
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_palette_w - ui(16), _height, COLORS._main_accent, 1);
|
||||||
|
|
||||||
var x0 = ui(16) + (i == 0) * ui(8 + 6);
|
var x0 = ui(16) + (i == -1) * ui(8 + 6);
|
||||||
var cc = i == palette_selecting? COLORS._main_accent : COLORS._main_text_sub;
|
var cc = i == palette_selecting? COLORS._main_accent : COLORS._main_text_sub;
|
||||||
draw_set_text(f_p2, fa_left, fa_top, cc);
|
draw_set_text(f_p2, fa_left, fa_top, cc);
|
||||||
draw_text(x0, yy + ui(8), filename_name_only(palette_name[| i]));
|
draw_text(x0, yy + ui(8), pal.name);
|
||||||
if(i == 0) {
|
if(i == -1) {
|
||||||
draw_set_color(cc);
|
draw_set_color(cc);
|
||||||
draw_circle_prec(ui(16) + ui(4), yy + ui(16), ui(4), false);
|
draw_circle_prec(ui(16) + ui(4), yy + ui(16), ui(4), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(palette_selecting == i)
|
if(palette_selecting == i)
|
||||||
drawPaletteGrid(palettes[| i], ui(16), yy + ui(28), ww, _gs);
|
drawPaletteGrid(pal.palette, ui(16), yy + ui(28), ww, _gs);
|
||||||
else
|
else
|
||||||
drawPalette(palettes[| i], ui(16), yy + ui(28), ww, ui(20));
|
drawPalette(pal.palette, ui(16), yy + ui(28), ww, ui(20));
|
||||||
|
|
||||||
if(!click_block && mouse_click(mb_left, interactable && sFOCUS)) {
|
if(!click_block && mouse_click(mb_left, interactable && sFOCUS)) {
|
||||||
if(palette_selecting == i && _hover && point_in_rectangle(_m[0], _m[1], ui(16), yy + ui(28), ui(16) + ww, yy + ui(28) + _height)) {
|
if(palette_selecting == i && _hover && point_in_rectangle(_m[0], _m[1], ui(16), yy + ui(28), ui(16) + ww, yy + ui(28) + _height)) {
|
||||||
|
@ -221,7 +190,7 @@ event_inherited();
|
||||||
|
|
||||||
var _index = m_gy * col + m_gx;
|
var _index = m_gy * col + m_gx;
|
||||||
if(_index < pre_amo && _index >= 0) {
|
if(_index < pre_amo && _index >= 0) {
|
||||||
selector.setColor(palettes[| i][_index]);
|
selector.setColor(pal.palette[_index]);
|
||||||
selector.setHSV();
|
selector.setHSV();
|
||||||
}
|
}
|
||||||
} else if(isHover) {
|
} else if(isHover) {
|
||||||
|
|
|
@ -214,7 +214,7 @@ if !ready exit;
|
||||||
var col_y = dialog_y + ui(136);
|
var col_y = dialog_y + ui(136);
|
||||||
|
|
||||||
if(palette_selecting > -1)
|
if(palette_selecting > -1)
|
||||||
selector.palette = palettes[| palette_selecting];
|
selector.palette = PALETTES[palette_selecting].palette;
|
||||||
selector.draw(col_x, col_y, sFOCUS, sHOVER);
|
selector.draw(col_x, col_y, sFOCUS, sHOVER);
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
|
@ -54,27 +54,6 @@ event_inherited();
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region presets
|
#region presets
|
||||||
presets = ds_list_create();
|
|
||||||
preset_name = ds_list_create();
|
|
||||||
|
|
||||||
function presetCollect() {
|
|
||||||
ds_list_clear(presets);
|
|
||||||
ds_list_clear(preset_name);
|
|
||||||
|
|
||||||
ds_list_add(presets, DEF_PALETTE);
|
|
||||||
ds_list_add(preset_name, "Project");
|
|
||||||
|
|
||||||
var path = DIRECTORY + "Palettes/"
|
|
||||||
var file = file_find_first(path + "*", 0);
|
|
||||||
while(file != "") {
|
|
||||||
ds_list_add(presets, loadPalette(path + file));
|
|
||||||
ds_list_add(preset_name, filename_name(file));
|
|
||||||
file = file_find_next();
|
|
||||||
}
|
|
||||||
file_find_close();
|
|
||||||
}
|
|
||||||
presetCollect();
|
|
||||||
|
|
||||||
hovering_name = "";
|
hovering_name = "";
|
||||||
|
|
||||||
sp_preset_w = ui(240 - 32 - 16);
|
sp_preset_w = ui(240 - 32 - 16);
|
||||||
|
@ -85,31 +64,36 @@ event_inherited();
|
||||||
var hg = ui(52);
|
var hg = ui(52);
|
||||||
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
||||||
|
|
||||||
for(var i = 0; i < ds_list_size(presets); i++) {
|
for(var i = -1; i < array_length(PALETTES); i++) {
|
||||||
|
var pal = i == -1? {
|
||||||
|
name: "project",
|
||||||
|
palette: PROJECT.attributes.palette,
|
||||||
|
path: ""
|
||||||
|
} : PALETTES[i];
|
||||||
var isHover = sHOVER && sp_presets.hover && point_in_rectangle(_m[0], _m[1], ui(4), yy, ui(4) + sp_preset_w - ui(16), yy + hg);
|
var isHover = sHOVER && sp_presets.hover && point_in_rectangle(_m[0], _m[1], ui(4), yy, ui(4) + sp_preset_w - ui(16), yy + hg);
|
||||||
draw_sprite_stretched(THEME.ui_panel_bg, 1, ui(4), yy, sp_preset_w - ui(16), hg);
|
draw_sprite_stretched(THEME.ui_panel_bg, 1, ui(4), yy, sp_preset_w - ui(16), hg);
|
||||||
if(isHover)
|
if(isHover)
|
||||||
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), hg, COLORS._main_accent, 1);
|
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), hg, COLORS._main_accent, 1);
|
||||||
|
|
||||||
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
|
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
|
||||||
draw_text(ui(16), yy + ui(8), filename_name_only(preset_name[| i]));
|
draw_text(ui(16), yy + ui(8), pal.name);
|
||||||
drawPalette(presets[| i], ui(16), yy + ui(28), ww, ui(16));
|
drawPalette(pal.palette, ui(16), yy + ui(28), ww, ui(16));
|
||||||
|
|
||||||
if(isHover) {
|
if(isHover) {
|
||||||
if(mouse_press(mb_left, interactable && sFOCUS)) {
|
if(mouse_press(mb_left, interactable && sFOCUS)) {
|
||||||
palette = array_create(array_length(presets[| i]));
|
palette = array_create(array_length(pal.palette));
|
||||||
for( var j = 0; j < array_length(presets[| i]); j++ )
|
for( var j = 0; j < array_length(pal.palette); j++ )
|
||||||
palette[j] = presets[| i][j];
|
palette[j] = pal.palette[j];
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mouse_press(mb_right, interactable && sFOCUS)) {
|
if(mouse_press(mb_right, interactable && sFOCUS)) {
|
||||||
hovering_name = preset_name[| i];
|
hovering_name = pal.name;
|
||||||
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( DIRECTORY + "Palettes/" + hovering_name);
|
file_delete(hovering_name);
|
||||||
presetCollect();
|
__initPalette();
|
||||||
})
|
})
|
||||||
],, { name : hovering_name })
|
])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -184,7 +184,8 @@ if palette == 0 exit;
|
||||||
if(buttonInstant(THEME.button, bx, by, ui(28), ui(28), mouse_ui, interactable && sFOCUS, sHOVER, __txtx("palette_editor_load", "Load palette file") + " (.hex)", THEME.file) == 2) {
|
if(buttonInstant(THEME.button, bx, by, ui(28), ui(28), mouse_ui, interactable && sFOCUS, sHOVER, __txtx("palette_editor_load", "Load palette file") + " (.hex)", THEME.file) == 2) {
|
||||||
var path = get_open_filename(".hex", "");
|
var path = get_open_filename(".hex", "");
|
||||||
key_release();
|
key_release();
|
||||||
if(path != "") {
|
|
||||||
|
if(isPaletteFile(path)) {
|
||||||
palette = loadPalette(path);
|
palette = loadPalette(path);
|
||||||
onApply(palette);
|
onApply(palette);
|
||||||
}
|
}
|
||||||
|
|
|
@ -82,6 +82,8 @@
|
||||||
log_message("SESSION", "> init Nodes"); __initNodes();
|
log_message("SESSION", "> init Nodes"); __initNodes();
|
||||||
log_message("SESSION", "> init SteamUGC"); __initSteamUGC();
|
log_message("SESSION", "> init SteamUGC"); __initSteamUGC();
|
||||||
log_message("SESSION", "> init Addon"); __initAddon();
|
log_message("SESSION", "> init Addon"); __initAddon();
|
||||||
|
log_message("SESSION", "> init Palette"); __initPalette();
|
||||||
|
log_message("SESSION", "> init Gradient"); __initGradient();
|
||||||
|
|
||||||
setPanel();
|
setPanel();
|
||||||
loadAddon();
|
loadAddon();
|
||||||
|
|
|
@ -7,17 +7,17 @@ function draw_circle_border(xx, yy, r, w) {
|
||||||
var step = 32;
|
var step = 32;
|
||||||
var angle_step = 360 / step;
|
var angle_step = 360 / step;
|
||||||
|
|
||||||
var px, py, _px, _py;
|
draw_primitive_begin(pr_trianglestrip);
|
||||||
|
|
||||||
for(var i = 0; i <= step; i++){
|
for(var i = 0; i <= step; i++){
|
||||||
var px = xx + lengthdir_x(r, i * angle_step);
|
var p0x = xx + lengthdir_x(r - w / 2, i * angle_step);
|
||||||
var py = yy + lengthdir_y(r, i * angle_step);
|
var p0y = yy + lengthdir_y(r - w / 2, i * angle_step);
|
||||||
|
var p1x = xx + lengthdir_x(r + w / 2, i * angle_step);
|
||||||
|
var p1y = yy + lengthdir_y(r + w / 2, i * angle_step);
|
||||||
|
|
||||||
if(i) draw_line_round(_px, _py, px, py, w);
|
draw_vertex(p0x, p0y);
|
||||||
|
draw_vertex(p1x, p1y);
|
||||||
_px = px;
|
|
||||||
_py = py;
|
|
||||||
}
|
}
|
||||||
|
draw_primitive_end();
|
||||||
}
|
}
|
||||||
|
|
||||||
function draw_ellipse_border(x0, y0, x1, y1, w) {
|
function draw_ellipse_border(x0, y0, x1, y1, w) {
|
||||||
|
|
|
@ -4,34 +4,31 @@ enum GRADIENT_INTER {
|
||||||
hue
|
hue
|
||||||
}
|
}
|
||||||
|
|
||||||
function gradientKey(time, value) constructor {
|
function gradientKey(time, value) constructor { #region
|
||||||
self.time = time;
|
self.time = time;
|
||||||
self.value = value;
|
self.value = value;
|
||||||
|
|
||||||
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 }; }
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function gradientObject(color = c_black) constructor {
|
function gradientObject(color = c_black) constructor { #region
|
||||||
static GRADIENT_LIMIT = 128;
|
static GRADIENT_LIMIT = 128;
|
||||||
|
|
||||||
if(is_array(color))
|
if(is_array(color)) keys = [ new gradientKey(0, color[0]), new gradientKey(1, color[1]) ];
|
||||||
keys = [ new gradientKey(0, color[0]), new gradientKey(1, color[1]) ];
|
else keys = [ new gradientKey(0, color) ];
|
||||||
else
|
|
||||||
keys = [ new gradientKey(0, color) ];
|
|
||||||
type = GRADIENT_INTER.smooth;
|
type = GRADIENT_INTER.smooth;
|
||||||
|
|
||||||
static clone = function() {
|
static clone = function() { #region
|
||||||
var g = new gradientObject();
|
var g = new gradientObject();
|
||||||
for( var i = 0, n = array_length(keys); i < n; i++ )
|
for( var i = 0, n = array_length(keys); i < n; i++ )
|
||||||
g.keys[i] = keys[i].clone();
|
g.keys[i] = keys[i].clone();
|
||||||
g.type = type;
|
g.type = type;
|
||||||
|
|
||||||
return g;
|
return g;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static add = function(_addkey, _deleteDup = true) {
|
static add = function(_addkey, _deleteDup = true) { #region
|
||||||
if(array_length(keys) > GRADIENT_LIMIT) return;
|
if(array_length(keys) > GRADIENT_LIMIT) return;
|
||||||
if(array_length(keys) == 0) {
|
if(array_length(keys) == 0) {
|
||||||
array_push(keys, _addkey);
|
array_push(keys, _addkey);
|
||||||
|
@ -52,9 +49,9 @@ function gradientObject(color = c_black) constructor {
|
||||||
}
|
}
|
||||||
|
|
||||||
array_push(keys, _addkey);
|
array_push(keys, _addkey);
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static eval = function(position) {
|
static eval = function(position) { #region
|
||||||
if(array_length(keys) == 0) return c_black;
|
if(array_length(keys) == 0) return c_black;
|
||||||
if(array_length(keys) == 1) return keys[0].value;
|
if(array_length(keys) == 1) return keys[0].value;
|
||||||
|
|
||||||
|
@ -77,9 +74,9 @@ function gradientObject(color = c_black) constructor {
|
||||||
}
|
}
|
||||||
|
|
||||||
return keys[array_length(keys) - 1].value; //after last color
|
return keys[array_length(keys) - 1].value; //after last color
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static draw = function(_x, _y, _w, _h, _a = 1) {
|
static draw = function(_x, _y, _w, _h, _a = 1) { #region
|
||||||
var uniform_grad_blend = shader_get_uniform(sh_gradient_display, "gradient_blend");
|
var uniform_grad_blend = shader_get_uniform(sh_gradient_display, "gradient_blend");
|
||||||
var uniform_grad = shader_get_uniform(sh_gradient_display, "gradient_color");
|
var uniform_grad = shader_get_uniform(sh_gradient_display, "gradient_color");
|
||||||
var uniform_grad_time = shader_get_uniform(sh_gradient_display, "gradient_time");
|
var uniform_grad_time = shader_get_uniform(sh_gradient_display, "gradient_time");
|
||||||
|
@ -112,9 +109,9 @@ function gradientObject(color = c_black) constructor {
|
||||||
draw_sprite_stretched_ext(s_fx_pixel, 0, _x, _y, _w, _h, c_white, _a)
|
draw_sprite_stretched_ext(s_fx_pixel, 0, _x, _y, _w, _h, c_white, _a)
|
||||||
shader_reset();
|
shader_reset();
|
||||||
}
|
}
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static toArray = function() {
|
static toArray = function() { #region
|
||||||
var _grad_color = [], _grad_time = [];
|
var _grad_color = [], _grad_time = [];
|
||||||
|
|
||||||
for(var i = 0; i < array_length(keys); i++) {
|
for(var i = 0; i < array_length(keys); i++) {
|
||||||
|
@ -128,9 +125,9 @@ function gradientObject(color = c_black) constructor {
|
||||||
}
|
}
|
||||||
|
|
||||||
return [ _grad_color, _grad_time ];
|
return [ _grad_color, _grad_time ];
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static lerpTo = function(target, amount) {
|
static lerpTo = function(target, amount) { #region
|
||||||
var grad = new gradientObject();
|
var grad = new gradientObject();
|
||||||
grad.keys = [];
|
grad.keys = [];
|
||||||
grad.type = type;
|
grad.type = type;
|
||||||
|
@ -150,9 +147,9 @@ function gradientObject(color = c_black) constructor {
|
||||||
}
|
}
|
||||||
|
|
||||||
return grad;
|
return grad;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static shader_submit = function() {
|
static shader_submit = function() { #region
|
||||||
var _grad = toArray();
|
var _grad = toArray();
|
||||||
var _grad_color = _grad[0];
|
var _grad_color = _grad[0];
|
||||||
var _grad_time = _grad[1];
|
var _grad_time = _grad[1];
|
||||||
|
@ -161,9 +158,9 @@ function gradientObject(color = c_black) constructor {
|
||||||
shader_set_f("gradient_color", _grad_color);
|
shader_set_f("gradient_color", _grad_color);
|
||||||
shader_set_f("gradient_time", _grad_time);
|
shader_set_f("gradient_time", _grad_time);
|
||||||
shader_set_i("gradient_keys", array_length(keys));
|
shader_set_i("gradient_keys", array_length(keys));
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static clone = function() {
|
static clone = function() { #region
|
||||||
var g = new gradientObject();
|
var g = new gradientObject();
|
||||||
g.keys = [];
|
g.keys = [];
|
||||||
g.type = type;
|
g.type = type;
|
||||||
|
@ -172,18 +169,18 @@ function gradientObject(color = c_black) constructor {
|
||||||
g.keys[i] = keys[i].clone();
|
g.keys[i] = keys[i].clone();
|
||||||
|
|
||||||
return g;
|
return g;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static serialize = function() {
|
static serialize = function() { #region
|
||||||
var s = { type: 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();
|
||||||
|
|
||||||
return json_stringify(s, false);
|
return json_stringify(s, false);
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static deserialize = function(str) {
|
static deserialize = function(str) { #region
|
||||||
var s;
|
var s;
|
||||||
|
|
||||||
if(is_string(str))
|
if(is_string(str))
|
||||||
|
@ -208,10 +205,10 @@ function gradientObject(color = c_black) constructor {
|
||||||
}
|
}
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
} #endregion
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
function loadGradient(path) {
|
function loadGradient(path) { #region
|
||||||
if(path == "") return noone;
|
if(path == "") return noone;
|
||||||
if(!file_exists(path)) return noone;
|
if(!file_exists(path)) return noone;
|
||||||
|
|
||||||
|
@ -240,4 +237,23 @@ function loadGradient(path) {
|
||||||
file_text_close(_t);
|
file_text_close(_t);
|
||||||
|
|
||||||
return grad;
|
return grad;
|
||||||
|
} #endregion
|
||||||
|
|
||||||
|
globalvar GRADIENTS;
|
||||||
|
GRADIENTS = [];
|
||||||
|
|
||||||
|
function __initGradient() {
|
||||||
|
GRADIENTS = [];
|
||||||
|
|
||||||
|
var path = DIRECTORY + "Gradients/"
|
||||||
|
var file = file_find_first(path + "*", 0);
|
||||||
|
while(file != "") {
|
||||||
|
array_push(GRADIENTS, {
|
||||||
|
name: filename_name_only(file),
|
||||||
|
path: path + file,
|
||||||
|
gradient: loadGradient(path + file)
|
||||||
|
});
|
||||||
|
file = file_find_next();
|
||||||
|
}
|
||||||
|
file_find_close();
|
||||||
}
|
}
|
|
@ -1,32 +0,0 @@
|
||||||
function loadPalette(path) {
|
|
||||||
var pal = [];
|
|
||||||
|
|
||||||
if(path != "" && file_exists(path)) {
|
|
||||||
var _t = file_text_open_read(path);
|
|
||||||
var _index = 0;
|
|
||||||
var ext = string_lower(filename_ext(path));
|
|
||||||
while(!file_text_eof(_t)) {
|
|
||||||
var _w = file_text_readln(_t);
|
|
||||||
if(_w != "") {
|
|
||||||
switch(ext) {
|
|
||||||
case ".hex" :
|
|
||||||
var _r = string_hexadecimal(string_copy(_w, 1, 2));
|
|
||||||
var _g = string_hexadecimal(string_copy(_w, 3, 2));
|
|
||||||
var _b = string_hexadecimal(string_copy(_w, 5, 2));
|
|
||||||
|
|
||||||
pal[_index++] = make_color_rgb(_r, _g, _b);
|
|
||||||
break;
|
|
||||||
case ".gpl" :
|
|
||||||
case ".pal" :
|
|
||||||
if(string_char_at(_w, 1) == "#") break;
|
|
||||||
var _c = string_splice(_w, " ");
|
|
||||||
if(array_length(_c) >= 3)
|
|
||||||
pal[_index++] = make_color_rgb(toNumber(_c[0]), toNumber(_c[1]), toNumber(_c[2]));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
file_text_close(_t);
|
|
||||||
}
|
|
||||||
return pal;
|
|
||||||
}
|
|
|
@ -20,10 +20,15 @@ function Node_Pin(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
||||||
|
|
||||||
outputs[| 0] = nodeValue("Out", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0);
|
outputs[| 0] = nodeValue("Out", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0);
|
||||||
|
|
||||||
static update = function(frame = CURRENT_FRAME) {
|
static step = function() {
|
||||||
inputs[| 0].setType(inputs[| 0].value_from == noone? VALUE_TYPE.any : inputs[| 0].value_from.type);
|
if(inputs[| 0].value_from == noone) return;
|
||||||
outputs[| 0].setType(inputs[| 0].type);
|
|
||||||
|
inputs[| 0].setType(inputs[| 0].value_from.type);
|
||||||
|
outputs[| 0].setType(inputs[| 0].value_from.type);
|
||||||
outputs[| 0].value_from = inputs[| 0].value_from;
|
outputs[| 0].value_from = inputs[| 0].value_from;
|
||||||
|
|
||||||
|
inputs[| 0].color_display = inputs[| 0].value_from.color_display;
|
||||||
|
outputs[| 0].color_display = inputs[| 0].color_display;
|
||||||
}
|
}
|
||||||
|
|
||||||
static pointIn = function(_x, _y, _mx, _my, _s) {
|
static pointIn = function(_x, _y, _mx, _my, _s) {
|
||||||
|
@ -77,8 +82,13 @@ function Node_Pin(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
||||||
active_draw_index = -1;
|
active_draw_index = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(hover_scale > 0)
|
if(hover_scale > 0) {
|
||||||
draw_sprite_ext(THEME.node_pin_bg_active, 0, xx, yy, _s * hover_scale, _s * hover_scale, 0, COLORS._main_accent, hover_alpha);
|
draw_set_color(COLORS._main_accent);
|
||||||
|
draw_set_alpha(hover_alpha);
|
||||||
|
draw_circle_border(xx, yy, _s * hover_scale * 20, 2);
|
||||||
|
draw_set_alpha(1);
|
||||||
|
}
|
||||||
|
|
||||||
hover_scale = lerp_float(hover_scale, hover_scale_to, 3);
|
hover_scale = lerp_float(hover_scale, hover_scale_to, 3);
|
||||||
hover_scale_to = 0;
|
hover_scale_to = 0;
|
||||||
|
|
||||||
|
|
91
scripts/palette_functions/palette_functions.gml
Normal file
91
scripts/palette_functions/palette_functions.gml
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
function isPaletteFile(path) { #region
|
||||||
|
var ext = string_lower(filename_ext(path));
|
||||||
|
switch(ext) {
|
||||||
|
case ".hex" :
|
||||||
|
case ".gpl" :
|
||||||
|
case ".pal" :
|
||||||
|
case ".png" :
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
} #endregion
|
||||||
|
|
||||||
|
function loadPalette(path) { #region
|
||||||
|
if(!file_exists(path)) return [];
|
||||||
|
if(!isPaletteFile(path)) return [];
|
||||||
|
|
||||||
|
var ext = string_lower(filename_ext(path));
|
||||||
|
|
||||||
|
if(ext == ".png") {
|
||||||
|
var _spr = sprite_add(path, 1, 0, 0, 0, 0);
|
||||||
|
var _sw = sprite_get_width(_spr);
|
||||||
|
var _sh = sprite_get_height(_spr);
|
||||||
|
var _s = surface_create(_sw, _sh);
|
||||||
|
surface_set_target(_s);
|
||||||
|
draw_clear_alpha(0, 0);
|
||||||
|
BLEND_OVERRIDE
|
||||||
|
draw_sprite(_spr, 0, 0, 0);
|
||||||
|
BLEND_NORMAL
|
||||||
|
surface_reset_target();
|
||||||
|
|
||||||
|
var pal = array_create(_sw * _sh);
|
||||||
|
for( var i = 0; i < _sh; i++ )
|
||||||
|
for( var j = 0; j < _sw; j++ )
|
||||||
|
pal[i * _sh + j] = surface_getpixel(_s, j, i);
|
||||||
|
|
||||||
|
surface_free(_s);
|
||||||
|
|
||||||
|
return pal;
|
||||||
|
}
|
||||||
|
|
||||||
|
var pal = [];
|
||||||
|
var _t = file_text_open_read(path);
|
||||||
|
var _index = 0;
|
||||||
|
|
||||||
|
while(!file_text_eof(_t)) {
|
||||||
|
var _w = file_text_readln(_t);
|
||||||
|
if(_w == "") continue;
|
||||||
|
|
||||||
|
switch(ext) {
|
||||||
|
case ".hex" :
|
||||||
|
var _r = string_hexadecimal(string_copy(_w, 1, 2));
|
||||||
|
var _g = string_hexadecimal(string_copy(_w, 3, 2));
|
||||||
|
var _b = string_hexadecimal(string_copy(_w, 5, 2));
|
||||||
|
|
||||||
|
pal[_index++] = make_color_rgb(_r, _g, _b);
|
||||||
|
break;
|
||||||
|
case ".gpl" :
|
||||||
|
case ".pal" :
|
||||||
|
if(string_char_at(_w, 1) == "#") break;
|
||||||
|
var _c = string_splice(_w, " ");
|
||||||
|
if(array_length(_c) >= 3)
|
||||||
|
pal[_index++] = make_color_rgb(toNumber(_c[0]), toNumber(_c[1]), toNumber(_c[2]));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
file_text_close(_t);
|
||||||
|
|
||||||
|
return pal;
|
||||||
|
} #endregion
|
||||||
|
|
||||||
|
globalvar PALETTES;
|
||||||
|
PALETTES = [];
|
||||||
|
|
||||||
|
function __initPalette() {
|
||||||
|
PALETTES = [];
|
||||||
|
|
||||||
|
var path = DIRECTORY + "Palettes/"
|
||||||
|
var file = file_find_first(path + "*", 0);
|
||||||
|
while(file != "") {
|
||||||
|
if(isPaletteFile(file)) {
|
||||||
|
array_push(PALETTES, {
|
||||||
|
name: filename_name_only(file),
|
||||||
|
path: path + file,
|
||||||
|
palette: loadPalette(path + file)
|
||||||
|
});
|
||||||
|
}
|
||||||
|
file = file_find_next();
|
||||||
|
}
|
||||||
|
file_find_close();
|
||||||
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"resourceType": "GMScript",
|
"resourceType": "GMScript",
|
||||||
"resourceVersion": "1.0",
|
"resourceVersion": "1.0",
|
||||||
"name": "load_palette",
|
"name": "palette_functions",
|
||||||
"isCompatibility": false,
|
"isCompatibility": false,
|
||||||
"isDnD": false,
|
"isDnD": false,
|
||||||
"parent": {
|
"parent": {
|
|
@ -7,25 +7,6 @@ function Panel_Gradient() : PanelContent() constructor {
|
||||||
w = ui(320);
|
w = ui(320);
|
||||||
h = ui(480);
|
h = ui(480);
|
||||||
|
|
||||||
presets = [];
|
|
||||||
|
|
||||||
function presetCollect() {
|
|
||||||
presets = [];
|
|
||||||
|
|
||||||
var path = DIRECTORY + "Gradients/"
|
|
||||||
var file = file_find_first(path + "*", 0);
|
|
||||||
while(file != "") {
|
|
||||||
array_push(presets, {
|
|
||||||
name: filename_name(file),
|
|
||||||
gradient: loadGradient(path + file)
|
|
||||||
});
|
|
||||||
|
|
||||||
file = file_find_next();
|
|
||||||
}
|
|
||||||
file_find_close();
|
|
||||||
}
|
|
||||||
presetCollect();
|
|
||||||
|
|
||||||
function onResize() {
|
function onResize() {
|
||||||
PANEL_PADDING
|
PANEL_PADDING
|
||||||
|
|
||||||
|
@ -37,7 +18,7 @@ function Panel_Gradient() : PanelContent() constructor {
|
||||||
var ww = sp_gradient.surface_w;
|
var ww = sp_gradient.surface_w;
|
||||||
var hh = 0;
|
var hh = 0;
|
||||||
|
|
||||||
var amo = array_length(presets);
|
var amo = array_length(GRADIENTS);
|
||||||
var col = floor(ww / ui(160));
|
var col = floor(ww / ui(160));
|
||||||
var row = ceil(amo / col);
|
var row = ceil(amo / col);
|
||||||
|
|
||||||
|
@ -53,7 +34,7 @@ function Panel_Gradient() : PanelContent() constructor {
|
||||||
if(ind >= amo) break;
|
if(ind >= amo) break;
|
||||||
|
|
||||||
var xx = j * gw;
|
var xx = j * gw;
|
||||||
var preset = presets[ind];
|
var preset = GRADIENTS[ind];
|
||||||
var isHover = pHOVER && point_in_rectangle(_m[0], _m[1], xx, max(0, yy), xx + gw - ui(8), min(sp_gradient.h, yy + hg));
|
var isHover = pHOVER && point_in_rectangle(_m[0], _m[1], xx, max(0, yy), xx + gw - ui(8), min(sp_gradient.h, yy + hg));
|
||||||
|
|
||||||
draw_sprite_stretched(THEME.ui_panel_bg, in_dialog, xx, yy, gw - ui(8), hg);
|
draw_sprite_stretched(THEME.ui_panel_bg, in_dialog, xx, yy, gw - ui(8), hg);
|
||||||
|
@ -98,6 +79,6 @@ function Panel_Gradient() : 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();
|
__initGradient();
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -7,28 +7,10 @@ function Panel_Palette() : PanelContent() constructor {
|
||||||
w = ui(320);
|
w = ui(320);
|
||||||
h = ui(480);
|
h = ui(480);
|
||||||
|
|
||||||
presets = [];
|
|
||||||
view_mode = 0;
|
view_mode = 0;
|
||||||
|
|
||||||
color_dragging = noone;
|
color_dragging = noone;
|
||||||
|
|
||||||
static presetCollect = function() {
|
|
||||||
presets = [];
|
|
||||||
|
|
||||||
var path = DIRECTORY + "Palettes/"
|
|
||||||
var file = file_find_first(path + "*", 0);
|
|
||||||
while(file != "") {
|
|
||||||
array_push(presets, {
|
|
||||||
name: filename_name(file),
|
|
||||||
palette: loadPalette(path + file)
|
|
||||||
});
|
|
||||||
|
|
||||||
file = file_find_next();
|
|
||||||
}
|
|
||||||
file_find_close();
|
|
||||||
}
|
|
||||||
presetCollect()
|
|
||||||
|
|
||||||
function onResize() {
|
function onResize() {
|
||||||
PANEL_PADDING
|
PANEL_PADDING
|
||||||
|
|
||||||
|
@ -48,8 +30,8 @@ function Panel_Palette() : PanelContent() constructor {
|
||||||
var yy = _y;
|
var yy = _y;
|
||||||
var _height;
|
var _height;
|
||||||
|
|
||||||
for(var i = 0; i < array_length(presets); i++) {
|
for(var i = 0; i < array_length(PALETTES); i++) {
|
||||||
var preset = presets[i];
|
var preset = PALETTES[i];
|
||||||
var pre_amo = array_length(preset.palette);
|
var pre_amo = array_length(preset.palette);
|
||||||
var col = floor((ww - ui(20)) / _gs);
|
var col = floor((ww - ui(20)) / _gs);
|
||||||
var row = ceil(pre_amo / col);
|
var row = ceil(pre_amo / col);
|
||||||
|
|
Loading…
Reference in a new issue