Flexible panel

This commit is contained in:
Tanasart 2023-03-11 12:40:34 +07:00
parent 73a735d5f0
commit 9155123dbe
16 changed files with 567 additions and 255 deletions

Binary file not shown.

View file

@ -1,29 +1,43 @@
{ {
"panel": { "panel": {
"split": "h", "split": "v",
"width": -400, "width": 40,
"content": [ "content": [{
"content": "Panel_Menu"
},
{ {
"split": "v", "split": "h",
"width": -48, "width": -400,
"content": [ "content": [{
{
"split": "v", "split": "v",
"width": -400, "width": -48,
"content": [ "content": [{
{ "content": "PREVIEW" }, "split": "v",
{ "content": "GRAPH" } "width": -400,
"content": [{
"content": "Panel_Preview"
},
{
"content": "Panel_Graph"
}
]
},
{
"content": "Panel_Animation"
}
] ]
}, },
{ "content": "ANIMATION" } {
"content": "Panel_Inspector"
}
] ]
}, }
{ "content": "INSPECTOR" }
] ]
}, },
"collection": { "Panel_Collection": {
"parent": "GRAPH", "parent": "Panel_Graph",
"width": 460, "width": 460,
"split": "h" "split": "h",
"index": 0
} }
} }

View file

@ -1,29 +1,43 @@
{ {
"panel": { "panel": {
"split": "h", "split": "v",
"width": -400, "width": 40,
"content": [ "content": [{
"content": "Panel_Menu"
},
{ {
"split": "v", "split": "h",
"width": -300, "width": -400,
"content": [ "content": [{
{ "split": "v",
"split": "h", "width": -300,
"width": 400, "content": [{
"content": [ "split": "h",
{ "content": "PREVIEW" }, "width": 400,
{ "content": "GRAPH" } "content": [{
"content": "Panel_Preview"
},
{
"content": "Panel_Graph"
}
]
},
{
"content": "Panel_Animation"
}
] ]
}, },
{ "content": "ANIMATION" } {
"content": "Panel_Inspector"
}
] ]
}, }
{ "content": "INSPECTOR" }
] ]
}, },
"collection": { "Panel_Collection": {
"parent": "ANIMATION", "parent": "Panel_Animation",
"width": 500, "width": 500,
"split": "h" "split": "h",
"index": 0
} }
} }

View file

@ -54,7 +54,7 @@ event_inherited();
return; return;
PREF_MAP[? "display_scaling"] = PREF_MAP[? "_display_scaling"]; PREF_MAP[? "display_scaling"] = PREF_MAP[? "_display_scaling"];
setPanel(); resetPanel();
loadFonts(); loadFonts();
time_source_start(time_source_create(time_source_global, 1, time_source_units_frames, onResize)); time_source_start(time_source_create(time_source_global, 1, time_source_units_frames, onResize));
@ -293,6 +293,15 @@ event_inherited();
PREF_MAP[? "connection_line_aa"] = max(1, real(str)); PREF_MAP[? "connection_line_aa"] = max(1, real(str));
PREF_SAVE(); PREF_SAVE();
}) })
])
ds_list_add(pref_appr, [
get_text("panel_menu_right_control", "Use Windows style window control."),
"panel_menu_right_control",
new checkBox(function() {
PREF_MAP[? "panel_menu_right_control"] = !PREF_MAP[? "panel_menu_right_control"];
PREF_SAVE();
})
]); ]);
#endregion #endregion

View file

@ -27,6 +27,7 @@
depth = 0; depth = 0;
win_wp = WIN_W; win_wp = WIN_W;
win_hp = WIN_H; win_hp = WIN_H;
win_resize = false;
room_width = WIN_W; room_width = WIN_W;
room_height = WIN_H; room_height = WIN_H;

View file

@ -24,7 +24,7 @@ if(OS == os_windows && gameframe_is_minimized()) {
#endregion #endregion
#region panels #region panels
if(PANEL_MAIN == 0) setPanel(); if(PANEL_MAIN == 0) resetPanel();
var surf = surface_get_target(); var surf = surface_get_target();
try try

View file

@ -144,5 +144,9 @@
#endregion #endregion
//print("===== Step end ====="); //print("===== Step end =====");
if(keyboard_check_pressed(ord("Q"))) if(keyboard_check_pressed(ord("Q"))) {
panelSerialize(); if(key_mod_press(CTRL))
print(panelSerializeArray());
else
print(panelSerialize());
}

View file

@ -8,8 +8,12 @@
} }
CURSOR = cr_default; CURSOR = cr_default;
if(!gameframe_is_minimized() && (win_wp != WIN_W || win_hp != WIN_H) && (WIN_W > 1 && WIN_H > 1)) if(!gameframe_is_minimized() && (win_wp != WIN_W || win_hp != WIN_H) && (WIN_W > 1 && WIN_H > 1)) {
if(!win_resize) CURRENT_PANEL = panelSerialize();
display_refresh(); display_refresh();
win_resize = true;
} else
win_resize = false;
#endregion #endregion
#region focus #region focus

View file

@ -7,7 +7,7 @@ function display_refresh() {
display_set_gui_size(WIN_SW, WIN_SH); display_set_gui_size(WIN_SW, WIN_SH);
clearPanel(); clearPanel();
setPanel(); resetPanel();
PANEL_GRAPH.fullView(); PANEL_GRAPH.fullView();
PANEL_PREVIEW.fullView(); PANEL_PREVIEW.fullView();

View file

@ -77,6 +77,43 @@ function Panel_Animation() : PanelContent() constructor {
prev_cache = array_create(ANIMATOR.frames_total); prev_cache = array_create(ANIMATOR.frames_total);
control_buttons = [
[ function() { return get_text("stop", "Stop"); },
function() { return 4; },
function() { return ANIMATOR.is_playing? COLORS._main_accent : COLORS._main_icon; },
function() {
ANIMATOR.is_playing = false;
ANIMATOR.setFrame(0);
} ],
[ function() { return ANIMATOR.is_playing? get_text("pause", "Pause") : get_text("play", "Play"); },
function() { return !ANIMATOR.is_playing; },
function() { return ANIMATOR.is_playing? COLORS._main_accent : COLORS._main_icon; },
function() {
ANIMATOR.is_playing = !ANIMATOR.is_playing;
ANIMATOR.frame_progress = true;
} ],
[ function() { return get_text("panel_animation_go_to_first_frame", "Go to first frame"); },
function() { return 3; },
function() { return COLORS._main_icon; },
function() { ANIMATOR.setFrame(0); }
],
[ function() { return get_text("panel_animation_go_to_last_frame", "Go to last frame"); },
function() { return 2; },
function() { return COLORS._main_icon; },
function() { ANIMATOR.setFrame(ANIMATOR.frames_total - 1); }
],
[ function() { return get_text("panel_animation_previous_frame", "Previous frame"); },
function() { return 5; },
function() { return COLORS._main_icon; },
function() { ANIMATOR.setFrame(ANIMATOR.real_frame - 1); }
],
[ function() { return get_text("panel_animation_next_frame", "Next frame"); },
function() { return 6; },
function() { return COLORS._main_icon; },
function() { ANIMATOR.setFrame(ANIMATOR.real_frame + 1); }
],
];
addHotkey("", "Play/Pause", vk_space, MOD_KEY.none, function() { addHotkey("", "Play/Pause", vk_space, MOD_KEY.none, function() {
ANIMATOR.is_playing = !ANIMATOR.is_playing; ANIMATOR.is_playing = !ANIMATOR.is_playing;
ANIMATOR.current_frame = -1; ANIMATOR.current_frame = -1;
@ -1359,44 +1396,63 @@ function Panel_Animation() : PanelContent() constructor {
function drawAnimationControl() { function drawAnimationControl() {
var bx = ui(8); var bx = ui(8);
if(w < ui(348))
bx = w / 2 - ui(36) * 6 / 2;
var by = h - ui(40); var by = h - ui(40);
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, get_text("stop", "Stop"), THEME.sequence_control, 4, ANIMATOR.is_playing? COLORS._main_accent : COLORS._main_icon) == 2) {
ANIMATOR.is_playing = false; if(w < ui(348)) {
ANIMATOR.setFrame(0); bx = w / 2 - ui(36) * 6 / 2;
by = h - ui(40);
} }
bx += ui(36); for( var i = 0; i < array_length(control_buttons); i++ ) {
var ind = !ANIMATOR.is_playing; var but = control_buttons[i];
var cc = ANIMATOR.is_playing? COLORS._main_accent : COLORS._main_icon; var txt = but[0]();
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, ANIMATOR.is_playing? get_text("pause", "Pause") : get_text("play", "Play"), THEME.sequence_control, ind, cc) == 2) { var ind = but[1]();
ANIMATOR.is_playing = !ANIMATOR.is_playing; var cc = but[2]();
ANIMATOR.frame_progress = true; var fnc = but[3];
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, txt, THEME.sequence_control, ind, cc) == 2)
fnc();
bx += ui(36);
} }
bx += ui(36); if(w < ui(348)) {
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, get_text("panel_animation_go_to_first_frame", "Go to first frame"), THEME.sequence_control, 3) == 2) { if(h < 72) return;
ANIMATOR.setFrame(0);
}
bx += ui(36); var y0 = ui(8);
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, get_text("panel_animation_go_to_last_frame", "Go to last frame"), THEME.sequence_control, 2) == 2) { var y1 = h - ui(48);
ANIMATOR.setFrame(ANIMATOR.frames_total - 1); var cy = (y0 + y1) / 2;
}
bx += ui(36); draw_sprite_stretched(THEME.ui_panel_bg, 1, ui(8), y0, w - ui(16), y1 - y0);
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, get_text("panel_animation_previous_frame", "Previous frame"), THEME.sequence_control, 5) == 2) {
ANIMATOR.setFrame(ANIMATOR.real_frame - 1);
}
bx += ui(36); var pw = w - ui(16);
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, get_text("panel_animation_next_frame", "Next frame"), THEME.sequence_control, 6) == 2) { var px = ui(8) + pw * (ANIMATOR.current_frame / ANIMATOR.frames_total);
ANIMATOR.setFrame(ANIMATOR.real_frame + 1); draw_set_color(COLORS._main_accent);
} draw_line(px, y0, px, y1);
if(w < ui(348)) return; if(point_in_rectangle(mx, my, ui(8), y0, w - ui(16), y1)) {
if(mouse_click(mb_left, pFOCUS)) {
var rfrm = (mx - ui(8)) / (w - ui(16)) * ANIMATOR.frames_total;
ANIMATOR.setFrame(clamp(rfrm, 0, ANIMATOR.frames_total - 1));
}
}
var txt = string(ANIMATOR.current_frame + 1) + "/" + string(ANIMATOR.frames_total);
if(h < 100) {
draw_set_text(f_p1, fa_left, fa_center, COLORS._main_text_sub);
draw_text(ui(16), cy, "Frame");
draw_set_text(f_p1, fa_right, fa_center, ANIMATOR.is_playing? COLORS._main_accent : COLORS._main_text_sub);
draw_text(w - ui(16), cy, txt);
} else {
draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text_sub);
draw_text(w / 2, cy - ui(16), "Frame");
draw_set_text(f_h3, fa_center, fa_center, ANIMATOR.is_playing? COLORS._main_accent : COLORS._main_text_sub);
draw_text(w / 2, cy + ui(6), txt);
}
return;
}
bx = w - ui(44); bx = w - ui(44);
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, get_text("panel_animation_animation_settings", "Animation settings"), THEME.animation_setting, 2) == 2) if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, get_text("panel_animation_animation_settings", "Animation settings"), THEME.animation_setting, 2) == 2)
@ -1420,7 +1476,7 @@ function Panel_Animation() : PanelContent() constructor {
draw_clear_alpha(COLORS.panel_bg_clear, 0); draw_clear_alpha(COLORS.panel_bg_clear, 0);
if(w < ui(348)) { if(w < ui(348)) {
draw_sprite_stretched(THEME.ui_panel_bg, 1, ui(8), h - ui(32 + 8), w - ui(16), ui(32)); //
} else { } else {
drawTimeline(); drawTimeline();
if(dope_sheet_h > 8) if(dope_sheet_h > 8)

View file

@ -19,7 +19,7 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
y = _y; y = _y;
w = _w; w = _w;
h = _h; h = _h;
split = -1; split = "";
min_w = ui(32); min_w = ui(32);
min_h = ui(32); min_h = ui(32);
@ -48,15 +48,8 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
} }
function refresh() { function refresh() {
if(is_surface(content_surface) && surface_exists(content_surface)) content_surface = surface_verify(content_surface, w, h);
surface_size_to(content_surface, w, h); mask_surface = surface_verify(mask_surface, w, h);
else
content_surface = surface_create_valid(w, h);
if(is_surface(mask_surface) && surface_exists(mask_surface))
surface_size_to(mask_surface, w, h);
else
mask_surface = surface_create_valid(w, h);
resetMask(); resetMask();
if(content != noone) if(content != noone)
@ -98,23 +91,24 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
return true; return true;
} }
function refreshSize() { //refresh content surface after resize function refreshSize(recur = true) { //refresh content surface after resize
//__debug_counter("refresh size");
if(content) { if(content) {
content.w = w; content.w = w;
content.h = h; content.h = h;
content.onResize(); content.onResize();
} else if(ds_list_size(childs) == 2) { } else if(ds_list_size(childs) == 2) {
print("=== Refreshing (" + string(w) + ", " + string(h) + ") " + string(split) + " ==="); //print("=== Refreshing (" + string(w) + ", " + string(h) + ") " + string(split) + " ===");
var tw = childs[| 0].w + childs[| 1].w; var tw = childs[| 0].w + childs[| 1].w;
var th = childs[| 0].h + childs[| 1].h; var th = childs[| 0].h + childs[| 1].h;
var fixChild = childs[| 1].x == x && childs[| 1].y == y; var fixChild = split == "h"? childs[| 1].x < childs[| 0].x : childs[| 1].y < childs[| 0].y;
childs[| fixChild].x = x; childs[| fixChild].x = x;
childs[| fixChild].y = y; childs[| fixChild].y = y;
if(split == 0) { if(split == "h") {
childs[| fixChild].w = childs[| fixChild].w / tw * w; childs[| fixChild].w = childs[| fixChild].w / tw * w;
childs[| fixChild].h = h; childs[| fixChild].h = h;
@ -123,7 +117,10 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
childs[| !fixChild].w = w - childs[| fixChild].w; childs[| !fixChild].w = w - childs[| fixChild].w;
childs[| !fixChild].h = h; childs[| !fixChild].h = h;
} else if(split == 1) {
childs[| fixChild].anchor = ANCHOR.left;
childs[| !fixChild].anchor = ANCHOR.right;
} else if(split == "v") {
childs[| fixChild].w = w; childs[| fixChild].w = w;
childs[| fixChild].h = childs[| fixChild].h / th * h; childs[| fixChild].h = childs[| fixChild].h / th * h;
@ -132,8 +129,12 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
childs[| !fixChild].w = w; childs[| !fixChild].w = w;
childs[| !fixChild].h = h - childs[| fixChild].h; childs[| !fixChild].h = h - childs[| fixChild].h;
childs[| fixChild].anchor = ANCHOR.top;
childs[| !fixChild].anchor = ANCHOR.bottom;
} }
if(recur)
for(var i = 0; i < ds_list_size(childs); i++) { for(var i = 0; i < ds_list_size(childs); i++) {
childs[| i].refreshSize(); childs[| i].refreshSize();
} }
@ -157,19 +158,7 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
w = max(w + dw, min_w); w = max(w + dw, min_w);
h = max(h + dh, min_h); h = max(h + dh, min_h);
if(w > 1 && h > 1) { refreshSize(false);
if(is_surface(content_surface))
surface_size_to(content_surface, w, h);
if(is_surface(mask_surface))
surface_size_to(mask_surface, w, h);
else
mask_surface = surface_create_valid(w, h);
resetMask();
}
refreshSize();
} }
function set(_content) { function set(_content) {
@ -178,12 +167,15 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
} }
function split_h(_w) { function split_h(_w) {
if(abs(_w) > w) return noone; if(abs(_w) > w) {
print("Error: Split panel larger than size w (" + string(_w) + " > " + string(w) + ")");
return noone;
}
if(_w < 0) _w = w + _w; if(_w < 0) _w = w + _w;
var _panelParent = new Panel(parent, x, y, w, h); var _panelParent = new Panel(parent, x, y, w, h);
_panelParent.anchor = anchor; _panelParent.anchor = anchor;
_panelParent.split = 0; _panelParent.split = "h";
var _panelL = self; var _panelL = self;
ds_list_add(_panelParent.childs, _panelL); ds_list_add(_panelParent.childs, _panelL);
@ -211,12 +203,15 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
} }
function split_v(_h) { function split_v(_h) {
if(abs(_h) > h) return noone; if(abs(_h) > h) {
print("Error: Split panel larger than size h (" + string(_h) + " > " + string(h) + ")");
return noone;
}
if(_h < 0) _h = h + _h; if(_h < 0) _h = h + _h;
var _panelParent = new Panel(parent, x, y, w, h); var _panelParent = new Panel(parent, x, y, w, h);
_panelParent.anchor = anchor; _panelParent.anchor = anchor;
_panelParent.split = 1; _panelParent.split = "v";
var _panelT = self; var _panelT = self;
ds_list_add(_panelParent.childs, _panelT); ds_list_add(_panelParent.childs, _panelT);
@ -399,6 +394,9 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
break; break;
} }
} }
if(self == PANEL_MAIN && o_main.panel_dragging != noone && key_mod_press(CTRL))
checkHover();
} }
function drawPanel() { function drawPanel() {
@ -415,7 +413,9 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
resetMask(); resetMask();
} }
if(!is_surface(content_surface)) content_surface = surface_create_valid(w, h); if(!is_surface(content_surface))
content_surface = surface_create_valid(w, h);
surface_set_target(content_surface); surface_set_target(content_surface);
draw_clear(COLORS.panel_bg_clear); draw_clear(COLORS.panel_bg_clear);
if(content) { if(content) {
@ -442,58 +442,71 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
var ind = !ds_list_find_index(parent.childs, self); //index of the other child var ind = !ds_list_find_index(parent.childs, self); //index of the other child
var sib = parent.childs[| ind]; var sib = parent.childs[| ind];
if(parent.childs[| ind].content == noone) { //other child is compound panel if(sib.content == noone && ds_list_size(sib.childs) == 2) { //other child is compound panel
var gparent = parent.parent; var gparent = parent.parent;
var pind = ds_list_find_index(gparent.childs, parent); //index of parent in grandparent object if(gparent == noone) {
gparent.childs[| pind] = sib; sib.x = PANEL_MAIN.x; sib.y = PANEL_MAIN.y;
gparent.refreshSize(); sib.w = PANEL_MAIN.w; sib.h = PANEL_MAIN.h;
} else { //other child is content panel, set parent to content panel
PANEL_MAIN = sib;
sib.parent = noone;
PANEL_MAIN.refreshSize();
} else {
var pind = ds_list_find_index(gparent.childs, parent); //index of parent in grandparent object
gparent.childs[| pind] = sib; //replace parent with sibling
sib.parent = gparent;
gparent.refreshSize();
}
} else if(sib.content != noone) { //other child is content panel, set parent to content panel
parent.set(sib.content); parent.set(sib.content);
ds_list_clear(parent.childs); ds_list_clear(parent.childs);
} }
} }
} }
if(o_main.panel_dragging != noone && m_ot) { if(o_main.panel_dragging != noone && m_ot && !key_mod_press(CTRL))
var dx = (mouse_mx - x) / w; checkHover();
var dy = (mouse_my - y) / h; }
var p = ui(8);
draw_set_color(COLORS._main_accent); function checkHover() {
o_main.panel_hovering = self; var dx = (mouse_mx - x) / w;
var dy = (mouse_my - y) / h;
var p = ui(8);
if(dx + dy > 1) { draw_set_color(COLORS._main_accent);
if((1 - dx) + dy > 1) { o_main.panel_hovering = self;
draw_set_alpha(.4);
draw_roundrect_ext(x + p, y + h / 2 + p, x + w - p, y + h - p, 8, 8, false);
draw_set_alpha(1.);
draw_roundrect_ext(x + p, y + h / 2 + p, x + w - p, y + h - p, 8, 8, true);
o_main.panel_split = 3; if(dx + dy > 1) {
} else { if((1 - dx) + dy > 1) {
draw_set_alpha(.4); draw_set_alpha(.4);
draw_roundrect_ext(x + p + w / 2, y + p, x + w - p, y + h - p, 8, 8, false); draw_roundrect_ext(x + p, y + h / 2 + p, x + w - p, y + h - p, 8, 8, false);
draw_set_alpha(1.); draw_set_alpha(1.);
draw_roundrect_ext(x + p + w / 2, y + p, x + w - p, y + h - p, 8, 8, true); draw_roundrect_ext(x + p, y + h / 2 + p, x + w - p, y + h - p, 8, 8, true);
o_main.panel_split = 1; o_main.panel_split = 3;
}
} else { } else {
if((1 - dx) + dy > 1) { draw_set_alpha(.4);
draw_set_alpha(.4); draw_roundrect_ext(x + p + w / 2, y + p, x + w - p, y + h - p, 8, 8, false);
draw_roundrect_ext(x + p, y + p, x + w / 2 - p, y + h - p, 8, 8, false); draw_set_alpha(1.);
draw_set_alpha(1.); draw_roundrect_ext(x + p + w / 2, y + p, x + w - p, y + h - p, 8, 8, true);
draw_roundrect_ext(x + p, y + p, x + w / 2 - p, y + h - p, 8, 8, true);
o_main.panel_split = 2; o_main.panel_split = 1;
} else { }
draw_set_alpha(.4); } else {
draw_roundrect_ext(x + p, y + p, x + w - p, y + h / 2 - p, 8, 8, false); if((1 - dx) + dy > 1) {
draw_set_alpha(1.); draw_set_alpha(.4);
draw_roundrect_ext(x + p, y + p, x + w - p, y + h / 2 - p, 8, 8, true); draw_roundrect_ext(x + p, y + p, x + w / 2 - p, y + h - p, 8, 8, false);
draw_set_alpha(1.);
draw_roundrect_ext(x + p, y + p, x + w / 2 - p, y + h - p, 8, 8, true);
o_main.panel_split = 0; o_main.panel_split = 2;
} } else {
draw_set_alpha(.4);
draw_roundrect_ext(x + p, y + p, x + w - p, y + h / 2 - p, 8, 8, false);
draw_set_alpha(1.);
draw_roundrect_ext(x + p, y + p, x + w - p, y + h / 2 - p, 8, 8, true);
o_main.panel_split = 0;
} }
} }
} }

View file

@ -38,65 +38,91 @@
} }
function loadPanelStruct(panel, str) { function loadPanelStruct(panel, str) {
if(variable_struct_exists(str, "split")) { if(variable_struct_exists(str, "split") && is_array(str.content)) {
var pan = panel; var pan = panel;
if(str.split == "v") if(str.split == "v")
pan = panel.split_v(ui(str.width)); pan = panel.split_v(ui(str.width));
else if(str.split == "h") else if(str.split == "h")
pan = panel.split_h(ui(str.width)); pan = panel.split_h(ui(str.width));
if(variable_struct_exists(str, "content")) { if(pan != noone) {
loadPanelStruct(pan[0], str.content[0]); loadPanelStruct(pan[0], str.content[0]);
loadPanelStruct(pan[1], str.content[1]); loadPanelStruct(pan[1], str.content[1]);
} }
} else if(variable_struct_exists(str, "content")) } else {
panel.set(getPanelFromName(str.content)); panel.set(getPanelFromName(str.content));
}
} }
function getPanelFromName(name) { function getPanelFromName(name) {
switch(name) { switch(name) {
case "INSPECTOR" : return PANEL_INSPECTOR; case "Panel_Menu" : return PANEL_MENU;
case "ANIMATION" : return PANEL_ANIMATION; case "Panel_Inspector" : return PANEL_INSPECTOR;
case "PREVIEW" : return PANEL_PREVIEW; case "Panel_Animation" : return PANEL_ANIMATION;
case "GRAPH" : return PANEL_GRAPH; case "Panel_Preview" : return PANEL_PREVIEW;
case "Panel_Graph" : return PANEL_GRAPH;
case "Panel_Collection" : return PANEL_COLLECTION;
} }
return noone; return noone;
} }
function loadPanel(path, panel) { function loadPanel(path, panel) {
var f = json_load_struct(path); CURRENT_PANEL = json_load_struct(path);
loadPanelStruct(panel, f.panel); loadPanelStruct(panel, CURRENT_PANEL.panel);
}
if(PREF_MAP[? "panel_collection"]) { function panelAdd(panel) {
var pan = getPanelFromName(f.collection.parent); var f = CURRENT_PANEL;
if(struct_has(f, panel)) {
var str = f[$ panel];
var pan = getPanelFromName(str.parent);
var p; var p;
if(f.collection.split == "v") if(str.split == "v")
p = pan.panel.split_v(ui(f.collection.width)); p = pan.panel.split_v(ui(str.width));
else if(f.collection.split == "h") else if(str.split == "h")
p = pan.panel.split_h(ui(f.collection.width)); p = pan.panel.split_h(ui(str.width));
p[0].set(PANEL_COLLECTION); p[ str.index].set(PANEL_COLLECTION);
p[1].set(pan); p[!str.index].set(pan);
} }
} }
function setPanel() { function panelObjectInit() {
PANEL_MAIN = new Panel(noone, ui(2), ui(2), WIN_SW - ui(4), WIN_SH - ui(4)); PANEL_MAIN = new Panel(noone, ui(2), ui(2), WIN_SW - ui(4), WIN_SH - ui(4));
PANEL_MENU = new Panel_Menu();
PANEL_MENU = new Panel_Menu(); PANEL_INSPECTOR = new Panel_Inspector();
PANEL_INSPECTOR = new Panel_Inspector(); PANEL_ANIMATION = new Panel_Animation();
PANEL_ANIMATION = new Panel_Animation(); PANEL_PREVIEW = new Panel_Preview();
PANEL_PREVIEW = new Panel_Preview(); PANEL_GRAPH = new Panel_Graph();
PANEL_GRAPH = new Panel_Graph();
PANEL_COLLECTION = new Panel_Collection(); PANEL_COLLECTION = new Panel_Collection();
}
var split_menu = PANEL_MAIN.split_v(ui(40)); function resetPanel() {
split_menu[0].set(PANEL_MENU); clearPanel();
panelObjectInit();
loadPanelStruct(PANEL_MAIN, CURRENT_PANEL.panel);
if(PREF_MAP[? "panel_collection"])
panelAdd("Panel_Collection");
PANEL_MAIN.refresh();
}
function setPanel() {
globalvar CURRENT_PANEL;
panelObjectInit();
zip_unzip("data/layouts.zip", DIRECTORY); zip_unzip("data/layouts.zip", DIRECTORY);
loadPanel(DIRECTORY + "layouts/" + PREF_MAP[? "panel_layout_file"] + ".json", split_menu[1]); var file = DIRECTORY + "layouts/" + PREF_MAP[? "panel_layout_file"] + ".json";
if(!file_exists(file))
file = DIRECTORY + "layouts/Horizontal.json";
loadPanel(file, PANEL_MAIN);
if(PREF_MAP[? "panel_collection"])
panelAdd("Panel_Collection");
PANEL_ANIMATION.updatePropertyList(); PANEL_ANIMATION.updatePropertyList();
PANEL_MAIN.refresh(); PANEL_MAIN.refresh();
@ -129,24 +155,42 @@
function panelDraw() { function panelDraw() {
if(panel_dragging) { if(panel_dragging) {
draw_surface_ext(panel_dragging.dragSurface, mouse_mx + 8, mouse_my + 8, 0.5, 0.5, 0, c_white, 0.5); draw_surface_ext(panel_dragging.dragSurface, mouse_mx + 8, mouse_my + 8, 0.5, 0.5, 0, c_white, 0.5);
if(mouse_release(mb_left)) { if(mouse_release(mb_left)) {
var p = []; var p = [];
var c = panel_hovering.content;
panel_hovering.content = noone;
switch(panel_split) { if(panel_hovering == PANEL_MAIN) { //split main panel
case 0 : p = panel_hovering.split_v( panel_hovering.h / 2); break; var panel = new Panel(noone, ui(2), ui(2), WIN_SW - ui(4), WIN_SH - ui(4));
case 1 : p = panel_hovering.split_h( panel_hovering.w / 2); break; var main = PANEL_MAIN;
case 2 : p = panel_hovering.split_h( panel_hovering.w / 2); break;
case 3 : p = panel_hovering.split_v( panel_hovering.h / 2); break; switch(panel_split) {
case 0 : p = panel.split_v( panel.h / 2); break;
case 1 : p = panel.split_h( panel.w / 2); break;
case 2 : p = panel.split_h( panel.w / 2); break;
case 3 : p = panel.split_v( panel.h / 2); break;
}
panel.parent.childs[| (panel_split + 1) % 2] = main;
main.parent = panel.parent;
panel.parent.childs[| (panel_split + 0) % 2].set(panel_dragging);
PANEL_MAIN.refreshSize();
} else {
var c = panel_hovering.content;
panel_hovering.content = noone;
switch(panel_split) {
case 0 : p = panel_hovering.split_v( panel_hovering.h / 2); break;
case 1 : p = panel_hovering.split_h( panel_hovering.w / 2); break;
case 2 : p = panel_hovering.split_h( panel_hovering.w / 2); break;
case 3 : p = panel_hovering.split_v( panel_hovering.h / 2); break;
}
p[(panel_split + 1) % 2].set(c);
p[(panel_split + 0) % 2].set(panel_dragging);
panel_hovering.refreshSize();
} }
p[(panel_split + 1) % 2].set(c);
p[(panel_split + 0) % 2].set(panel_dragging);
panel_hovering.refreshSize();
panel_hovering = noone; panel_hovering = noone;
panel_dragging = noone; panel_dragging = noone;
} }
@ -154,19 +198,48 @@
} }
function panelSerialize() { function panelSerialize() {
var cont = _panelSerialize(PANEL_MAIN); var cont = {};
print(json_stringify(cont, true)); cont.panel = _panelSerialize(PANEL_MAIN);
return cont;
} }
function _panelSerialize(panel) { function _panelSerialize(panel) {
var cont = {}; var cont = {};
var ind = 0;
cont.content = panel.content == noone? noone : instanceof(panel.content); if(panel.split != "" && ds_list_size(panel.childs) == 2) {
cont.split = panel.split; cont.split = panel.split;
if(panel.split == "h") {
ind = panel.childs[| 1].w < panel.childs[| 0].w;
cont.width = panel.childs[| ind].w * (panel.childs[| ind].x == panel.x? 1 : -1);
cont.child = []; } else {
for( var i = 0; i < ds_list_size(panel.childs); i++ ) ind = panel.childs[| 1].h < panel.childs[| 0].h;
cont.child[i] = _panelSerialize(panel.childs[| i]); cont.width = panel.childs[| ind].h * (panel.childs[| ind].y == panel.y? 1 : -1);
}
cont.content = [];
ind = panel.childs[| 1].x == panel.x && panel.childs[| 1].y == panel.y;
for( var i = 0; i < ds_list_size(panel.childs); i++ )
cont.content[i] = _panelSerialize(panel.childs[| (ind + i) % 2]);
} else if(panel.content != noone)
cont.content = instanceof(panel.content);
return cont;
}
function panelSerializeArray() {
return _panelSerializeArray(PANEL_MAIN);
}
function _panelSerializeArray(panel) {
var cont = [];
if(panel.content == noone) {
for( var i = 0; i < ds_list_size(panel.childs); i++ )
cont[i] = _panelSerializeArray(panel.childs[| i]);
} else
cont = instanceof(panel.content);
return cont; return cont;
} }

View file

@ -1,5 +1,5 @@
function Panel_Menu() : PanelContent() constructor { function Panel_Menu() : PanelContent() constructor {
draggable = false; draggable = true;
noti_flash = 0; noti_flash = 0;
noti_flash_color = COLORS._main_accent; noti_flash_color = COLORS._main_accent;
@ -7,9 +7,9 @@ function Panel_Menu() : PanelContent() constructor {
noti_icon_show = 0; noti_icon_show = 0;
noti_icon_time = 0; noti_icon_time = 0;
if(OS == os_windows) if(PREF_MAP[? "panel_menu_right_control"])
action_buttons = ["exit", "maximize", "minimize", "fullscreen"]; action_buttons = ["exit", "maximize", "minimize", "fullscreen"];
else if(OS == os_macosx) else
action_buttons = ["exit", "minimize", "maximize", "fullscreen"]; action_buttons = ["exit", "minimize", "maximize", "fullscreen"];
menu_file = [ menu_file = [
@ -148,6 +148,15 @@ function Panel_Menu() : PanelContent() constructor {
f = file_find_next(); f = file_find_next();
} }
array_push(arr, menuItem("Save layout", function() {
var dia = dialogCall(o_dialog_file_name, mouse_mx + ui(8), mouse_my + ui(8));
dia.onModify = function(name) {
var cont = panelSerialize();
json_save_struct(DIRECTORY + "layouts/" + name + ".json", cont);
};
}));
array_push(arr, -1);
for(var i = 0; i < array_length(lays); i++) { for(var i = 0; i < array_length(lays); i++) {
array_push(arr, menuItem(lays[i], array_push(arr, menuItem(lays[i],
function(_x, _y, _depth, _path) { function(_x, _y, _depth, _path) {
@ -161,9 +170,8 @@ function Panel_Menu() : PanelContent() constructor {
}).setIsShelf(), }).setIsShelf(),
-1, -1,
menuItem(get_text("panel_menu_collections", "Collections"), function() { menuItem(get_text("panel_menu_collections", "Collections"), function() {
clearPanel();
PREF_MAP[? "panel_collection"] = !PREF_MAP[? "panel_collection"]; PREF_MAP[? "panel_collection"] = !PREF_MAP[? "panel_collection"];
setPanel(); resetPanel();
PREF_SAVE(); PREF_SAVE();
}), }),
menuItem(get_text("tunnels", "Tunnels"), function() { menuItem(get_text("tunnels", "Tunnels"), function() {
@ -239,48 +247,90 @@ function Panel_Menu() : PanelContent() constructor {
function drawContent(panel) { function drawContent(panel) {
draw_clear_alpha(COLORS.panel_bg_clear, 0); draw_clear_alpha(COLORS.panel_bg_clear, 0);
menus[6][1] = STEAM_ENABLED? menu_help_steam : menu_help; menus[6][1] = STEAM_ENABLED? menu_help_steam : menu_help;
var hori = w > h;
var xx = ui(40); var xx = ui(40);
if(OS == os_windows) var yy = ui(8);
xx = ui(24);
else if(OS == os_macosx) { if(hori) {
xx = ui(140); if(PREF_MAP[? "panel_menu_right_control"])
draw_set_color(COLORS._main_icon_dark); xx = ui(24);
draw_line_round(xx, ui(8), xx, h - ui(8), 3); else {
xx = ui(140);
draw_set_color(COLORS._main_icon_dark);
draw_line_round(xx, ui(8), xx, h - ui(8), 3);
}
var bx = xx;
if(!PREF_MAP[? "panel_menu_right_control"])
bx = w - ui(24);
draw_sprite_ui_uniform(THEME.icon_24, 0, bx, h / 2, 1, c_white);
if(pHOVER && point_in_rectangle(mx, my, bx - ui(16), 0, bx + ui(16), ui(32))) {
if(mouse_press(mb_left, pFOCUS))
dialogCall(o_dialog_about);
}
} else {
var bx = ui(20);
var by = h - ui(20);
draw_sprite_ui_uniform(THEME.icon_24, 0, bx, by, 1, c_white);
if(pHOVER && point_in_rectangle(mx, my, bx - ui(16), by - ui(16), bx + ui(16), by + ui(16))) {
if(mouse_press(mb_left, pFOCUS))
dialogCall(o_dialog_about);
}
} }
var bx = xx; if(hori) {
if(OS == os_macosx) if(PREF_MAP[? "panel_menu_right_control"])
bx = w - ui(24); xx += ui(20);
else
draw_sprite_ui_uniform(THEME.icon_24, 0, bx, h / 2, 1, c_white); xx += ui(8);
if(pHOVER && point_in_rectangle(mx, my, bx - ui(16), 0, bx + ui(16), ui(32))) { yy = 0;
if(mouse_press(mb_left, pFOCUS)) } else {
dialogCall(o_dialog_about); xx = ui(8);
yy = w < ui(200)? ui(72) : ui(40);
} }
if(OS == os_windows) var xc, x0, x1, yc, y0, y1;
xx += ui(20);
else if(OS == os_macosx)
xx += ui(8);
for(var i = 0; i < array_length(menus); i++) { for(var i = 0; i < array_length(menus); i++) {
draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text); draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text);
var ww = string_width(menus[i][0]) + ui(16); var ww = string_width(menus[i][0]) + ui(16);
var xc = xx + ww / 2; var hh = line_height() + ui(8);
if(pHOVER && point_in_rectangle(mx, my, xc - ww / 2, 0, xc + ww / 2, h)) { if(hori) {
draw_sprite_stretched(THEME.menu_button, 0, xc - ww / 2, ui(6), ww, h - ui(12)); xc = xx + ww / 2;
yc = h / 2;
x0 = xx;
x1 = xx + ww;
y0 = ui(6);
y1 = h - ui(6);
} else {
xc = w / 2;
yc = yy + hh / 2;
x0 = ui(6);
x1 = w - ui(6);
y0 = yy;
y1 = yy + hh;
}
if(pHOVER && point_in_rectangle(mx, my, x0, y0, x1, y1)) {
draw_sprite_stretched(THEME.menu_button, 0, x0, y0, x1 - x0, y1 - y0);
if((mouse_press(mb_left, pFOCUS)) || instance_exists(o_dialog_menubox)) { if((mouse_press(mb_left, pFOCUS)) || instance_exists(o_dialog_menubox)) {
menuCall( xx, h, menus[i][1]); if(hori) menuCall( x + x0, y + y1, menus[i][1]);
else menuCall( x + x1, y + y0, menus[i][1]);
} }
} }
draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text); draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text);
draw_text_over(xx + ww / 2, h / 2, menus[i][0]); draw_text_over(xc, yc, menus[i][0]);
xx += ww + 8; if(hori) xx += ww + 8;
else yy += hh + 8;
} }
#region notification #region notification
@ -292,8 +342,13 @@ function Panel_Menu() : PanelContent() constructor {
for( var i = 0; i < ds_list_size(ERRORS); i++ ) for( var i = 0; i < ds_list_size(ERRORS); i++ )
error_amo += ERRORS[| i].amount; error_amo += ERRORS[| i].amount;
var nx0 = xx + ui(24); if(hori) {
var ny0 = h / 2; var nx0 = xx + ui(24);
var ny0 = h / 2;
} else {
var nx0 = ui(8);
var ny0 = yy + ui(16);
}
draw_set_text(f_p0, fa_left, fa_center); draw_set_text(f_p0, fa_left, fa_center);
var wr_w = ui(20) + ui(8) + string_width(string(warning_amo)); var wr_w = ui(20) + ui(8) + string_width(string(warning_amo));
@ -305,7 +360,7 @@ function Panel_Menu() : PanelContent() constructor {
} else } else
noti_icon_show = lerp_float(noti_icon_show, 0, 4); noti_icon_show = lerp_float(noti_icon_show, 0, 4);
var nw = ui(16) + wr_w + ui(16) + er_w + noti_icon_show * ui(32); var nw = hori? ui(16) + wr_w + ui(16) + er_w + noti_icon_show * ui(32) : w - ui(16);
var nh = ui(32); var nh = ui(32);
noti_flash = lerp_linear(noti_flash, 0, 0.02); noti_flash = lerp_linear(noti_flash, 0, 0.02);
@ -330,23 +385,25 @@ function Panel_Menu() : PanelContent() constructor {
if(noti_icon_show > 0) if(noti_icon_show > 0)
draw_sprite_ui(noti_icon, 0, nx0 + nw - ui(16), ny0,,,,, noti_icon_show); draw_sprite_ui(noti_icon, 0, nx0 + nw - ui(16), ny0,,,,, noti_icon_show);
var wr_x = nx0 + ui(8); var wr_x = hori? nx0 + ui(8) : w / 2 - (wr_w + er_w + ui(16)) / 2;
draw_sprite_ui_uniform(THEME.noti_icon_warning, warning_amo? 1 : 0, wr_x + ui(10), ny0); draw_sprite_ui_uniform(THEME.noti_icon_warning, warning_amo? 1 : 0, wr_x + ui(10), ny0);
draw_text(wr_x + ui(28), ny0, warning_amo); draw_text(wr_x + ui(28), ny0, warning_amo);
var er_x = nx0 + ui(8) + wr_w + ui(16); wr_x += wr_w + ui(16);
draw_sprite_ui_uniform(THEME.noti_icon_error, error_amo? 1 : 0, er_x + ui(10), ny0); draw_sprite_ui_uniform(THEME.noti_icon_error, error_amo? 1 : 0, wr_x + ui(10), ny0);
draw_text(er_x + ui(28), ny0, error_amo); draw_text(wr_x + ui(28), ny0, error_amo);
nx0 += nw + ui(8); if(hori) nx0 += nw + ui(8);
else ny0 += nh + ui(8);
#endregion #endregion
#region addons #region addons
var wh = ui(32); var wh = ui(32);
if(!hori) nx0 = ui(8);
with(addon) { with(addon) {
draw_set_text(f_p0, fa_center, fa_center, COLORS._main_text); draw_set_text(f_p0, fa_center, fa_center, COLORS._main_text);
var ww = string_width(name) + ui(16); var ww = hori? string_width(name) + ui(16) : w - ui(16);
if(other.pHOVER && point_in_rectangle(other.mx, other.my, nx0, ny0 - wh / 2, nx0 + ww, ny0 + wh / 2)) { if(other.pHOVER && point_in_rectangle(other.mx, other.my, nx0, ny0 - wh / 2, nx0 + ww, ny0 + wh / 2)) {
draw_sprite_stretched(THEME.menu_button, 1, nx0, ny0 - wh / 2, ww, wh); draw_sprite_stretched(THEME.menu_button, 1, nx0, ny0 - wh / 2, ww, wh);
@ -358,13 +415,16 @@ function Panel_Menu() : PanelContent() constructor {
draw_sprite_stretched(THEME.ui_panel_bg, 1, nx0, ny0 - wh / 2, ww, wh); draw_sprite_stretched(THEME.ui_panel_bg, 1, nx0, ny0 - wh / 2, ww, wh);
draw_text(nx0 + ww / 2, ny0, name); draw_text(nx0 + ww / 2, ny0, name);
nx0 += ww + ui(4); if(hori) nx0 += ww + ui(4);
else ny0 += hh + ui(4);
} }
#endregion #endregion
var x1 = w - ui(6); var x1 = w - ui(6);
if(OS == os_windows) x1 = w - ui(6); if(PREF_MAP[? "panel_menu_right_control"])
else if(OS == os_macosx) x1 = ui(8 + 28); x1 = w - ui(6);
else
x1 = ui(8 + 28);
#region actions #region actions
var bs = ui(28); var bs = ui(28);
@ -427,26 +487,44 @@ function Panel_Menu() : PanelContent() constructor {
break; break;
} }
if(OS == os_windows) x1 -= bs + ui(4); if(PREF_MAP[? "panel_menu_right_control"])
else if(OS == os_macosx) x1 += bs + ui(4); x1 -= bs + ui(4);
else
x1 += bs + ui(4);
} }
#endregion #endregion
if(OS == os_macosx) x1 = w - ui(40); if(!PREF_MAP[? "panel_menu_right_control"]) x1 = w - ui(40);
#region version #region version
draw_set_text(f_p0, fa_right, fa_center, COLORS._main_text_sub);
var txt = "v. " + string(VERSION_STRING); var txt = "v. " + string(VERSION_STRING);
if(STEAM_ENABLED) txt += " Steam"; if(STEAM_ENABLED) txt += " Steam";
var ww = string_width(txt) + ui(12);
if(pHOVER && point_in_rectangle(mx, my, x1 - ww, 0, x1, h)) {
draw_sprite_stretched(THEME.button_hide_fill, 1, x1 - ww, ui(6), ww, h - ui(12));
if(mouse_press(mb_left, pFOCUS)) { if(hori) {
dialogCall(o_dialog_release_note); draw_set_text(f_p0, fa_right, fa_center, COLORS._main_text_sub);
var ww = string_width(txt) + ui(12);
if(pHOVER && point_in_rectangle(mx, my, x1 - ww, 0, x1, h)) {
draw_sprite_stretched(THEME.button_hide_fill, 1, x1 - ww, ui(6), ww, h - ui(12));
if(mouse_press(mb_left, pFOCUS)) {
dialogCall(o_dialog_release_note);
}
} }
draw_text(x1 - ui(6), h / 2, txt);
} else {
var x1 = ui(40);
var y1 = h - ui(20);
draw_set_text(f_p0, fa_left, fa_center, COLORS._main_text_sub);
var ww = string_width(txt) + ui(12);
if(pHOVER && point_in_rectangle(mx, my, x1, y1 - ui(16), x1 + ww, y1 + ui(16))) {
draw_sprite_stretched(THEME.button_hide_fill, 1, x1, y1 - ui(16), ww, ui(32));
if(mouse_press(mb_left, pFOCUS))
dialogCall(o_dialog_release_note);
}
draw_text(x1 + ui(6), y1, txt);
} }
draw_text(x1 - ui(6), h / 2, txt);
#endregion #endregion
#region title #region title
@ -460,16 +538,41 @@ function Panel_Menu() : PanelContent() constructor {
txt += " - Pixel Composer"; txt += " - Pixel Composer";
if(DEMO) txt += " DEMO"; if(DEMO) txt += " DEMO";
var tx0 = nx0; var tx0, tx1, maxW, tcx;
var tx1 = x1 - ww; var ty0, ty1;
var maxW = abs(tx0 - tx1); var tbx0, tby0;
var tcx = (tx0 + tx1) / 2;
if(hori) {
tx0 = nx0;
tx1 = x1 - ww;
ty0 = 0;
ty1 = h;
tcx = (tx0 + tx1) / 2;
} else {
tx0 = ui(8);
tx1 = w < ui(200)? w - ui(16) : w - ui(144);
ty0 = w < ui(200)? ui(36) : ui(6);
tcx = tx0;
}
maxW = abs(tx0 - tx1);
draw_set_font(f_p0b); draw_set_font(f_p0b);
var tc = string_cut(txt, maxW); var tc = string_cut(txt, maxW);
var tw = string_width(tc) + ui(16); var tw = string_width(tc) + ui(16);
var th = ui(28);
if(buttonInstant(THEME.button_hide_fill, tcx - tw / 2, h / 2 - ui(14), tw, ui(28), [mx, my], pFOCUS, pHOVER) == 2) { if(hori) {
tbx0 = tcx - tw / 2;
tby0 = ty1 / 2 - ui(14);
} else {
tbx0 = tx0;
tby0 = ty0;
}
if(buttonInstant(THEME.button_hide_fill, tbx0, tby0, tw, th, [mx, my], pFOCUS, pHOVER) == 2) {
var arr = []; var arr = [];
var tip = []; var tip = [];
for(var i = 0; i < min(10, ds_list_size(RECENT_FILES)); i++) { for(var i = 0; i < min(10, ds_list_size(RECENT_FILES)); i++) {
@ -479,12 +582,17 @@ function Panel_Menu() : PanelContent() constructor {
array_push(tip, [ method(_dat, _dat.getThumbnail), VALUE_TYPE.surface ]); array_push(tip, [ method(_dat, _dat.getThumbnail), VALUE_TYPE.surface ]);
} }
var dia = menuCall(tcx, h, arr, fa_center); var dia = hori? menuCall(x + tcx, y + h, arr, fa_center) : menuCall(x + w, y + tby0, arr);
dia.tooltips = tip; dia.tooltips = tip;
} }
draw_set_text(f_p0b, fa_center, fa_center, COLORS._main_text_sub); if(hori) {
draw_text(tcx, h / 2, tc); draw_set_text(f_p0b, fa_center, fa_center, COLORS._main_text_sub);
draw_text(tcx, (ty0 + ty1) / 2, tc);
} else {
draw_set_text(f_p0b, fa_left, fa_center, COLORS._main_text_sub);
draw_text(tx0 + ui(8), tby0 + th / 2, tc);
}
#endregion #endregion
undoUpdate(); undoUpdate();

View file

@ -823,11 +823,10 @@ function Panel_Preview() : PanelContent() constructor {
mouse_on_preview = pHOVER && point_in_rectangle(mx, my, 0, toolbar_height, w, h - toolbar_height); mouse_on_preview = pHOVER && point_in_rectangle(mx, my, 0, toolbar_height, w, h - toolbar_height);
draw_clear(COLORS.panel_bg_clear); draw_clear(COLORS.panel_bg_clear);
if(canvas_bg == -1) { if(canvas_bg == -1 && canvas_s >= 1)
if(canvas_s >= 1) draw_sprite_tiled_ext(s_transparent, 0, canvas_x, canvas_y, canvas_s, canvas_s, c_white, 0.5); draw_sprite_tiled_ext(s_transparent, 0, canvas_x, canvas_y, canvas_s, canvas_s, c_white, 0.5);
} else { else
draw_clear(canvas_bg); draw_clear(canvas_bg);
}
dragCanvas(); dragCanvas();
getPreviewData(); getPreviewData();

View file

@ -64,6 +64,7 @@
PREF_MAP[? "dialog_add_node_h"] = 400; PREF_MAP[? "dialog_add_node_h"] = 400;
PREF_MAP[? "panel_menu_resource_monitor"] = false; PREF_MAP[? "panel_menu_resource_monitor"] = false;
PREF_MAP[? "panel_menu_right_control"] = os_type == os_windows;
#endregion #endregion
#region hotkeys #region hotkeys

View file

@ -89,6 +89,22 @@ function textArea(_input, _onModify, _extras = noone) : textInput(_input, _onMod
var word = words[j]; var word = words[j];
if(j) word = " " + word; if(j) word = " " + word;
if(string_width(word) > line_width) { //the entire word is longer than a line
for( var k = 1; k <= string_length(word); k++ ) {
var ch = string_char_at(word, k);
if(currW + string_width(ch) > line_width) {
array_push(_input_text_line, currL);
currW = 0;
currL = "";
}
currL += ch;
currW += string_width(ch);
}
continue;
}
if(currW + string_width(word) > line_width) { if(currW + string_width(word) > line_width) {
array_push(_input_text_line, currL); array_push(_input_text_line, currL);
currW = 0; currW = 0;