From 075903f9a95a26ce430cdd34b70554351fa5e6eb Mon Sep 17 00:00:00 2001 From: Robert Jelic <36573031+NoryiE@users.noreply.github.com> Date: Sat, 29 Apr 2023 23:14:19 +0200 Subject: [PATCH] Small 1.6 fixes - added basalt.forceRenderUpdate - fixed dropdowns behaving wrong on monitors --- Basalt/Frame.lua | 6 +++--- Basalt/main.lua | 4 ++++ Basalt/objects/Dropdown.lua | 5 ++++- 3 files changed, 11 insertions(+), 4 deletions(-) diff --git a/Basalt/Frame.lua b/Basalt/Frame.lua index a8dc6de..6a71859 100644 --- a/Basalt/Frame.lua +++ b/Basalt/Frame.lua @@ -885,20 +885,20 @@ return function(name, parent, pTerm, basalt) end end, - mouseHandler = function(self, button, x, y, _, side) + mouseHandler = function(self, button, x, y, touch, side) if(isGroupedMonitor)then if(termObject.calculateClick~=nil)then x, y = termObject.calculateClick(side, x, y) end end - if(base.mouseHandler(self, button, x, y))then + if(base.mouseHandler(self, button, x, y, touch))then if(events["mouse_click"]~=nil)then self:setCursor(false) for _, index in ipairs(eventZIndex["mouse_click"]) do if (events["mouse_click"][index] ~= nil) then for _, value in rpairs(events["mouse_click"][index]) do if (value.mouseHandler ~= nil) then - if (value:mouseHandler(button, x, y)) then + if (value:mouseHandler(button, x, y, touch)) then return true end diff --git a/Basalt/main.lua b/Basalt/main.lua index 120222d..284000e 100644 --- a/Basalt/main.lua +++ b/Basalt/main.lua @@ -436,6 +436,10 @@ basalt = { projectDirectory = dir end, + forceRenderUpdate = function() + drawFrames() + end, + debug = function(...) local args = { ... } if(mainFrame==nil)then print(...) return end diff --git a/Basalt/objects/Dropdown.lua b/Basalt/objects/Dropdown.lua index 2dbf66e..4a66928 100644 --- a/Basalt/objects/Dropdown.lua +++ b/Basalt/objects/Dropdown.lua @@ -124,7 +124,7 @@ return function(name) return dropdownW, dropdownH end, - mouseHandler = function(self, button, x, y) + mouseHandler = function(self, button, x, y, touch) if (isOpened) then local obx, oby = self:getAbsolutePosition(self:getAnchorPosition()) if(button==1)then @@ -135,6 +135,9 @@ return function(name) self:setValue(list[n + yOffset]) self:updateDraw() local val = self:getEventSystem():sendEvent("mouse_click", self, "mouse_click", dir, x, y) + if(touch)then + self:mouseUpHandler(button, x, y) + end if(val==false)then return val end return true end