mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-12 15:26:33 +01:00
128 lines
No EOL
3.8 KiB
Text
128 lines
No EOL
3.8 KiB
Text
function surfaceBox(_onModify, def_path = "") : widget() constructor {
|
|
onModify = _onModify;
|
|
self.def_path = def_path;
|
|
|
|
open = false;
|
|
open_rx = 0;
|
|
open_ry = 0;
|
|
|
|
align = fa_center;
|
|
display_data = {};
|
|
|
|
cb_atlas_crop = new checkBox(function() {
|
|
display_data.atlas_crop = !display_data.atlas_crop;
|
|
display_data.update();
|
|
});
|
|
|
|
static trigger = function() {
|
|
open = true;
|
|
with(dialogCall(o_dialog_assetbox, x + w + open_rx, y + open_ry)) {
|
|
target = other;
|
|
gotoDir(other.def_path);
|
|
}
|
|
}
|
|
|
|
static setInteract = function(interactable) {
|
|
self.interactable = interactable;
|
|
cb_atlas_crop.interactable = true;
|
|
}
|
|
|
|
static drawParam = function(params) {
|
|
return draw(params.x, params.y, params.w, params.h, params.data, params.display_data, params.m, params.rx, params.ry);
|
|
}
|
|
|
|
static draw = function(_x, _y, _w, _h, _surface, _display_data, _m, _rx, _ry) {
|
|
_h = ui(96);
|
|
|
|
x = _x;
|
|
y = _y;
|
|
w = _w;
|
|
h = _h;
|
|
open_rx = _rx;
|
|
open_ry = _ry;
|
|
display_data = _display_data;
|
|
|
|
var hoverRect = point_in_rectangle(_m[0], _m[1], _x, _y, _x + _w, _y + _h);
|
|
var _type = VALUE_TYPE.surface;
|
|
|
|
var _surf_single = _surface;
|
|
if(is_array(_surf_single) && !array_empty(_surf_single))
|
|
_surf_single = _surf_single[0];
|
|
|
|
if(is_instanceof(_surf_single, dynaSurf)) {
|
|
_type = VALUE_TYPE.dynaSurface;
|
|
} else if(is_instanceof(_surf_single, SurfaceAtlas)) {
|
|
_type = VALUE_TYPE.atlas;
|
|
}
|
|
|
|
if(!open) {
|
|
draw_sprite_stretched(THEME.textbox, 3, _x, _y, _w, _h);
|
|
|
|
if(_type == VALUE_TYPE.surface && hover && hoverRect) {
|
|
draw_sprite_stretched(THEME.textbox, 1, _x, _y, _w, _h);
|
|
if(mouse_press(mb_left, active))
|
|
trigger();
|
|
|
|
if(mouse_click(mb_left, active))
|
|
draw_sprite_stretched_ext(THEME.textbox, 2, _x, _y, _w, _h, COLORS._main_accent, 1);
|
|
} else {
|
|
draw_sprite_stretched_ext(THEME.textbox, 0, _x, _y, _w, _h, c_white, 0.5 + 0.5 * interactable);
|
|
if(mouse_press(mb_left)) deactivate();
|
|
}
|
|
|
|
var pad = ui(12);
|
|
var sw = min(_w - pad, _h - pad);
|
|
var sh = sw;
|
|
|
|
var sx0 = _x + _w / 2 - sw / 2;
|
|
var sx1 = sx0 + sw;
|
|
var sy0 = _y + _h / 2 - sh / 2;
|
|
var sy1 = sy0 + sh;
|
|
|
|
draw_set_color(COLORS.widget_surface_frame);
|
|
draw_rectangle(sx0, sy0, sx1, sy1, true);
|
|
|
|
if(is_array(_surface) && array_length(_surface))
|
|
_surface = _surface[safe_mod(round(current_time / 250), array_length(_surface))];
|
|
|
|
if(is_surface(_surface)) {
|
|
var sfw = surface_get_width_safe(_surface);
|
|
var sfh = surface_get_height_safe(_surface);
|
|
var ss = min(sw / sfw, sh / sfh);
|
|
var _sx = sx0 + sw / 2 - ss * sfw / 2;
|
|
var _sy = sy0 + sh / 2 - ss * sfh / 2;
|
|
|
|
draw_surface_ext_safe(_surface, _sx, _sy, ss, ss, 0, c_white, 1);
|
|
}
|
|
|
|
if(_type == VALUE_TYPE.surface)
|
|
draw_sprite_ui_uniform(THEME.scroll_box_arrow, 0, _x + _w - ui(20), _y + _h / 2, 1, COLORS._main_icon);
|
|
}
|
|
|
|
//if(_type == VALUE_TYPE.atlas) {
|
|
// draw_sprite_stretched_ext(THEME.ui_panel_inner_bg, 1, _x, _y + _h + ui(8), _w, ui(40), COLORS.node_composite_bg_blend, 1);
|
|
|
|
// var set_y = _y + _h + ui(16);
|
|
// var set_w = ui(64);
|
|
// var set_h = ui(24);
|
|
|
|
// draw_set_text(f_p0, fa_left, fa_center, COLORS._main_text);
|
|
// draw_text_add(_x + ui(16), set_y + set_h / 2, __txt("Crop atlas"));
|
|
|
|
// cb_atlas_crop.drawParam(new widgetParam(_x + _w - set_w, set_y, set_w, set_h, display_data.atlas_crop,, _m, _rx, _ry));
|
|
//}
|
|
|
|
if(WIDGET_CURRENT == self)
|
|
draw_sprite_stretched_ext(THEME.widget_selecting, 0, _x - ui(3), _y - ui(3), _w + ui(6), _h + ui(6), COLORS._main_accent, 1);
|
|
|
|
if(DRAGGING && DRAGGING.type == "Asset" && hover && hoverRect) {
|
|
draw_sprite_stretched_ext(THEME.ui_panel_active, 0, _x, _y, _w, _h, COLORS._main_value_positive, 1);
|
|
if(mouse_release(mb_left))
|
|
onModify(DRAGGING.data.path);
|
|
}
|
|
|
|
resetFocus();
|
|
|
|
return h;
|
|
}
|
|
} |