fullscreen implementation
This commit is contained in:
@@ -33,24 +33,39 @@ while true do
|
||||
if data[1] == "mouse_click" then
|
||||
for indx = #_G.windows, 1, -1 do
|
||||
local win = _G.windows[indx]
|
||||
local h= win.h
|
||||
local w = win.w
|
||||
local x = win.x
|
||||
local y = win.y
|
||||
if win.isFullscreen then
|
||||
local sw,sh = term.getSize()
|
||||
w = sw
|
||||
h = sh-2
|
||||
x=1
|
||||
y=3
|
||||
end
|
||||
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
|
||||
elseif x+w-1 == data[3] and y+h-1 == data[4] and win.decorations and win.resizable and not win.isFullscreen 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
|
||||
elseif ((y - 1 == data[4] and x + 2 <= data[3] and x + w >= data[3] and data[2] == 1 and win.decorations) or (y <= data[4] and x <= data[3] and y + h > data[4] and x + w > data[3] and key[keys["leftAlt"]] and win.draggable)) and not win.isFullscreen then
|
||||
dragging = win
|
||||
offsetX = win.x - data[3]
|
||||
offsetY = win.y - data[4]
|
||||
offsetX = x - data[3]
|
||||
offsetY = y - data[4]
|
||||
bringtofront(indx)
|
||||
break
|
||||
elseif win.y - 1 == data[4] and win.x == data[3] and win.decorations then
|
||||
elseif y - 1 == data[4] and x == data[3] and win.decorations then
|
||||
threading.addThread(function() win.closeRequested() end)
|
||||
bringtofront(indx)
|
||||
break
|
||||
elseif win.y <= data[4] and win.x <= data[3] and win.y + win.h > data[4] and win.x + win.w > data[3] then
|
||||
threading.addThread(function() win.clicked(data[3] - win.x + 1, data[4] - win.y + 1, data[2]) end)
|
||||
elseif y - 1 == data[4] and x+1 == data[3] and win.decorations then
|
||||
threading.addThread(function() win.fullscreen() end)
|
||||
bringtofront(indx)
|
||||
break
|
||||
elseif y <= data[4] and x <= data[3] and y + h > data[4] and x + w > data[3] then
|
||||
threading.addThread(function() win.clicked(data[3] - x + 1, data[4] - y + 1, data[2]) end)
|
||||
bringtofront(indx)
|
||||
break
|
||||
end
|
||||
@@ -69,8 +84,19 @@ while true do
|
||||
else
|
||||
for indx = #_G.windows, 1, -1 do
|
||||
local win = _G.windows[indx]
|
||||
if win.y <= data[4] and win.x <= data[3] and win.y + win.h > data[4] and win.x + win.w > data[3] then
|
||||
threading.addThread(function() win.dragged(data[3] - win.x + 1, data[4] - win.y + 1, data[2]) end)
|
||||
local h= win.h
|
||||
local w = win.w
|
||||
local x = win.x
|
||||
local y = win.y
|
||||
if win.isFullscreen then
|
||||
local sw,sh = term.getSize()
|
||||
w = sw
|
||||
h = sh-2
|
||||
x=1
|
||||
y=3
|
||||
end
|
||||
if y <= data[4] and x <= data[3] and y + h > data[4] and x + w > data[3] then
|
||||
threading.addThread(function() win.dragged(data[3] - x + 1, data[4] - y + 1, data[2]) end)
|
||||
bringtofront(indx)
|
||||
break
|
||||
end
|
||||
@@ -83,8 +109,19 @@ while true do
|
||||
else
|
||||
for indx = #_G.windows, 1, -1 do
|
||||
local win = _G.windows[indx]
|
||||
if win.y <= data[4] and win.x <= data[3] and win.y + win.h > data[4] and win.x + win.w > data[3] then
|
||||
threading.addThread(function() win.released(data[3] - win.x + 1, data[4] - win.y + 1, data[2]) end)
|
||||
local h= win.h
|
||||
local w = win.w
|
||||
local x = win.x
|
||||
local y = win.y
|
||||
if win.isFullscreen then
|
||||
local sw,sh = term.getSize()
|
||||
w = sw
|
||||
h = sh-2
|
||||
x=1
|
||||
y=3
|
||||
end
|
||||
if y <= data[4] and x <= data[3] and y + h > data[4] and x + w > data[3] then
|
||||
threading.addThread(function() win.released(data[3] - x + 1, data[4] - y + 1, data[2]) end)
|
||||
bringtofront(indx)
|
||||
break
|
||||
end
|
||||
@@ -93,8 +130,19 @@ while true do
|
||||
elseif data[1] == "mouse_scroll" then
|
||||
for indx = #_G.windows, 1, -1 do
|
||||
local win = _G.windows[indx]
|
||||
if win.y <= data[4] and win.x <= data[3] and win.y + win.h > data[4] and win.x + win.w > data[3] then
|
||||
threading.addThread(function() win.scrolled(data[2], data[3] - win.x + 1, data[4] - win.y + 1) end)
|
||||
local h= win.h
|
||||
local w = win.w
|
||||
local x = win.x
|
||||
local y = win.y
|
||||
if win.isFullscreen then
|
||||
local sw,sh = term.getSize()
|
||||
w = sw
|
||||
h = sh-2
|
||||
x=1
|
||||
y=3
|
||||
end
|
||||
if y <= data[4] and x <= data[3] and y + h > data[4] and x + w > data[3] then
|
||||
threading.addThread(function() win.scrolled(data[2], data[3] - x + 1, data[4] - y + 1) end)
|
||||
break
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user