mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-12 15:26:33 +01:00
74 lines
No EOL
1.7 KiB
Text
74 lines
No EOL
1.7 KiB
Text
function rotator(_onModify, _step = -1) constructor {
|
|
active = false;
|
|
hover = false;
|
|
|
|
onModify = _onModify;
|
|
step = _step;
|
|
|
|
dragging = false;
|
|
drag_sv = 0;
|
|
drag_sa = 0;
|
|
|
|
real_val = 0;
|
|
|
|
tb_value = new textBox(TEXTBOX_INPUT.number, onModify);
|
|
|
|
static draw = function(_x, _y, _data, _m) {
|
|
var knob_y = _y + ui(48);
|
|
|
|
tb_value.hover = hover;
|
|
tb_value.active = active;
|
|
tb_value.draw(_x + ui(64), knob_y - ui(17), ui(64), TEXTBOX_HEIGHT, _data, _m);
|
|
|
|
draw_sprite_ui_uniform(THEME.rotator_bg, 0, _x, knob_y);
|
|
|
|
var px = _x + lengthdir_x(ui(36), _data);
|
|
var py = knob_y + lengthdir_y(ui(36), _data);
|
|
|
|
if(dragging) {
|
|
var delta = angle_difference(point_direction(_x, knob_y, _m[0], _m[1]), drag_sa);
|
|
var val;
|
|
var real_val = round(delta + drag_sv);
|
|
|
|
if(key_mod_press(CTRL))
|
|
val = round(real_val / 15) * 15;
|
|
else
|
|
val = real_val;
|
|
|
|
if(step != -1)
|
|
val = round(real_val / step) * step;
|
|
|
|
draw_sprite_ui_uniform(THEME.rotator_knob, 1, px, py);
|
|
|
|
if(val != drag_sv) {
|
|
onModify(val);
|
|
UNDO_HOLDING = true;
|
|
}
|
|
|
|
drag_sa = point_direction(_x, knob_y, _m[0], _m[1]);
|
|
drag_sv = real_val;
|
|
|
|
if(mouse_release(mb_left)) {
|
|
dragging = false;
|
|
UNDO_HOLDING = false;
|
|
}
|
|
|
|
} else if(hover && point_in_circle(_m[0], _m[1], _x, knob_y, ui(48))) {
|
|
draw_sprite_ui_uniform(THEME.rotator_knob, 1, px, py);
|
|
|
|
if(mouse_press(mb_left, active)) {
|
|
dragging = true;
|
|
drag_sv = _data;
|
|
drag_sa = point_direction(_x, knob_y, _m[0], _m[1]);
|
|
}
|
|
} else {
|
|
draw_sprite_ui_uniform(THEME.rotator_knob, 0, px, py);
|
|
}
|
|
|
|
draw_set_text(f_p0, fa_center, fa_center, COLORS._main_text);
|
|
draw_text(_x, knob_y, string(_data));
|
|
|
|
active = false;
|
|
hover = false;
|
|
}
|
|
} |