mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2024-12-25 22:46:19 +01:00
133 lines
No EOL
3.4 KiB
Text
133 lines
No EOL
3.4 KiB
Text
function rotator(_onModify, _step = -1) : widget() constructor {
|
|
onModify = _onModify;
|
|
valStep = _step;
|
|
|
|
scale = 1;
|
|
dragging = noone;
|
|
drag_sv = 0;
|
|
real_val = 0;
|
|
slide_speed = 1 / 10;
|
|
side_button = noone;
|
|
|
|
spr_bg = THEME.rotator_bg;
|
|
spr_knob = THEME.rotator_knob;
|
|
|
|
tb_value = new textBox(TEXTBOX_INPUT.number, onModify).setSlidable([ 0.1, 15 ], true);
|
|
tb_value.hide = true;
|
|
|
|
halign = fa_center;
|
|
|
|
static setInteract = function(interactable = noone) { #region
|
|
self.interactable = interactable;
|
|
tb_value.interactable = interactable;
|
|
} #endregion
|
|
|
|
static register = function(parent = noone) { #region
|
|
tb_value.register(parent);
|
|
} #endregion
|
|
|
|
static isHovering = function() { return dragging || tb_value.hovering; }
|
|
|
|
static drawParam = function(params) { #region
|
|
setParam(params);
|
|
tb_value.setParam(params);
|
|
|
|
return draw(params.x, params.y, params.w, params.h, params.data, params.m);
|
|
} #endregion
|
|
|
|
static draw = function(_x, _y, _w, _h, _data, _m, draw_tb = true) { #region
|
|
x = _x;
|
|
y = _y;
|
|
w = _w;
|
|
h = _h;
|
|
|
|
if(!is_real(_data)) return;
|
|
|
|
var _r = _h;
|
|
var _bs = min(_h, ui(32));
|
|
var _drawRot = _w - _r > ui(64);
|
|
|
|
if(_drawRot && side_button) {
|
|
side_button.setFocusHover(active, hover);
|
|
side_button.draw(_x + _w - _bs, _y + _h / 2 - _bs / 2, _bs, _bs, _m, THEME.button_hide);
|
|
_w -= _bs + ui(4);
|
|
}
|
|
|
|
var _tx = _drawRot? _x + _r + ui(4) : _x;
|
|
var _tw = _drawRot? _w - _r - ui(4) : _w;
|
|
|
|
draw_sprite_stretched_ext(THEME.textbox, 3, _tx, _y, _tw, _h, c_white, 1);
|
|
draw_sprite_stretched_ext(THEME.textbox, 0, _tx, _y, _tw, _h, c_white, 0.5 + 0.5 * interactable);
|
|
|
|
tb_value.setFocusHover(active, hover);
|
|
tb_value.draw(_tx, _y, _tw, _h, _data, _m);
|
|
|
|
if(_drawRot) {
|
|
var _kx = _x + _r / 2;
|
|
var _ky = _y + _r / 2;
|
|
var _kr = (_r - ui(12)) / 2;
|
|
var _kc = COLORS._main_icon;
|
|
|
|
if(dragging) {
|
|
_kc = COLORS._main_icon_light;
|
|
|
|
var real_val = dragging.delta_acc + drag_sv;
|
|
var val = key_mod_press(CTRL)? value_snap(real_val, 15) : real_val;
|
|
|
|
if(valStep != -1) val = value_snap(real_val, valStep);
|
|
|
|
if(onModify(val))
|
|
UNDO_HOLDING = true;
|
|
|
|
MOUSE_BLOCK = true;
|
|
|
|
if(mouse_check_button_pressed(mb_right)) {
|
|
onModify(drag_sv);
|
|
instance_destroy(dragging);
|
|
dragging = noone;
|
|
UNDO_HOLDING = false;
|
|
|
|
} else if(mouse_release(mb_left)) {
|
|
instance_destroy(dragging);
|
|
dragging = noone;
|
|
UNDO_HOLDING = false;
|
|
}
|
|
|
|
} else if(hover && point_in_rectangle(_m[0], _m[1], _x, _y, _x + _r, _y + _r)) {
|
|
_kc = COLORS._main_icon_light;
|
|
|
|
if(mouse_press(mb_left, active)) {
|
|
dragging = instance_create(0, 0, rotator_Rotator).init(_m, _kx, _ky);
|
|
drag_sv = _data;
|
|
}
|
|
|
|
if(key_mod_press(SHIFT)) {
|
|
var amo = 1;
|
|
if(key_mod_press(CTRL)) amo *= 10;
|
|
if(key_mod_press(ALT)) amo /= 10;
|
|
|
|
if(mouse_wheel_down()) onModify(_data + amo * SCROLL_SPEED);
|
|
if(mouse_wheel_up()) onModify(_data - amo * SCROLL_SPEED);
|
|
}
|
|
}
|
|
|
|
shader_set(sh_widget_rotator);
|
|
shader_set_color("color", _kc);
|
|
shader_set_f("side", _r);
|
|
shader_set_f("angle", degtorad(_data));
|
|
|
|
draw_sprite_stretched(s_fx_pixel, 0, _x, _y, _r, _r);
|
|
shader_reset();
|
|
}
|
|
|
|
resetFocus();
|
|
|
|
return h;
|
|
} #endregion
|
|
|
|
static clone = function() { #region
|
|
var cln = new rotator(onModify, valStep);
|
|
|
|
return cln;
|
|
} #endregion
|
|
} |