alot of stuff

This commit is contained in:
2025-10-22 16:43:36 -07:00
parent 734587569a
commit b6126945fd
8 changed files with 110 additions and 35 deletions

View File

@@ -1,6 +1,8 @@
local threading = require("libs.threading")
local dragging = nil
local resizing = false
local offsetX, offsetY = 0, 0
local key = {}
local function bringtofront(indx)
local win = _G.windows[indx]
if win.alwaysOnTop or win.alwaysBelow then return end
@@ -31,7 +33,13 @@ while true do
if data[1] == "mouse_click" then
for indx = #_G.windows, 1, -1 do
local win = _G.windows[indx]
if win.y - 1 == data[4] and win.x + 1 <= data[3] and win.x + win.w >= data[3] and data[2] == 1 and win.decorations then
if data[4] == 1 then
break
elseif win.x+win.w-1 == data[3] and win.y+win.h-1 == data[4] and win.decorations and win.resizable then
dragging = win
resizing = true
bringtofront(indx)
elseif ((win.y - 1 == data[4] and win.x + 1 <= data[3] and win.x + win.w >= data[3] and data[2] == 1 and win.decorations) or (win.y <= data[4] and win.x <= data[3] and win.y + win.h > data[4] and win.x + win.w > data[3] and key[keys["leftAlt"] and win.draggable])) then
dragging = win
offsetX = win.x - data[3]
offsetY = win.y - data[4]
@@ -49,8 +57,14 @@ while true do
end
elseif data[1] == "mouse_drag" then
if data[2] == 1 and dragging then
dragging.x = data[3] + offsetX
dragging.y = data[4] + offsetY
if resizing then
dragging.w = math.max(data[3] - dragging.x + 1,dragging.min_w)
dragging.h = math.max(data[4] - dragging.y + 1,dragging.min_h)
threading.addThread(function()dragging.resized(dragging.w,dragging.h)end)
else
dragging.x = data[3] + offsetX
dragging.y = data[4] + offsetY
end
else
for indx = #_G.windows, 1, -1 do
local win = _G.windows[indx]
@@ -64,6 +78,7 @@ while true do
elseif data[1] == "mouse_up" then
if data[2] == 1 and dragging then
dragging = nil
resizing = false
else
for indx = #_G.windows, 1, -1 do
local win = _G.windows[indx]
@@ -83,6 +98,7 @@ while true do
end
end
elseif data[1] == "key" then
key[data[2]] = true
if _G.windows[#_G.windows] then
threading.addThread(function() _G.windows[#_G.windows].key(data[2], data[3]) end)
end
@@ -91,6 +107,7 @@ while true do
threading.addThread(function() _G.windows[#_G.windows].char(data[2]) end)
end
elseif data[1] == "key_up" then
key[data[2]] = false
if _G.windows[#_G.windows] then
threading.addThread(function() _G.windows[#_G.windows].key_up(data[2]) end)
end