Fix disabling auto update still make the node update in some case.

This commit is contained in:
Tanasart 2024-09-11 14:54:40 +07:00
parent c26d7e14e2
commit ba29167abf
33 changed files with 1599 additions and 265 deletions

View file

@ -248,6 +248,7 @@
{"name":"Spout","order":13,"path":"extensions/Spout/Spout.yy",}, {"name":"Spout","order":13,"path":"extensions/Spout/Spout.yy",},
{"name":"Steamworks","order":2,"path":"extensions/Steamworks/Steamworks.yy",}, {"name":"Steamworks","order":2,"path":"extensions/Steamworks/Steamworks.yy",},
{"name":"TabletStuff","order":15,"path":"extensions/TabletStuff/TabletStuff.yy",}, {"name":"TabletStuff","order":15,"path":"extensions/TabletStuff/TabletStuff.yy",},
{"name":"winwin","order":5,"path":"extensions/winwin/winwin.yy",},
{"name":"YYFirebaseFirestore","order":1,"path":"extensions/YYFirebaseFirestore/YYFirebaseFirestore.yy",}, {"name":"YYFirebaseFirestore","order":1,"path":"extensions/YYFirebaseFirestore/YYFirebaseFirestore.yy",},
{"name":"_f_code_s","order":18,"path":"fonts/_f_code_s/_f_code_s.yy",}, {"name":"_f_code_s","order":18,"path":"fonts/_f_code_s/_f_code_s.yy",},
{"name":"_f_code","order":9,"path":"fonts/_f_code/_f_code.yy",}, {"name":"_f_code","order":9,"path":"fonts/_f_code/_f_code.yy",},
@ -1377,6 +1378,7 @@
{"name":"wav_file_object","order":2,"path":"scripts/wav_file_object/wav_file_object.yy",}, {"name":"wav_file_object","order":2,"path":"scripts/wav_file_object/wav_file_object.yy",},
{"name":"widget","order":5,"path":"scripts/widget/widget.yy",}, {"name":"widget","order":5,"path":"scripts/widget/widget.yy",},
{"name":"window_functions","order":2,"path":"scripts/window_functions/window_functions.yy",}, {"name":"window_functions","order":2,"path":"scripts/window_functions/window_functions.yy",},
{"name":"winwin_extras","order":6,"path":"scripts/winwin_extras/winwin_extras.yy",},
{"name":"sh_2d_light","order":10,"path":"shaders/sh_2d_light/sh_2d_light.yy",}, {"name":"sh_2d_light","order":10,"path":"shaders/sh_2d_light/sh_2d_light.yy",},
{"name":"sh_3d_depth","order":6,"path":"shaders/sh_3d_depth/sh_3d_depth.yy",}, {"name":"sh_3d_depth","order":6,"path":"shaders/sh_3d_depth/sh_3d_depth.yy",},
{"name":"sh_3d_extrude_corner","order":7,"path":"shaders/sh_3d_extrude_corner/sh_3d_extrude_corner.yy",}, {"name":"sh_3d_extrude_corner","order":7,"path":"shaders/sh_3d_extrude_corner/sh_3d_extrude_corner.yy",},

View file

@ -680,6 +680,8 @@
{"$GMIncludedFile":"","%Name":"Canvas.png","CopyToMask":-1,"filePath":"datafiles/Welcome files/Templates","name":"Canvas.png","resourceType":"GMIncludedFile","resourceVersion":"2.0",}, {"$GMIncludedFile":"","%Name":"Canvas.png","CopyToMask":-1,"filePath":"datafiles/Welcome files/Templates","name":"Canvas.png","resourceType":"GMIncludedFile","resourceVersion":"2.0",},
{"$GMIncludedFile":"","%Name":"Canvas.pxc","CopyToMask":-1,"filePath":"datafiles/Welcome files/Templates","name":"Canvas.pxc","resourceType":"GMIncludedFile","resourceVersion":"2.0",}, {"$GMIncludedFile":"","%Name":"Canvas.pxc","CopyToMask":-1,"filePath":"datafiles/Welcome files/Templates","name":"Canvas.pxc","resourceType":"GMIncludedFile","resourceVersion":"2.0",},
{"$GMIncludedFile":"","%Name":"Welcome files.zip","CopyToMask":-1,"filePath":"datafiles/Welcome files","name":"Welcome files.zip","resourceType":"GMIncludedFile","resourceVersion":"2.0",}, {"$GMIncludedFile":"","%Name":"Welcome files.zip","CopyToMask":-1,"filePath":"datafiles/Welcome files","name":"Welcome files.zip","resourceType":"GMIncludedFile","resourceVersion":"2.0",},
{"$GMIncludedFile":"","%Name":"winwin.html","CopyToMask":-1,"filePath":"datafiles","name":"winwin.html","resourceType":"GMIncludedFile","resourceVersion":"2.0",},
{"$GMIncludedFile":"","%Name":"winwin.html","CopyToMask":-1,"filePath":"datafiles","name":"winwin.html","resourceType":"GMIncludedFile","resourceVersion":"2.0",},
], ],
"isEcma":false, "isEcma":false,
"LibraryEmitters":[], "LibraryEmitters":[],
@ -713,6 +715,7 @@
{"id":{"name":"Spout","path":"extensions/Spout/Spout.yy",},}, {"id":{"name":"Spout","path":"extensions/Spout/Spout.yy",},},
{"id":{"name":"Steamworks","path":"extensions/Steamworks/Steamworks.yy",},}, {"id":{"name":"Steamworks","path":"extensions/Steamworks/Steamworks.yy",},},
{"id":{"name":"TabletStuff","path":"extensions/TabletStuff/TabletStuff.yy",},}, {"id":{"name":"TabletStuff","path":"extensions/TabletStuff/TabletStuff.yy",},},
{"id":{"name":"winwin","path":"extensions/winwin/winwin.yy",},},
{"id":{"name":"YYFirebaseFirestore","path":"extensions/YYFirebaseFirestore/YYFirebaseFirestore.yy",},}, {"id":{"name":"YYFirebaseFirestore","path":"extensions/YYFirebaseFirestore/YYFirebaseFirestore.yy",},},
{"id":{"name":"_f_code_s","path":"fonts/_f_code_s/_f_code_s.yy",},}, {"id":{"name":"_f_code_s","path":"fonts/_f_code_s/_f_code_s.yy",},},
{"id":{"name":"_f_code","path":"fonts/_f_code/_f_code.yy",},}, {"id":{"name":"_f_code","path":"fonts/_f_code/_f_code.yy",},},
@ -2025,6 +2028,7 @@
{"id":{"name":"widget","path":"scripts/widget/widget.yy",},}, {"id":{"name":"widget","path":"scripts/widget/widget.yy",},},
{"id":{"name":"window_functions","path":"scripts/window_functions/window_functions.yy",},}, {"id":{"name":"window_functions","path":"scripts/window_functions/window_functions.yy",},},
{"id":{"name":"windowManager","path":"scripts/windowManager/windowManager.yy",},}, {"id":{"name":"windowManager","path":"scripts/windowManager/windowManager.yy",},},
{"id":{"name":"winwin_extras","path":"scripts/winwin_extras/winwin_extras.yy",},},
{"id":{"name":"sh_2d_light","path":"shaders/sh_2d_light/sh_2d_light.yy",},}, {"id":{"name":"sh_2d_light","path":"shaders/sh_2d_light/sh_2d_light.yy",},},
{"id":{"name":"sh_3d_depth","path":"shaders/sh_3d_depth/sh_3d_depth.yy",},}, {"id":{"name":"sh_3d_depth","path":"shaders/sh_3d_depth/sh_3d_depth.yy",},},
{"id":{"name":"sh_3d_extrude_corner","path":"shaders/sh_3d_extrude_corner/sh_3d_extrude_corner.yy",},}, {"id":{"name":"sh_3d_extrude_corner","path":"shaders/sh_3d_extrude_corner/sh_3d_extrude_corner.yy",},},

1049
datafiles/winwin.html Normal file

File diff suppressed because one or more lines are too long

View file

@ -3,6 +3,10 @@
#macro DIALOG_DRAW_BG draw_sprite_stretched(THEME.dialog, 0, dialog_x - 8, dialog_y - 8, dialog_w + 16, dialog_h + 16); #macro DIALOG_DRAW_BG draw_sprite_stretched(THEME.dialog, 0, dialog_x - 8, dialog_y - 8, dialog_w + 16, dialog_h + 16);
#macro DIALOG_DRAW_FOCUS draw_sprite_stretched_ext(THEME.dialog, 1, dialog_x - 8, dialog_y - 8, dialog_w + 16, dialog_h + 16, COLORS._main_accent, 1); #macro DIALOG_DRAW_FOCUS draw_sprite_stretched_ext(THEME.dialog, 1, dialog_x - 8, dialog_y - 8, dialog_w + 16, dialog_h + 16, COLORS._main_accent, 1);
#macro DIALOG_WINCLEAR if(window != noone) { winwin_draw_clear(COLORS.panel_bg_clear, 0); }
#macro DIALOG_PREDRAW if(window != noone) { winwin_draw_begin(window); WINDOW_ACTIVE = window; }
#macro DIALOG_POSTDRAW if(window != noone) { winwin_draw_end(); WINDOW_ACTIVE = noone; }
#region data #region data
on_top = false; on_top = false;
@ -21,6 +25,9 @@
dialog_x = 0; dialog_x = 0;
dialog_y = 0; dialog_y = 0;
title = "dialog";
window = noone;
title_height = 64; title_height = 64;
padding = 20; padding = 20;
@ -55,15 +62,45 @@
mouse_active = true; mouse_active = true;
if(!draggable) return; if(!draggable) return;
WINDOW_ACTIVE = window;
if(window == noone) {
if(dialog_dragging) { if(dialog_dragging) {
dialog_x = clamp(dialog_drag_sx + mouse_mx - dialog_drag_mx, ui(16) - dialog_w, WIN_W - ui(16)); var _dx = dialog_drag_sx + mouse_mx - dialog_drag_mx;
dialog_y = clamp(dialog_drag_sy + mouse_my - dialog_drag_my, ui(16) - dialog_h, WIN_H - ui(16)); var _dy = dialog_drag_sy + mouse_my - dialog_drag_my;
var _wx = window_get_x();
var _wy = window_get_y();
if(point_in_rectangle(mouse_raw_x, mouse_raw_y, _wx, _wy, _wx + WIN_W, _wy + WIN_H)) {
dialog_x = clamp(_dx, ui(16) - dialog_w, WIN_W - ui(16));
dialog_y = clamp(_dy, ui(16) - dialog_h, WIN_H - ui(16));
} else if(PREFERENCES.multi_window) {
o_main.dialog_popup_to = 1;
o_main.dialog_popup_x = mouse_mx;
o_main.dialog_popup_y = mouse_my;
if(mouse_release(mb_left)) {
var _wconfig = new winwin_config();
_wconfig.kind = winwin_kind_borderless;
_wconfig.caption = title;
_wconfig.topmost = true;
_wconfig.per_pixel_alpha = true;
_wconfig.resize = true;
_wconfig.owner = winwin_main;
window = winwin_create(_wx + _dx, _wy + _dy, dialog_w, dialog_h, _wconfig);
dialog_x = 0;
dialog_y = 0;
}
}
if(mouse_release(mb_left)) if(mouse_release(mb_left))
dialog_dragging = false; dialog_dragging = false;
} }
if(mouse_draggable && point_in_rectangle(mouse_mx, mouse_my, dialog_x, dialog_y, dialog_x + dialog_w, dialog_y + ui(title_height))) { if(mouse_draggable && point_in_rectangle(mouse_mx, mouse_my, dialog_x, dialog_y, dialog_x + dialog_w, dialog_y + title_height)) {
mouse_active = false; mouse_active = false;
if(mouse_press(mb_left, sFOCUS)) { if(mouse_press(mb_left, sFOCUS)) {
dialog_dragging = true; dialog_dragging = true;
@ -74,7 +111,34 @@
} }
} }
} else {
if(dialog_dragging) {
var _dx = dialog_drag_sx + mouse_raw_x - dialog_drag_mx;
var _dy = dialog_drag_sy + mouse_raw_y - dialog_drag_my;
winwin_set_position(window, _dx, _dy);
if(mouse_release(mb_left))
dialog_dragging = false;
}
if(mouse_draggable && point_in_rectangle(mouse_mx, mouse_my, 0, 0, dialog_w, title_height)) {
mouse_active = false;
// print($"{mouse_mx}, {mouse_my} / {mouse_press(mb_left, sFOCUS)}");
if(mouse_press(mb_left, sFOCUS)) {
dialog_dragging = true;
dialog_drag_sx = winwin_get_x(window);
dialog_drag_sy = winwin_get_y(window);
dialog_drag_mx = mouse_raw_x;
dialog_drag_my = mouse_raw_y;
}
}
}
mouse_draggable = true; mouse_draggable = true;
WINDOW_ACTIVE = noone;
} }
dialog_resizable = false; dialog_resizable = false;
@ -93,6 +157,7 @@
if(!active) return; if(!active) return;
if(!dialog_resizable) return; if(!dialog_resizable) return;
if(window == noone) {
if(dialog_resizing & 1 << 0 != 0) { if(dialog_resizing & 1 << 0 != 0) {
var ww = dialog_resiz_sw + (mouse_mx - dialog_resiz_mx); var ww = dialog_resiz_sw + (mouse_mx - dialog_resiz_mx);
ww = clamp(ww, dialog_w_min, dialog_w_max); ww = clamp(ww, dialog_w_min, dialog_w_max);
@ -122,10 +187,8 @@
if(sHOVER && distance_to_line(mouse_mx, mouse_my, dialog_x, dialog_y + dialog_h, dialog_x + dialog_w, dialog_y + dialog_h) < 12) { if(sHOVER && distance_to_line(mouse_mx, mouse_my, dialog_x, dialog_y + dialog_h, dialog_x + dialog_w, dialog_y + dialog_h) < 12) {
mouse_active = false; mouse_active = false;
if(CURSOR == cr_size_we) if(CURSOR == cr_size_we) CURSOR = cr_size_nwse;
CURSOR = cr_size_nwse; else CURSOR = cr_size_ns;
else
CURSOR = cr_size_ns;
if(mouse_press(mb_left, sFOCUS)) { if(mouse_press(mb_left, sFOCUS)) {
dialog_resizing |= 1 << 1; dialog_resizing |= 1 << 1;
@ -134,6 +197,60 @@
dialog_resiz_my = mouse_my; dialog_resiz_my = mouse_my;
} }
} }
} else {
WINDOW_ACTIVE = window;
var ww = dialog_resiz_sw;
var hh = dialog_resiz_sh;
if(dialog_resizing & 1 << 0 != 0) {
ww = dialog_resiz_sw + (mouse_raw_x - dialog_resiz_mx);
ww = clamp(ww, dialog_w_min, dialog_w_max);
}
if(dialog_resizing & 1 << 1 != 0) {
hh = dialog_resiz_sh + (mouse_raw_y - dialog_resiz_my);
hh = clamp(hh, dialog_h_min, dialog_h_max);
}
if(dialog_resizing != 0) {
winwin_set_size(window, ww, hh);
if(mouse_release(mb_left)) dialog_resizing = 0;
}
if(sHOVER && distance_to_line(mouse_mx, mouse_my, dialog_w, 0, dialog_w, dialog_h) < 12) {
mouse_active = false;
CURSOR = cr_size_we;
if(mouse_press(mb_left, sFOCUS)) {
dialog_resizing |= 1 << 0;
dialog_resiz_sw = dialog_w;
dialog_resiz_sh = dialog_h;
dialog_resiz_mx = mouse_raw_x;
dialog_resiz_my = mouse_raw_y;
}
}
if(sHOVER && distance_to_line(mouse_mx, mouse_my, 0, dialog_h, dialog_w, dialog_h) < 12) {
mouse_active = false;
if(CURSOR == cr_size_we) CURSOR = cr_size_nwse;
else CURSOR = cr_size_ns;
if(mouse_press(mb_left, sFOCUS)) {
dialog_resizing |= 1 << 1;
dialog_resiz_sw = dialog_w;
dialog_resiz_sh = dialog_h;
dialog_resiz_mx = mouse_raw_x;
dialog_resiz_my = mouse_raw_y;
}
}
winwin_set_cursor(window, CURSOR);
WINDOW_ACTIVE = noone;
}
} }
#endregion #endregion
@ -152,7 +269,9 @@
function checkFocus() { function checkFocus() {
if(!active) return; if(!active) return;
WINDOW_ACTIVE = window;
if(window == noone) {
var _mx = FILE_IS_DROPPING? FILE_DROPPING_X : mouse_mx; var _mx = FILE_IS_DROPPING? FILE_DROPPING_X : mouse_mx;
var _my = FILE_IS_DROPPING? FILE_DROPPING_Y : mouse_my; var _my = FILE_IS_DROPPING? FILE_DROPPING_Y : mouse_my;
@ -162,17 +281,27 @@
HOVER = self.id; HOVER = self.id;
} }
} }
} else {
if(winwin_mouse_is_over(window))
HOVER = self.id;
}
WINDOW_ACTIVE = noone;
} }
function checkDepth() { function checkDepth() {
if(!active) return; if(!active) return;
if(HOVER != self.id) return; if(HOVER != self.id) return;
if(mouse_press(mb_any) && FOCUS != self.id) { WINDOW_ACTIVE = window;
if(mouse_press(mb_any)) {
setFocus(self.id, "Dialog"); setFocus(self.id, "Dialog");
with(_p_dialog) other.depth = min(other.depth, depth - 1); with(_p_dialog) other.depth = min(other.depth, depth - 1);
} }
WINDOW_ACTIVE = noone;
} }
function onFocusBegin() {} function onFocusBegin() {}
@ -203,6 +332,8 @@
if(!active) return; if(!active) return;
if(!DIALOG_CLICK) return; if(!DIALOG_CLICK) return;
WINDOW_ACTIVE = window;
if(!init_pressing && mouse_press(mb_any)) { if(!init_pressing && mouse_press(mb_any)) {
if(!isTop()) return; if(!isTop()) return;

View file

@ -8,3 +8,5 @@ ds_list_remove(DIALOGS, self);
if(parent) array_remove(parent.children, id); if(parent) array_remove(parent.children, id);
if(!passthrough) MOUSE_BLOCK = true; if(!passthrough) MOUSE_BLOCK = true;
if(window != noone) winwin_destroy(window);

View file

@ -0,0 +1,3 @@
if(window != noone) {
winwin_draw_end();
}

View file

@ -0,0 +1 @@
/// @description Insert description here

View file

@ -0,0 +1 @@
/// @description Insert description here

View file

@ -13,6 +13,11 @@ if !active exit;
#endregion #endregion
#region resize #region resize
if(window != noone) {
dialog_w = winwin_get_width(window);
dialog_h = winwin_get_height(window);
}
if(_dialog_h != dialog_h || _dialog_w != dialog_w) { if(_dialog_h != dialog_h || _dialog_w != dialog_w) {
_dialog_h = dialog_h; _dialog_h = dialog_h;
_dialog_w = dialog_w; _dialog_w = dialog_w;
@ -20,3 +25,4 @@ if !active exit;
if(onResize != -1) onResize(); if(onResize != -1) onResize();
} }
#endregion #endregion

View file

@ -6,6 +6,8 @@
{"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":0,"eventType":1,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",}, {"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":0,"eventType":1,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",},
{"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":0,"eventType":2,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",}, {"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":0,"eventType":2,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",},
{"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":1,"eventType":3,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",}, {"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":1,"eventType":3,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",},
{"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":74,"eventType":8,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",},
{"$GMEvent":"v1","%Name":"","collisionObjectId":null,"eventNum":75,"eventType":8,"isDnD":false,"name":"","resourceType":"GMEvent","resourceVersion":"2.0",},
], ],
"managed":true, "managed":true,
"name":"_p_dialog", "name":"_p_dialog",

View file

@ -1,2 +1,4 @@
/// @description /// @description
selector.colorPicker(); selector.colorPicker();
event_inherited();

View file

@ -1,2 +1,4 @@
/// @description /// @description
selector.colorPicker(); selector.colorPicker();
event_inherited();

View file

@ -1,2 +1,3 @@
/// @description /// @description
selector.colorPicker(); selector.colorPicker();
event_inherited();

View file

@ -1,22 +1,24 @@
/// @description /// @description
if !ready exit; if !ready exit;
#region base UI DIALOG_PREDRAW
DIALOG_WINCLEAR
title = content.title;
var p = ui(8); var p = ui(8);
var m_in = point_in_rectangle(mouse_mxs, mouse_mys, dialog_x + p, dialog_y + p, dialog_x + dialog_w - p, dialog_y + dialog_h - p); var m_in = point_in_rectangle(mouse_mxs, mouse_mys, dialog_x + p, dialog_y + p, dialog_x + dialog_w - p, dialog_y + dialog_h - p);
var m_ot = point_in_rectangle(mouse_mxs, mouse_mys, dialog_x, dialog_y, dialog_x + dialog_w, dialog_y + dialog_h); var m_ot = point_in_rectangle(mouse_mxs, mouse_mys, dialog_x, dialog_y, dialog_x + dialog_w, dialog_y + dialog_h);
DIALOG_DRAW_BG DIALOG_DRAW_BG
#endregion
#region content if(!is_undefined(content) && content != noone) { // content
if(!is_undefined(content) && content != noone) {
content.panel = self; content.panel = self;
var cx = dialog_x + content.showHeader * padding; var cx = dialog_x + content.showHeader * padding;
var cy = dialog_y + content.showHeader * (padding + title_height); var cy = dialog_y + content.showHeader * (padding + title_height);
content.x = cx; content.x = cx;
content.y = cy; content.y = cy;
content.onStepBegin(); content.onStepBegin();
content.pFOCUS = sFOCUS && m_in; content.pFOCUS = sFOCUS && m_in;
@ -27,33 +29,38 @@ if !ready exit;
if(!is_surface(mask_surface)) if(!is_surface(mask_surface))
resetMask(); resetMask();
DIALOG_POSTDRAW
surface_set_target(panel); surface_set_target(panel);
draw_clear(COLORS.panel_bg_clear); draw_clear(COLORS.panel_bg_clear);
WINDOW_ACTIVE = window;
content.drawContent(panel); content.drawContent(panel);
WINDOW_ACTIVE = noone;
gpu_set_blendmode(bm_subtract); gpu_set_blendmode(bm_subtract);
draw_surface_safe(mask_surface); draw_surface_safe(mask_surface);
gpu_set_blendmode(bm_normal); gpu_set_blendmode(bm_normal);
surface_reset_target(); surface_reset_target();
DIALOG_PREDRAW
content.drawGUI(); content.drawGUI();
draw_surface(panel, cx, cy); draw_surface(panel, cx, cy);
} }
#endregion
#region overlay
if(content.showHeader) { if(content.showHeader) {
var _tx = window == noone? dialog_x + ui(32) : dialog_x + ui(10);
draw_sprite_stretched_ext(THEME.ui_panel_bg, 3, dialog_x + 3, dialog_y + 3, dialog_w - 6, title_height + 2, COLORS._main_icon_light, 1); draw_sprite_stretched_ext(THEME.ui_panel_bg, 3, dialog_x + 3, dialog_y + 3, dialog_w - 6, title_height + 2, COLORS._main_icon_light, 1);
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub); draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
draw_text_cut(dialog_x + ui(32), dialog_y + ui(8), content.title, dialog_w - ui(32 + 32)); draw_text_cut(_tx, dialog_y + ui(8), content.title, dialog_w - ui(32 + 32));
var _bx = dialog_x + dialog_w - ui(28); var _bx = dialog_x + dialog_w - ui(28);
var _by = dialog_y + ui(8); var _by = dialog_y + ui(8);
var _bs = ui(20); var _bs = ui(20);
if(instanceof(content) != "Panel_Menu") if(instanceof(content) != "Panel_Menu")
if(buttonInstant(THEME.button_hide, _bx, _by, _bs, _bs, mouse_ui, sFOCUS, sHOVER, "", THEME.window_exit) == 2) { if(buttonInstant(THEME.button_hide, _bx, _by, _bs, _bs, [ mouse_mx, mouse_my ], sFOCUS, sHOVER, "", THEME.window_exit) == 2) {
DIALOG_POSTDRAW
onDestroy(); onDestroy();
instance_destroy(); instance_destroy();
} }
@ -67,7 +74,7 @@ if !ready exit;
_bx -= _bs; _bx -= _bs;
_b.setFocusHover(sFOCUS, sHOVER); _b.setFocusHover(sFOCUS, sHOVER);
_b.draw(_bx, _by, _bs, _bs, mouse_ui, THEME.button_hide); _b.draw(_bx, _by, _bs, _bs, [ mouse_mx, mouse_my ], THEME.button_hide);
_bs -= ui(4); _bs -= ui(4);
} }
} }
@ -80,14 +87,15 @@ if !ready exit;
var ss = content.showHeader? ui(20) : ui(28); var ss = content.showHeader? ui(20) : ui(28);
var sc = content.showHeader? 0.75 : 1; var sc = content.showHeader? 0.75 : 1;
if(instanceof(content) != "Panel_Menu") if(window == noone && instanceof(content) != "Panel_Menu") {
if(buttonInstant(THEME.button_hide, bx, by, ss, ss, mouse_ui, sFOCUS, sHOVER, txt, THEME.pin, ind, cc,, sc) == 2) var b = buttonInstant(THEME.button_hide, bx, by, ss, ss, [ mouse_mx, mouse_my ], sFOCUS, sHOVER, txt, THEME.pin, ind, cc, 1, sc);
destroy_on_click_out = !destroy_on_click_out; if(b == 2) destroy_on_click_out = !destroy_on_click_out;
}
if(sFOCUS) { if(sFOCUS) {
DIALOG_DRAW_FOCUS DIALOG_DRAW_FOCUS
if(!m_in && m_ot) { if(window == noone && !m_in && m_ot) {
var p = DIALOG_PAD; var p = DIALOG_PAD;
var p2 = DIALOG_PAD * 2; var p2 = DIALOG_PAD * 2;
draw_sprite_stretched_ext(THEME.dialog, 1, dialog_x - p, dialog_y - p, dialog_w + p2, dialog_h + p2, c_white, 0.4); draw_sprite_stretched_ext(THEME.dialog, 1, dialog_x - p, dialog_y - p, dialog_w + p2, dialog_h + p2, c_white, 0.4);
@ -113,4 +121,5 @@ if !ready exit;
} }
} }
#endregion
DIALOG_POSTDRAW

View file

@ -1,3 +1,5 @@
/// @description /// @description
if(!is_undefined(content) && content != noone) if(!is_undefined(content) && content != noone)
content.drawGUI(); content.drawGUI();
event_inherited();

View file

@ -212,6 +212,14 @@ event_inherited();
new checkBox(function() /*=>*/ { PREFERENCES.test_mode = !PREFERENCES.test_mode; should_restart = true; PREF_SAVE(); }) new checkBox(function() /*=>*/ { PREFERENCES.test_mode = !PREFERENCES.test_mode; should_restart = true; PREF_SAVE(); })
)); ));
if(PREFERENCES.test_mode) {
ds_list_add(pref_global, new __Panel_Linear_Setting_Item_Preference(
__txtx("pref_exp_popup_dialog", "[Experimental] Pop-up Dialog"),
"multi_window",
new checkBox(function() /*=>*/ { PREFERENCES.multi_window = !PREFERENCES.multi_window; PREF_SAVE(); })
));
}
ds_list_add(pref_global, __txt("Paths")); ds_list_add(pref_global, __txt("Paths"));
ds_list_add(pref_global, new __Panel_Linear_Setting_Item( ds_list_add(pref_global, new __Panel_Linear_Setting_Item(

View file

@ -180,6 +180,7 @@ if(winMan_isMinimized()) exit;
NODE_DROPPER_TARGET_CAN = false; NODE_DROPPER_TARGET_CAN = false;
panelDisplayDraw(); panelDisplayDraw();
dialogGUIDraw();
#endregion #endregion
#region debug #region debug

View file

@ -1,6 +1,6 @@
/// @description init /// @description init
if(winMan_isMinimized()) exit; if(winMan_isMinimized()) exit;
winManStep() winManStep();
//print("===== Step start ====="); //print("===== Step start =====");

View file

@ -1,4 +1,6 @@
/// @description init /// @description init
if(PREFERENCES.multi_window) winwin_update();
global.__debug_runner++; global.__debug_runner++;
global.cache_call = 0; global.cache_call = 0;
global.cache_hit = 0; global.cache_hit = 0;
@ -22,7 +24,11 @@ _FILE_DROPPED = false;
minimized = false; minimized = false;
} }
game_set_speed(window_has_focus() || IS_PLAYING? PREFERENCES.ui_framerate : PREFERENCES.ui_framerate_non_focus, gamespeed_fps); var foc = window_has_focus();
if(HOVER && instance_exists(HOVER) && HOVER.window != noone) foc = true;
game_set_speed(foc || IS_PLAYING? PREFERENCES.ui_framerate : PREFERENCES.ui_framerate_non_focus, gamespeed_fps);
WINDOW_ACTIVE = noone;
#endregion #endregion
#region fpss #region fpss
@ -81,17 +87,17 @@ _FILE_DROPPED = false;
if(mouse_release(mb_any)) DIALOG_CLICK = true; if(mouse_release(mb_any)) DIALOG_CLICK = true;
HOVER = noone; HOVER = noone;
with(_p_dialog) checkMouse(); with(_p_dialog) checkMouse(); WINDOW_ACTIVE = noone;
if(PANEL_MAIN != 0) PANEL_MAIN.stepBegin(); if(PANEL_MAIN != 0) PANEL_MAIN.stepBegin();
DIALOG_DEPTH_HOVER = 0; DIALOG_DEPTH_HOVER = 0;
with(_p_dialog) checkFocus(); with(_p_dialog) checkFocus(); WINDOW_ACTIVE = noone;
with(_p_dialog) checkDepth(); with(_p_dialog) checkDepth(); WINDOW_ACTIVE = noone;
with(_p_dialog) doDrag(); with(_p_dialog) doDrag(); WINDOW_ACTIVE = noone;
with(_p_dialog) doResize(); with(_p_dialog) doResize(); WINDOW_ACTIVE = noone;
#endregion #endregion
#region auto save #region auto save
@ -276,4 +282,4 @@ _FILE_DROPPED = false;
#endregion #endregion
//if(global.cache_call) print($"CACHE called: {global.cache_call} | hit: {global.cache_hit} ({global.cache_hit / global.cache_call * 100}%)"); //if(global.cache_call) print($"CACHE called: {global.cache_call} | hit: {global.cache_hit} ({global.cache_hit / global.cache_call * 100}%)");
//if(!is_struct(FOCUS)) print(FOCUS); // print($"{is_struct(HOVER)? instanceof(HOVER) : HOVER}, {is_struct(FOCUS)? instanceof(FOCUS) : FOCUS}");

View file

@ -8,12 +8,17 @@
function menuCall(menu_id = "", menu = [], _x = 0, _y = 0, align = fa_left, context = noone) { function menuCall(menu_id = "", menu = [], _x = 0, _y = 0, align = fa_left, context = noone) {
if(array_empty(menu)) return noone; if(array_empty(menu)) return noone;
FOCUS_BEFORE = FOCUS;
_x = _x == 0? mouse_mx + ui(4) : _x; _x = _x == 0? mouse_mx + ui(4) : _x;
_y = _y == 0? mouse_my + ui(4) : _y; _y = _y == 0? mouse_my + ui(4) : _y;
FOCUS_BEFORE = FOCUS;
var dia = dialogCall(o_dialog_menubox, _x, _y); var dia = dialogCall(o_dialog_menubox, _x, _y);
// if(WINDOW_ACTIVE != noone) {
// dia.window = WINDOW_ACTIVE;
// }
if(menu_id != "" && ds_map_exists(CONTEXT_MENU_CALLBACK, menu_id)) { if(menu_id != "" && ds_map_exists(CONTEXT_MENU_CALLBACK, menu_id)) {
var callbacks = CONTEXT_MENU_CALLBACK[? menu_id]; var callbacks = CONTEXT_MENU_CALLBACK[? menu_id];

View file

@ -60,6 +60,7 @@
globalvar FOCUS, FOCUS_STR, FOCUS_CONTENT, HOVER, HOVERING_ELEMENT, _HOVERING_ELEMENT; globalvar FOCUS, FOCUS_STR, FOCUS_CONTENT, HOVER, HOVERING_ELEMENT, _HOVERING_ELEMENT;
globalvar DOUBLE_CLICK, DOUBLE_CLICK_POS; globalvar DOUBLE_CLICK, DOUBLE_CLICK_POS;
globalvar DIALOG_CLICK; globalvar DIALOG_CLICK;
globalvar WINDOW_ACTIVE;
DOUBLE_CLICK_POS = [ 0, 0 ]; DOUBLE_CLICK_POS = [ 0, 0 ];
DOUBLE_CLICK = false; DOUBLE_CLICK = false;
@ -78,6 +79,7 @@
ADD_NODE_PAGE = 0; ADD_NODE_PAGE = 0;
ADD_NODE_SCROLL = 0; ADD_NODE_SCROLL = 0;
WINDOW_ACTIVE = noone;
#endregion #endregion
#region macro #region macro
@ -93,18 +95,18 @@
#macro UI_SCALE PREFERENCES.display_scaling #macro UI_SCALE PREFERENCES.display_scaling
#macro mouse_mx (PEN_USE? PEN_X : device_mouse_x_to_gui(0)) #macro mouse_mx (PEN_USE? PEN_X : (WINDOW_ACTIVE == noone? device_mouse_x_to_gui(0) : winwin_mouse_get_x(WINDOW_ACTIVE)))
#macro mouse_my (PEN_USE? PEN_Y : device_mouse_y_to_gui(0)) #macro mouse_my (PEN_USE? PEN_Y : (WINDOW_ACTIVE == noone? device_mouse_y_to_gui(0) : winwin_mouse_get_y(WINDOW_ACTIVE)))
#macro mouse_mxs (FILE_IS_DROPPING? FILE_DROPPING_X : mouse_mx) #macro mouse_mxs (FILE_IS_DROPPING? FILE_DROPPING_X : mouse_mx)
#macro mouse_mys (FILE_IS_DROPPING? FILE_DROPPING_Y : mouse_my) #macro mouse_mys (FILE_IS_DROPPING? FILE_DROPPING_Y : mouse_my)
#macro mouse_raw_x (device_mouse_raw_x(0) + window_get_x()) #macro mouse_raw_x display_mouse_get_x()
#macro mouse_raw_y (device_mouse_raw_y(0) + window_get_y()) #macro mouse_raw_y display_mouse_get_y()
#macro mouse_ui [device_mouse_x_to_gui(0), device_mouse_y_to_gui(0)] #macro mouse_ui [device_mouse_x_to_gui(0), device_mouse_y_to_gui(0)]
#macro sFOCUS (FOCUS == self.id) #macro sFOCUS (FOCUS == self.id)
#macro sHOVER (!CURSOR_IS_LOCK && HOVER == self.id) #macro sHOVER (!CURSOR_IS_LOCK && (HOVER == self.id || (WINDOW_ACTIVE != noone && winwin_mouse_is_over(WINDOW_ACTIVE))))
#macro DELTA_TIME delta_time / 1_000_000 #macro DELTA_TIME delta_time / 1_000_000

View file

@ -11,95 +11,105 @@
#macro SCROLL_SPEED PREFERENCES.mouse_wheel_speed #macro SCROLL_SPEED PREFERENCES.mouse_wheel_speed
#macro MOUSE_MOVED (window_mouse_get_delta_x() || window_mouse_get_delta_y()) #macro MOUSE_MOVED (window_mouse_get_delta_x() || window_mouse_get_delta_y())
#macro mouse_wheel_up mouse_wheel_up_override
#macro __mouse_wheel_up mouse_wheel_up
#macro mouse_wheel_down mouse_wheel_down_override
#macro __mouse_wheel_down mouse_wheel_down
function setMouseWrap() { function setMouseWrap() {
INLINE INLINE
MOUSE_WRAP = true; MOUSE_WRAP = true;
} }
#endregion #endregion
function mouse_click(mouse, focus = true) { #region function mouse_click(mouse, focus = true) {
INLINE INLINE
if(MOUSE_BLOCK) return false; if(MOUSE_BLOCK) return false;
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_CLICK) return mouse == mb_right; if(PEN_RIGHT_CLICK) return mouse == mb_right;
return mouse_check_button(mouse); return WINDOW_ACTIVE == noone? mouse_check_button(mouse) : winwin_mouse_check_button(WINDOW_ACTIVE, mouse);
} #endregion }
function mouse_press(mouse, focus = true) { #region function mouse_press(mouse, focus = true) {
INLINE INLINE
if(MOUSE_BLOCK) return false; if(MOUSE_BLOCK) return false;
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_PRESS) return mouse == mb_right; if(PEN_RIGHT_PRESS) return mouse == mb_right;
return mouse_check_button_pressed(mouse); if(WINDOW_ACTIVE == noone) return mouse_check_button_pressed(mouse);
} #endregion if(mouse != mb_any) return winwin_mouse_check_button_pressed(WINDOW_ACTIVE, mouse);
function mouse_release(mouse, focus = true) { #region return winwin_mouse_check_button_pressed(WINDOW_ACTIVE, mb_left) || winwin_mouse_check_button_pressed(WINDOW_ACTIVE, mb_right);
}
function mouse_release(mouse, focus = true) {
INLINE INLINE
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_RELEASE) return mouse == mb_right; if(PEN_RIGHT_RELEASE) return mouse == mb_right;
return mouse_check_button_released(mouse) || ((mouse == mb_left || mouse == mb_any) && PEN_RELEASED); var rl = WINDOW_ACTIVE == noone? mouse_check_button_released(mouse) : winwin_mouse_check_button_released(WINDOW_ACTIVE, mouse);
} #endregion return rl || ((mouse == mb_left || mouse == mb_any) && PEN_RELEASED);
}
function mouse_lclick(focus = true) { #region function mouse_lclick(focus = true) {
INLINE INLINE
if(MOUSE_BLOCK) return false; if(MOUSE_BLOCK) return false;
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_CLICK || PEN_RIGHT_RELEASE) return false; if(PEN_RIGHT_CLICK || PEN_RIGHT_RELEASE) return false;
return mouse_check_button(mb_left); return WINDOW_ACTIVE == noone? mouse_check_button(mb_left) : winwin_mouse_check_button(WINDOW_ACTIVE, mb_left);
} #endregion }
function mouse_lpress(focus = true) { #region function mouse_lpress(focus = true) {
INLINE INLINE
if(MOUSE_BLOCK) return false; if(MOUSE_BLOCK) return false;
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_PRESS) return false; if(PEN_RIGHT_PRESS) return false;
return mouse_check_button_pressed(mb_left); return WINDOW_ACTIVE == noone? mouse_check_button_pressed(mb_left) : winwin_mouse_check_button_pressed(WINDOW_ACTIVE, mb_left);
} #endregion }
function mouse_lrelease(focus = true) { #region function mouse_lrelease(focus = true) {
INLINE INLINE
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_RELEASE) return false; if(PEN_RIGHT_RELEASE) return false;
if(PEN_RELEASED) return true; if(PEN_RELEASED) return true;
return mouse_check_button_released(mb_left); return WINDOW_ACTIVE == noone? mouse_check_button_released(mb_left) : winwin_mouse_check_button_released(WINDOW_ACTIVE, mb_left);
} #endregion }
function mouse_rclick(focus = true) { #region function mouse_rclick(focus = true) {
INLINE INLINE
if(MOUSE_BLOCK) return false; if(MOUSE_BLOCK) return false;
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_CLICK) return true; if(PEN_RIGHT_CLICK) return true;
return mouse_check_button(mb_right); return WINDOW_ACTIVE == noone? mouse_check_button(mb_right) : winwin_mouse_check_button(WINDOW_ACTIVE, mb_right);
} #endregion }
function mouse_rpress(focus = true) { #region function mouse_rpress(focus = true) {
INLINE INLINE
if(MOUSE_BLOCK) return false; if(MOUSE_BLOCK) return false;
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_PRESS) return true; if(PEN_RIGHT_PRESS) return true;
return mouse_check_button_pressed(mb_right); return WINDOW_ACTIVE == noone? mouse_check_button_pressed(mb_right) : winwin_mouse_check_button_pressed(WINDOW_ACTIVE, mb_right);
} #endregion }
function mouse_rrelease(focus = true) { #region function mouse_rrelease(focus = true) {
INLINE INLINE
if(!focus) return false; if(!focus) return false;
if(PEN_RIGHT_RELEASE) return true; if(PEN_RIGHT_RELEASE) return true;
return mouse_check_button_released(mb_right); return WINDOW_ACTIVE == noone? mouse_check_button_released(mb_right) : winwin_mouse_check_button_released(WINDOW_ACTIVE, mb_right);
} #endregion }
function mouse_lock(mx = CURSOR_LOCK_X, my = CURSOR_LOCK_Y) { #region function mouse_lock(mx = CURSOR_LOCK_X, my = CURSOR_LOCK_Y) {
INLINE INLINE
CURSOR_LOCK = true; CURSOR_LOCK = true;
@ -107,4 +117,7 @@ function mouse_lock(mx = CURSOR_LOCK_X, my = CURSOR_LOCK_Y) { #region
CURSOR_LOCK_Y = my; CURSOR_LOCK_Y = my;
window_mouse_set(CURSOR_LOCK_X, CURSOR_LOCK_Y); window_mouse_set(CURSOR_LOCK_X, CURSOR_LOCK_Y);
} #endregion }
function mouse_wheel_up_override() { return WINDOW_ACTIVE == noone? __mouse_wheel_up() : winwin_mouse_wheel_up(WINDOW_ACTIVE); }
function mouse_wheel_down_override() { return WINDOW_ACTIVE == noone? __mouse_wheel_down() : winwin_mouse_wheel_down(WINDOW_ACTIVE); }

View file

@ -864,7 +864,7 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
var sBase = surface_get_target(); var sBase = surface_get_target();
try { try {
update(frame); if(attributes.update_graph) update(frame);
} catch(exception) { } catch(exception) {
var sCurr = surface_get_target(); var sCurr = surface_get_target();
while(surface_get_target() != sBase) while(surface_get_target() != sBase)

View file

@ -23,7 +23,10 @@ function Node_Json_File_Write(_x, _y, _group = noone) : Node(_x, _y, _group) con
json_save_struct(path, cont); json_save_struct(path, cont);
} }
static update = function(frame = CURRENT_FRAME) { writeFile(); } static update = function(frame = CURRENT_FRAME) {
writeFile();
}
static onInspector1Update = function() { writeFile(); } static onInspector1Update = function() { writeFile(); }
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) {

View file

@ -401,10 +401,14 @@ function Panel(_parent, _x, _y, _w, _h) constructor {
if(con && point_in_rectangle(_mx, _my, x + ui(2), y + ui(2), x + w - ui(4), y + h - ui(4))) { if(con && point_in_rectangle(_mx, _my, x + ui(2), y + ui(2), x + w - ui(4), y + h - ui(4))) {
HOVER = self; HOVER = self;
// print($"Hovering {instanceof(con)} : {mouse_press(mb_any)} : {random(1)}")
if(mouse_press(mb_any)) if(mouse_press(mb_any))
setFocus(self); setFocus(self);
if(FOCUS == self && con) if(FOCUS == self && con)
FOCUS_STR = con.context_str; FOCUS_STR = con.context_str;
} else { } else {
for(var i = 0; i < array_length(childs); i++) for(var i = 0; i < array_length(childs); i++)
childs[i].stepBegin(); childs[i].stepBegin();
@ -905,6 +909,7 @@ function PanelContent() constructor {
dragSurface = surface_create(1, 1); dragSurface = surface_create(1, 1);
showHeader = true; showHeader = true;
window = noone;
title_actions = []; title_actions = [];
@ -942,6 +947,7 @@ function PanelContent() constructor {
function onStepBegin() { function onStepBegin() {
mx = mouse_mx - x; mx = mouse_mx - x;
my = mouse_my - y; my = mouse_my - y;
window = WINDOW_ACTIVE;
stepBegin(); stepBegin();
} }

View file

@ -29,7 +29,7 @@
#endregion #endregion
#region functions #region functions
function clearPanel() { #region function clearPanel() {
delete PANEL_MAIN; delete PANEL_MAIN;
delete PANEL_MENU; delete PANEL_MENU;
delete PANEL_INSPECTOR; delete PANEL_INSPECTOR;
@ -45,9 +45,9 @@
PANEL_COLLECTION = {}; PANEL_COLLECTION = {};
PANEL_FILE = 0; PANEL_FILE = 0;
} #endregion }
function getPanelFromName(name, create = false, focus = true) { #region function getPanelFromName(name, create = false, focus = true) {
switch(name) { switch(name) {
case "Panel_Menu" : var p = (create || findPanel(name))? new Panel_Menu() : PANEL_MENU; if(focus) { PANEL_MENU = p; } return p; case "Panel_Menu" : var p = (create || findPanel(name))? new Panel_Menu() : PANEL_MENU; if(focus) { PANEL_MENU = p; } return p;
case "Panel_Inspector" : var p = (create || findPanel(name))? new Panel_Inspector() : PANEL_INSPECTOR; if(focus) { PANEL_INSPECTOR = p; } return p; case "Panel_Inspector" : var p = (create || findPanel(name))? new Panel_Inspector() : PANEL_INSPECTOR; if(focus) { PANEL_INSPECTOR = p; } return p;
@ -75,14 +75,14 @@
} }
return noone; return noone;
} #endregion }
function LoadPanelStruct(struct) { function LoadPanelStruct(struct) {
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));
loadPanelStruct(PANEL_MAIN, struct); loadPanelStruct(PANEL_MAIN, struct);
} }
function loadPanelStruct(panel, str) { #region function loadPanelStruct(panel, str) {
var cont = str.content; var cont = str.content;
if(variable_struct_exists(str, "split")) { if(variable_struct_exists(str, "split")) {
@ -111,14 +111,14 @@
_pnCont.deserialize(_content); _pnCont.deserialize(_content);
} }
} }
} #endregion }
function loadPanel(path) { function loadPanel(path) {
CURRENT_PANEL = json_load_struct(path); CURRENT_PANEL = json_load_struct(path);
LoadPanelStruct(CURRENT_PANEL.panel); LoadPanelStruct(CURRENT_PANEL.panel);
} }
function checkPanelValid() { #region function checkPanelValid() {
var val = true; var val = true;
var _mst = ""; var _mst = "";
if(!is_instanceof(PANEL_GRAPH.panel, Panel)) { val = false; _mst += "Graph, " }; if(!is_instanceof(PANEL_GRAPH.panel, Panel)) { val = false; _mst += "Graph, " };
@ -136,16 +136,16 @@
} }
return val; return val;
} #endregion }
function panelAdd(panel, create = false, focus = true) { #region function panelAdd(panel, create = false, focus = true) {
var pan = getPanelFromName(panel, create, focus); var pan = getPanelFromName(panel, create, focus);
if(pan == noone) return noone; if(pan == noone) return noone;
return dialogPanelCall(pan, noone, noone, { focus }); return dialogPanelCall(pan, noone, noone, { focus });
} #endregion }
function panelObjectInit() { #region 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();
@ -153,18 +153,18 @@
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();
} #endregion }
function resetPanel(check = true) { #region function resetPanel(check = true) {
clearPanel(); clearPanel();
panelObjectInit(); panelObjectInit();
loadPanelStruct(PANEL_MAIN, CURRENT_PANEL.panel); loadPanelStruct(PANEL_MAIN, CURRENT_PANEL.panel);
PANEL_MAIN.refresh(); PANEL_MAIN.refresh();
if(check) checkPanelValid(); if(check) checkPanelValid();
} #endregion }
function __initPanel() { #region function __initPanel() {
directory_verify($"{DIRECTORY}layouts"); directory_verify($"{DIRECTORY}layouts");
if(check_version($"{DIRECTORY}layouts/version")) if(check_version($"{DIRECTORY}layouts/version"))
@ -174,9 +174,9 @@
panelDisplayInit(); panelDisplayInit();
checkPanelValid(); checkPanelValid();
} #endregion }
function setPanel() { #region function setPanel() {
globalvar CURRENT_PANEL; globalvar CURRENT_PANEL;
panelObjectInit(); panelObjectInit();
@ -188,9 +188,9 @@
PANEL_MAIN.refresh(); PANEL_MAIN.refresh();
PANEL_MAIN.refreshSize(); PANEL_MAIN.refreshSize();
} #endregion }
function findPanel(_type, _pane = PANEL_MAIN) { #region function findPanel(_type, _pane = PANEL_MAIN) {
var pan = _findPanel(_type, _pane); var pan = _findPanel(_type, _pane);
if(pan) return pan; if(pan) return pan;
@ -200,9 +200,9 @@
} }
return noone; return noone;
} #endregion }
function _findPanel(_type, _pane, _res = noone) { #region function _findPanel(_type, _pane, _res = noone) {
if(instanceof(_pane) != "Panel") if(instanceof(_pane) != "Panel")
return _res; return _res;
@ -218,13 +218,13 @@
} }
return _res; return _res;
} #endregion }
function findPanels(_type, _pane = PANEL_MAIN) { #region function findPanels(_type, _pane = PANEL_MAIN) {
return _findPanels(_type, _pane, []); return _findPanels(_type, _pane, []);
} #endregion }
function _findPanels(_type, _pane, _arr = []) { #region function _findPanels(_type, _pane, _arr = []) {
if(!is_instanceof(_pane, Panel)) if(!is_instanceof(_pane, Panel))
return _arr; return _arr;
@ -239,9 +239,9 @@
_arr = _findPanels(_type, _pane.childs[i], _arr); _arr = _findPanels(_type, _pane.childs[i], _arr);
return _arr; return _arr;
} #endregion }
function panelInit() { #region function panelInit() {
panel_dragging = noone; panel_dragging = noone;
panel_hovering = noone; panel_hovering = noone;
panel_split = 0; panel_split = 0;
@ -254,9 +254,14 @@
panel_draw_y1 = noone; panel_draw_y1_to = noone; panel_draw_y1 = noone; panel_draw_y1_to = noone;
panel_draw_depth = 0; panel_draw_depth = 0;
} #endregion
function panelDraw() { #region dialog_popup = 0;
dialog_popup_to = 0;
dialog_popup_x = 0;
dialog_popup_y = 0;
}
function panelDraw() {
panel_draw_x0 = panel_draw_x0 == noone? panel_draw_x0_to : lerp_float(panel_draw_x0, panel_draw_x0_to, 3); panel_draw_x0 = panel_draw_x0 == noone? panel_draw_x0_to : lerp_float(panel_draw_x0, panel_draw_x0_to, 3);
panel_draw_y0 = panel_draw_y0 == noone? panel_draw_y0_to : lerp_float(panel_draw_y0, panel_draw_y0_to, 3); panel_draw_y0 = panel_draw_y0 == noone? panel_draw_y0_to : lerp_float(panel_draw_y0, panel_draw_y0_to, 3);
panel_draw_x1 = panel_draw_x1 == noone? panel_draw_x1_to : lerp_float(panel_draw_x1, panel_draw_x1_to, 3); panel_draw_x1 = panel_draw_x1 == noone? panel_draw_x1_to : lerp_float(panel_draw_x1, panel_draw_x1_to, 3);
@ -264,25 +269,28 @@
panel_draw_depth = lerp_float(panel_draw_depth, panel_split == 4, 3); panel_draw_depth = lerp_float(panel_draw_depth, panel_split == 4, 3);
var _rr = THEME_VALUE.panel_corner_radius;
if(panel_draw_x0_to != noone) { if(panel_draw_x0_to != noone) {
draw_set_color(COLORS._main_accent); draw_set_color(COLORS._main_accent);
if(panel_split == 4) { if(panel_split == 4) {
var dist = ui(8) * panel_draw_depth; var dist = ui(8) * panel_draw_depth;
draw_set_alpha(.2); draw_set_alpha(.2);
draw_roundrect_ext(panel_draw_x0 - dist, panel_draw_y0 - dist, panel_draw_x1 - dist, panel_draw_y1 - dist, THEME_VALUE.panel_corner_radius, THEME_VALUE.panel_corner_radius, false); draw_roundrect_ext(panel_draw_x0 - dist, panel_draw_y0 - dist, panel_draw_x1 - dist, panel_draw_y1 - dist, _rr, _rr, false);
draw_set_alpha(1.); draw_set_alpha(1.);
draw_roundrect_ext(panel_draw_x0 - dist, panel_draw_y0 - dist, panel_draw_x1 - dist, panel_draw_y1 - dist, THEME_VALUE.panel_corner_radius, THEME_VALUE.panel_corner_radius, true); draw_roundrect_ext(panel_draw_x0 - dist, panel_draw_y0 - dist, panel_draw_x1 - dist, panel_draw_y1 - dist, _rr, _rr, true);
draw_set_alpha(.2); draw_set_alpha(.2);
draw_roundrect_ext(panel_draw_x0 + dist, panel_draw_y0 + dist, panel_draw_x1 + dist, panel_draw_y1 + dist, THEME_VALUE.panel_corner_radius, THEME_VALUE.panel_corner_radius, false); draw_roundrect_ext(panel_draw_x0 + dist, panel_draw_y0 + dist, panel_draw_x1 + dist, panel_draw_y1 + dist, _rr, _rr, false);
draw_set_alpha(1.); draw_set_alpha(1.);
draw_roundrect_ext(panel_draw_x0 + dist, panel_draw_y0 + dist, panel_draw_x1 + dist, panel_draw_y1 + dist, THEME_VALUE.panel_corner_radius, THEME_VALUE.panel_corner_radius, true); draw_roundrect_ext(panel_draw_x0 + dist, panel_draw_y0 + dist, panel_draw_x1 + dist, panel_draw_y1 + dist, _rr, _rr, true);
} else { } else {
draw_set_alpha(.4); draw_set_alpha(.4);
draw_roundrect_ext(panel_draw_x0, panel_draw_y0, panel_draw_x1, panel_draw_y1, THEME_VALUE.panel_corner_radius, THEME_VALUE.panel_corner_radius, false); draw_roundrect_ext(panel_draw_x0, panel_draw_y0, panel_draw_x1, panel_draw_y1, _rr, _rr, false);
draw_set_alpha(1.); draw_set_alpha(1.);
draw_roundrect_ext(panel_draw_x0, panel_draw_y0, panel_draw_x1, panel_draw_y1, THEME_VALUE.panel_corner_radius, THEME_VALUE.panel_corner_radius, true); draw_roundrect_ext(panel_draw_x0, panel_draw_y0, panel_draw_x1, panel_draw_y1, _rr, _rr, true);
} }
} }
@ -340,13 +348,33 @@
panel_draw_depth = 0; panel_draw_depth = 0;
} }
} }
} #endregion }
function panelSerialize(_content = false) { #region function dialogGUIDraw() {
draw_set_color(COLORS._main_accent);
dialog_popup = lerp_float(dialog_popup, dialog_popup_to, 5);
dialog_popup_to = 0;
if(dialog_popup > 0) {
var _rr = THEME_VALUE.panel_corner_radius;
var dpw = ui(24) * dialog_popup;
var dph = ui(24) * dialog_popup;
var dpx = clamp(dialog_popup_x, 8 + dpw, WIN_W - 8 - dpw);
var dpy = clamp(dialog_popup_y, 8 + dph, WIN_H - 8 - dph);
draw_set_alpha(.4);
draw_roundrect_ext(dpx - dpw, dpy - dph, dpx + dpw, dpy + dph, _rr, _rr, false);
draw_set_alpha(1.);
draw_roundrect_ext(dpx - dpw, dpy - dph, dpx + dpw, dpy + dph, _rr, _rr, true);
}
}
function panelSerialize(_content = false) {
return { panel : _panelSerialize(PANEL_MAIN, _content) }; return { panel : _panelSerialize(PANEL_MAIN, _content) };
} #endregion }
function _panelSerialize(_panel, _content = false) { #region function _panelSerialize(_panel, _content = false) {
var cont = {}; var cont = {};
var ind = 0; var ind = 0;
@ -372,13 +400,13 @@
} }
return cont; return cont;
} #endregion }
function panelSerializeArray() { #region function panelSerializeArray() {
return _panelSerializeArray(PANEL_MAIN); return _panelSerializeArray(PANEL_MAIN);
} #endregion }
function _panelSerializeArray(panel) { #region function _panelSerializeArray(panel) {
var cont = []; var cont = [];
if(!array_empty(panel.childs)) { if(!array_empty(panel.childs)) {
@ -391,7 +419,7 @@
} }
return cont; return cont;
} #endregion }
#endregion #endregion
#region fullscreen #region fullscreen

View file

@ -658,7 +658,7 @@ function Panel_Inspector() : PanelContent() constructor {
} }
draw_set_text(f_p1, fa_left, fa_center, COLORS._main_text); draw_set_text(f_p1, fa_left, fa_center, COLORS._main_text);
draw_text_add(ui(8), yy + hg / 2, edt[0]); draw_text_alpha(ui(8), yy + hg / 2, edt[0]);
var _param = new widgetParam(wx0, yy, ww, hg, val, {}, _m, x + contentPane.x, y + contentPane.y); var _param = new widgetParam(wx0, yy, ww, hg, val, {}, _m, x + contentPane.x, y + contentPane.y);
_param.s = hg; _param.s = hg;

View file

@ -133,6 +133,8 @@ function Panel_Preview_Window() : PanelContent() constructor {
else if(scale > 0.25) inc = 0.25; else if(scale > 0.25) inc = 0.25;
else inc = 0.05; else inc = 0.05;
//if(WINDOW_ACTIVE != noone) print($"{winwin_mouse_wheel_down(WINDOW_ACTIVE)} : {winwin_mouse_wheel_up(WINDOW_ACTIVE)} : {random(1)}");
var s = scale; var s = scale;
if(mouse_wheel_down()) { if(mouse_wheel_down()) {
for( var i = 0, n = array_length(scale_levels) - 1; i < n; i++ ) { for( var i = 0, n = array_length(scale_levels) - 1; i < n; i++ ) {

View file

@ -171,6 +171,10 @@
#endregion #endregion
#region ////////////////////////////////////////////////////////////////////// EXPERIMENT ///////////////////////////////////////////////////////////////////////
PREFERENCES.multi_window = false;
#endregion
PREFERENCES_DEF = variable_clone(PREFERENCES); PREFERENCES_DEF = variable_clone(PREFERENCES);
#endregion #endregion

View file

@ -1,3 +1,7 @@
#macro surface_reset_target surface_reset_target_override
#macro __surface_reset_target surface_reset_target
function surface_reset_target_override() { __surface_reset_target(); winwin_draw_sync(); }
#region ==================================== DRAW ==================================== #region ==================================== DRAW ====================================
function draw_surface_safe(surface, _x = 0, _y = 0) { #region function draw_surface_safe(surface, _x = 0, _y = 0) { #region

View file

@ -0,0 +1,22 @@
global.__winwin_map = ds_map_create();
function winwin(_ptr) constructor {
__ptr__ = _ptr;
}
function winwin_config() constructor {
static caption = "Window";
static kind = winwin_kind_normal;
static resize = false;
static show = true;
static topmost = false;
static taskbar_button = true; // can only disable for borderless!
static clickthrough = false;
static noactivate = false;
static per_pixel_alpha = false;
static thread = false;
static vsync = 0;
static close_button = 1;
static owner = undefined;
}

View file

@ -0,0 +1,13 @@
{
"$GMScript":"v1",
"%Name":"winwin_extras",
"isCompatibility":false,
"isDnD":false,
"name":"winwin_extras",
"parent":{
"name":"WinMan",
"path":"folders/_extensions/WinMan.yy",
},
"resourceType":"GMScript",
"resourceVersion":"2.0",
}