mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-12 07:16:49 +01:00
palette view
This commit is contained in:
parent
3510e1ea2f
commit
d1d810d763
3 changed files with 67 additions and 19 deletions
|
@ -16,6 +16,10 @@ event_inherited();
|
||||||
interactable = true;
|
interactable = true;
|
||||||
drop_target = noone;
|
drop_target = noone;
|
||||||
|
|
||||||
|
mouse_interact = false;
|
||||||
|
|
||||||
|
colors_selecting = [];
|
||||||
|
|
||||||
index_drag_x = 0; index_drag_x_to = 0;
|
index_drag_x = 0; index_drag_x_to = 0;
|
||||||
index_drag_y = 0; index_drag_y_to = 0;
|
index_drag_y = 0; index_drag_y_to = 0;
|
||||||
index_drag_w = 0; index_drag_w_to = 0;
|
index_drag_w = 0; index_drag_w_to = 0;
|
||||||
|
@ -24,7 +28,8 @@ event_inherited();
|
||||||
palette_positions = {}
|
palette_positions = {}
|
||||||
|
|
||||||
setColor = function(color) {
|
setColor = function(color) {
|
||||||
if(index_selecting[1] == 0 || palette == 0) return;
|
if(index_selecting[1] != 1 || palette == 0) return;
|
||||||
|
|
||||||
palette[index_selecting[0]] = color;
|
palette[index_selecting[0]] = color;
|
||||||
|
|
||||||
if(onApply == noone) return;
|
if(onApply == noone) return;
|
||||||
|
|
|
@ -322,9 +322,10 @@ if palette == 0 exit;
|
||||||
selector.setColor(palette[hover]);
|
selector.setColor(palette[hover]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mouse_interact = true;
|
||||||
index_sel_start = hover;
|
index_sel_start = hover;
|
||||||
|
|
||||||
} else if(mouse_click(mb_left, sFOCUS)) {
|
} else if(mouse_click(mb_left, sFOCUS) && mouse_interact) {
|
||||||
|
|
||||||
if(hover > index_sel_start) {
|
if(hover > index_sel_start) {
|
||||||
index_selecting[0] = index_sel_start;
|
index_selecting[0] = index_sel_start;
|
||||||
|
@ -338,10 +339,21 @@ if palette == 0 exit;
|
||||||
index_selecting[0] = hover;
|
index_selecting[0] = hover;
|
||||||
index_selecting[1] = 1;
|
index_selecting[1] = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(mouse_release(mb_left)) mouse_interact = false;
|
||||||
|
|
||||||
|
selector.current_colors = noone;
|
||||||
|
if(index_selecting[1] > 1) {
|
||||||
|
colors_selecting = array_verify(colors_selecting, index_selecting[1]);
|
||||||
|
for(var i = 0; i < index_selecting[1]; i++)
|
||||||
|
colors_selecting[i] = palette[index_selecting[0] + i];
|
||||||
|
selector.current_colors = colors_selecting;
|
||||||
|
}
|
||||||
|
|
||||||
var bx = content_x + content_w - ui(50);
|
var bx = content_x + content_w - ui(50);
|
||||||
var by = pl_y - ui(2);
|
var by = pl_y - ui(2);
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
function colorSelector(onApply = noone) constructor {
|
function colorSelector(onApply = noone) constructor {
|
||||||
self.onApply = onApply;
|
self.onApply = onApply;
|
||||||
|
|
||||||
current_color = c_white;
|
current_color = c_white;
|
||||||
|
current_colors = noone;
|
||||||
|
|
||||||
hue = 1;
|
hue = 1;
|
||||||
sat = 0;
|
sat = 0;
|
||||||
|
@ -35,7 +36,7 @@ function colorSelector(onApply = noone) constructor {
|
||||||
setHSV();
|
setHSV();
|
||||||
}).setSlideType(1);
|
}).setSlideType(1);
|
||||||
|
|
||||||
tb_val= slider(0, 255, 1, function(_val) {
|
tb_val = slider(0, 255, 1, function(_val) {
|
||||||
if(!interactable) return;
|
if(!interactable) return;
|
||||||
val = clamp(_val, 0, 255);
|
val = clamp(_val, 0, 255);
|
||||||
setHSV();
|
setHSV();
|
||||||
|
@ -132,7 +133,6 @@ function colorSelector(onApply = noone) constructor {
|
||||||
|
|
||||||
function setColor(color, _apply = true) {
|
function setColor(color, _apply = true) {
|
||||||
current_color = color;
|
current_color = color;
|
||||||
|
|
||||||
resetHSV(_apply);
|
resetHSV(_apply);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -225,8 +225,8 @@ function colorSelector(onApply = noone) constructor {
|
||||||
draw_surface(side_surface, sel_x, sel_y);
|
draw_surface(side_surface, sel_x, sel_y);
|
||||||
|
|
||||||
BLEND_ADD
|
BLEND_ADD
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, cont_x, cont_y, cont_w, cont_h, c_white, 0.2);
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, cont_x, cont_y, cont_w, cont_h, c_white, 0.2);
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, sel_x, sel_y, sel_w, sel_h, c_white, 0.2);
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, sel_x, sel_y, sel_w, sel_h, c_white, 0.2);
|
||||||
BLEND_NORMAL
|
BLEND_NORMAL
|
||||||
|
|
||||||
#region control
|
#region control
|
||||||
|
@ -243,21 +243,52 @@ function colorSelector(onApply = noone) constructor {
|
||||||
var _sx = sel_x - _p;
|
var _sx = sel_x - _p;
|
||||||
var _sy = (disp_mode == 0? sel_y + ui(hue) : sel_y + ui(256 - val)) - _sh / 2;
|
var _sy = (disp_mode == 0? sel_y + ui(hue) : sel_y + ui(256 - val)) - _sh / 2;
|
||||||
|
|
||||||
|
|
||||||
if(discr) _sc = current_color;
|
if(discr) _sc = current_color;
|
||||||
else _sc = disp_mode == 0? make_color_hsv(hue, 255, 255) : make_color_hsv(hue, 255, val);
|
else _sc = disp_mode == 0? make_color_hsv(hue, 255, 255) : make_color_hsv(hue, 255, val);
|
||||||
|
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _cx - 1, _cy - 1, _cs + 2, _cs + 2, c_black, 0.5);
|
if(current_colors != noone) {
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _sx - 1, _sy - 1, _sw + 2, _sh + 2, c_black, 0.5);
|
var _csz = ui(8);
|
||||||
|
var _ssx = sel_x + sel_w / 2 - _csz / 2;
|
||||||
|
|
||||||
|
BLEND_ADD
|
||||||
|
for (var i = 0, n = array_length(current_colors); i < n; i++) {
|
||||||
|
var _cc = current_colors[i];
|
||||||
|
var _cch = round(color_get_hue(_cc));
|
||||||
|
var _ccs = round(color_get_saturation(_cc));
|
||||||
|
var _ccv = round(color_get_value(_cc));
|
||||||
|
|
||||||
|
var _csy = disp_mode == 0? cont_y + ui(_cch) : cont_y + ui(256 - _ccv);
|
||||||
|
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, _ssx, _csy - _csz / 2, _csz, _csz, c_white, 0.75);
|
||||||
|
|
||||||
|
var _sel = 1 - abs(disp_mode == 0? _cch - hue : _ccv - val) / 32;
|
||||||
|
|
||||||
|
if(_sel <= 0) continue;
|
||||||
|
var _ccx = disp_mode == 0? cont_x + ui(_ccs) : cont_x + ui(_cch);
|
||||||
|
var _ccy = disp_mode == 0? cont_y + ui(256 - _ccv) : cont_y + ui(256 - _ccs);
|
||||||
|
var _cszz = _sel == 1? ui(16) : lerp(ui(6), ui(12), _sel);
|
||||||
|
var _caa = _sel == 1? 1 : lerp(0.25, 0.75, _sel);
|
||||||
|
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, _ccx - _cszz / 2, _ccy - _cszz / 2, _cszz, _cszz, c_white, _caa);
|
||||||
|
}
|
||||||
|
BLEND_NORMAL
|
||||||
|
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _sx - 1, _sy - 1, _sw + 2, _sh + 2, c_black, 0.5);
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _sx, _sy, _sw, _sh, _sc, 1);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _cx - 1, _cy - 1, _cs + 2, _cs + 2, c_black, 0.5);
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _sx - 1, _sy - 1, _sw + 2, _sh + 2, c_black, 0.5);
|
||||||
|
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _sx, _sy, _sw, _sh, _sc, 1);
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _cx, _cy, _cs, _cs, current_color, 1);
|
||||||
|
|
||||||
|
BLEND_ADD
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, _sx, _sy, _sw, _sh, c_white, 0.75);
|
||||||
|
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, _cx, _cy, _cs, _cs, c_white, 0.75);
|
||||||
|
BLEND_NORMAL
|
||||||
|
}
|
||||||
|
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _sx, _sy, _sw, _sh, _sc, 1);
|
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 0, _cx, _cy, _cs, _cs, current_color, 1);
|
|
||||||
|
|
||||||
BLEND_ADD
|
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, _sx, _sy, _sw, _sh, c_white, 0.75);
|
|
||||||
draw_sprite_stretched_ext(THEME.menu_button_mask, 1, _cx, _cy, _cs, _cs, c_white, 0.75);
|
|
||||||
BLEND_NORMAL
|
|
||||||
|
|
||||||
if(mouse_press(mb_left, interactable && focus)) {
|
if(mouse_press(mb_left, interactable && focus)) {
|
||||||
if(point_in_rectangle(mouse_mx, mouse_my, sel_x, sel_y, sel_x + ui(16), sel_y + ui(256)))
|
if(point_in_rectangle(mouse_mx, mouse_my, sel_x, sel_y, sel_x + ui(16), sel_y + ui(256)))
|
||||||
side_dragging = true;
|
side_dragging = true;
|
||||||
|
|
Loading…
Reference in a new issue