Pixel-Composer/objects/o_dialog_gradient/Create_0.gml

142 lines
3.5 KiB
Plaintext
Raw Normal View History

2022-01-13 05:24:03 +01:00
/// @description init
event_inherited();
#region data
2022-12-10 05:06:01 +01:00
dialog_w = ui(812);
dialog_h = ui(476);
2022-01-13 05:24:03 +01:00
name = "Gradient editor";
gradient = noone;
grad_data = noone;
key_selecting = noone;
key_dragging = noone;
key_drag_sx = 0;
key_drag_mx = 0;
destroy_on_click_out = true;
2022-11-14 03:16:15 +01:00
sl_position = new slider(0, 100, 0.1, function(val) {
if(key_selecting == noone) return;
setKeyPosition(key_selecting, val / 100);
}, function() { removeKeyOverlap(key_selecting); })
2022-11-18 03:20:31 +01:00
setColor = function(color) {
2022-01-13 05:24:03 +01:00
if(key_selecting == noone) return;
2022-11-18 03:20:31 +01:00
key_selecting.value = color;
2022-01-13 05:24:03 +01:00
}
function setGradient(grad, data) {
gradient = grad;
grad_data = data;
if(!ds_list_empty(grad))
key_selecting = grad[| 0];
}
2022-11-18 03:20:31 +01:00
selector = new colorSelector(setColor);
2022-12-22 03:09:55 +01:00
selector.dropper_close = false;
2022-11-18 03:20:31 +01:00
2022-11-14 03:16:15 +01:00
function setKeyPosition(key, position) {
key.time = position;
ds_list_remove(gradient, key);
gradient_add(gradient, key, false);
}
function removeKeyOverlap(key) {
for(var i = 0; i < ds_list_size(gradient); i++) {
var _key = gradient[| i];
if(_key == key || _key.time != key.time)
continue;
_key.value = key.value;
ds_list_remove(gradient, key);
}
}
2022-01-13 05:24:03 +01:00
#endregion
#region preset
function loadGradient(path) {
2022-11-18 03:20:31 +01:00
if(path == "") return noone;
if(!file_exists(path)) return noone;
2022-01-13 05:24:03 +01:00
2022-11-18 03:20:31 +01:00
var grad = ds_list_create();
var _t = file_text_open_read(path);
while(!file_text_eof(_t)) {
var key = file_text_readln(_t);
var _col = 0, _pos = 0;
if(string_pos(",", key)) {
var keys = string_splice(key, ",");
if(array_length(keys) != 2) continue;
2022-01-13 05:24:03 +01:00
2022-11-18 03:20:31 +01:00
_col = toNumber(keys[0]);
_pos = toNumber(keys[1]);
} else {
_col = toNumber(key);
if(file_text_eof(_t)) break;
_pos = toNumber(file_text_readln(_t));
2022-01-13 05:24:03 +01:00
}
2022-11-18 03:20:31 +01:00
ds_list_add(grad, new valueKey(_pos, _col));
2022-01-13 05:24:03 +01:00
}
2022-11-18 03:20:31 +01:00
file_text_close(_t);
2022-01-13 05:24:03 +01:00
return grad;
}
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();
2022-11-03 11:44:49 +01:00
sp_preset_w = ui(240 - 32 - 16);
sp_presets = new scrollPane(sp_preset_w, dialog_h - ui(62), function(_y, _m) {
var ww = sp_preset_w - ui(40);
var hh = ui(32);
var yy = _y + ui(8);
var hg = ui(52);
2022-12-19 13:35:30 +01:00
var _hover = sHOVER && sp_presets.hover;
2022-11-18 03:20:31 +01:00
draw_clear_alpha(COLORS.panel_bg_clear, 0);
2022-01-13 05:24:03 +01:00
for(var i = 0; i < ds_list_size(presets); i++) {
2022-12-10 05:06:01 +01:00
var isHover = point_in_rectangle(_m[0], _m[1], ui(4), yy, ui(4) + sp_preset_w - ui(16), yy + hg);
2022-01-13 05:24:03 +01:00
2022-12-10 05:06:01 +01:00
draw_sprite_stretched(THEME.ui_panel_bg, 1, ui(4), yy, sp_preset_w - ui(16), hg);
2022-12-19 13:35:30 +01:00
if(_hover && isHover)
2022-12-10 05:06:01 +01:00
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), hg, COLORS._main_accent, 1);
2022-11-18 03:20:31 +01:00
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
2022-11-03 11:44:49 +01:00
draw_text(ui(16), yy + ui(8), preset_name[| i]);
draw_gradient(ui(16), yy + ui(28), ww, ui(16), presets[| i]);
2022-01-13 05:24:03 +01:00
2022-12-19 13:35:30 +01:00
if(_hover && isHover && mouse_press(mb_left, sFOCUS)) {
var target = presets[| i];
ds_list_clear(gradient);
for( var i = 0; i < ds_list_size(target); i++ ) {
ds_list_add(gradient, new valueKey(target[| i].time, target[| i].value));
2022-11-18 03:20:31 +01:00
}
2022-01-13 05:24:03 +01:00
}
2022-11-03 11:44:49 +01:00
yy += hg + ui(4);
hh += hg + ui(4);
2022-01-13 05:24:03 +01:00
}
return hh;
})
2022-11-18 03:20:31 +01:00
#endregion
#region action
function checkMouse() {}
2022-01-13 05:24:03 +01:00
#endregion