Make GridFrame automatically adjust to SetWidth and SetHeight

This commit is contained in:
2025-01-06 21:26:52 +01:00
parent 4594dff4a6
commit d44aa04e44

View File

@@ -9,7 +9,7 @@ local addonname, shared = ...
---@field cellWidth number
---@field cellHeight number
---@field allowOverflow boolean
---@field columnCursors table<number, number>
---@field columnHeights table<number, number>
GridFrame = {
---@param name string
---@param parent Frame
@@ -26,7 +26,7 @@ GridFrame = {
if size.w then self.frame:SetWidth(size.w) end
if size.h then self.frame:SetHeight(size.h) end
self.allowOverflow = false
self.frame:SetPoint("CENTER", UIParent, "CENTER")
self.frame:SetPoint("CENTER", parent, "CENTER")
self.frame:SetBackdrop({
bgFile = "Interface/Tooltips/UI-Tooltip-Background",
tileSize = 64,
@@ -38,18 +38,10 @@ GridFrame = {
self.columns = columns
self.cellWidth = self.frame:GetWidth() / columns
self.cellHeight = cellHeight
self.columnCursors = {}
self.columnHeights = {}
for i = 1, columns do
self.columnCursors[i] = 0
self.columnHeights[i] = 0
end
local previousSetWidth = self.frame.SetWidth
self.frame.SetWidth = function(frame, width)
if not width then return end
previousSetWidth(frame, width)
self.cellWidth = self.frame:GetWidth() / self.columns
end
return self
end,
---@param self GridFrame
@@ -59,41 +51,71 @@ GridFrame = {
Add = function(self, frame, rowspan, colspan)
colspan = math.min(colspan, self.columns)
local bestStartColumn = nil
local bestMaxY = math.huge
local bestColumn = nil
local bestRow = math.huge
for startColumn = 1, self.columns - colspan + 1 do
local currentMaxY = 0
for c = startColumn, startColumn + colspan - 1 do
currentMaxY = math.max(currentMaxY, self.columnCursors[c])
currentMaxY = math.max(currentMaxY, self.columnHeights[c])
end
if currentMaxY < bestMaxY then
bestMaxY = currentMaxY
bestStartColumn = startColumn
if currentMaxY < bestRow then
bestRow = currentMaxY
bestColumn = startColumn
end
end
if not self.allowOverflow then
if bestMaxY + self.cellHeight * rowspan > self.frame:GetHeight() then
if bestRow + self.cellHeight * rowspan > self.frame:GetHeight() then
print("Frame is too tall")
return
end
end
if bestStartColumn then
local x = (bestStartColumn - 1) * self.cellWidth
local y = -bestMaxY
print("Adding frame to grid", x, y, self.cellWidth * colspan, self.cellHeight * rowspan)
frame:SetWidth(self.cellWidth * colspan)
frame:SetHeight(self.cellHeight * rowspan)
frame:SetPoint("TOPLEFT", self.frame, "TOPLEFT", x, y)
if bestColumn then
frame:SetParent(self.frame)
frame.gridData = {
row = bestRow,
column = bestColumn,
colspan = colspan,
rowspan = rowspan,
parent = self
}
frame.SetPos = function(self)
if not self.gridData then return end
local parent = self.gridData.parent
local x = (self.gridData.column - 1) * parent.cellWidth
local y = -(self.gridData.row * parent.cellHeight)
self:SetPoint("TOPLEFT", parent.frame, "TOPLEFT", x, y)
self:SetWidth(parent.cellWidth * self.gridData.colspan)
self:SetHeight(parent.cellHeight * self.gridData.rowspan)
end
frame.SetPos(frame)
for c = bestStartColumn, bestStartColumn + colspan - 1 do
self.columnCursors[c] = self.columnCursors[c] + self.cellHeight * rowspan
for c = bestColumn, bestColumn + colspan - 1 do
self.columnHeights[c] = self.columnHeights[c] + rowspan
end
else
print("No available space in the grid.")
end
end,
Recalculate = function(self)
local children = { self.frame:GetChildren() }
for _, child in pairs(children) do child:SetPos() end
end,
SetWidth = function(self, width)
self.frame:SetWidth(width)
self.cellWidth = width / self.columns
self:Recalculate()
end,
SetHeight = function(self, height)
self.frame:SetHeight(height)
local tallestRow = 0
for _, height in pairs(self.columnHeights) do
tallestRow = math.max(tallestRow, height)
end
self.cellHeight = height / tallestRow
self:Recalculate()
end
}
@@ -165,6 +187,8 @@ StaticGridFrame = {
if canPlace then
local x = (col - 1) * self.cellWidth
local y = -(row - 1) * self.cellHeight
frame.colspan = colspan
frame.rowspan = rowspan
frame:SetWidth(self.cellWidth * colspan)
frame:SetHeight(self.cellHeight * rowspan)
frame:SetPoint("TOPLEFT", self.frame, "TOPLEFT", x, y)
@@ -191,7 +215,30 @@ StaticGridFrame = {
self.frame:SetScript("OnDragStop", function(self)
self:StopMovingOrSizing()
end)
end,
Recalculate = function(self)
for _, frame in pairs(self.frame:GetChildren()) do
if frame.colspan then
frame:SetWidth(self.cellWidth * frame.colspan)
end
if frame.rowspan then
frame:SetHeight(self.cellHeight * frame.rowspan)
end
end
end,
SetWidth = function(self, width)
self.frame:SetWidth(width)
self.cellWidth = self.frame:GetWidth() / self.columns
self:Recalculate()
end,
SetHeight = function(self, height)
self.frame:SetHeight(height)
print("Setting height", height)
self.cellHeight = self.frame:GetHeight() / self.rows
print("Cell height", self.cellHeight)
self:Recalculate()
end
}
local configFrame = StaticGridFrame.new("HeimdallConfig",
@@ -199,13 +246,13 @@ local configFrame = StaticGridFrame.new("HeimdallConfig",
40, 12,
{ w = 1024 + 512, h = 1024 })
configFrame:MakeMovable()
configFrame.frame:SetScript("OnKeyUp", function(self, key)
if key == "ESCAPE" then
self:Hide()
end
end)
--configFrame.frame:SetScript("OnKeyUp", function(self, key)
-- if key == "ESCAPE" then
-- self:Hide()
-- end
--end)
local colors = {
local colors = {
{ 1, 0, 0, 1 },
{ 0, 1, 0, 1 },
{ 0, 0, 1, 1 },
@@ -214,17 +261,20 @@ local colors = {
{ 0, 1, 1, 1 },
{ 1, 1, 1, 1 },
}
--for i = 1, 200 do
-- local frame = CreateFrame("Frame", "HeimdallConfigFrame" .. i, UIParent)
-- frame:SetBackdrop({
-- bgFile = "Interface/Tooltips/UI-Tooltip-Background",
-- tileSize = 64,
-- tile = true
-- })
-- frame:SetBackdropColor(unpack(colors[i % #colors + 1]))
-- frame:SetBackdropBorderColor(0.5, 0.5, 0.5, 1)
-- configFrame:Add(frame, 4, 2)
--end
HeimdallTestFrame = GridFrame.new("HeimdallPartyFrame", UIParent, 12, 20, { w = 1024, h = 1024 })
for i = 1, 10 do
local frame = CreateFrame("Frame", "HeimdallPartyFrame" .. i, UIParent)
frame:SetBackdrop({
bgFile = "Interface/Tooltips/UI-Tooltip-Background",
tileSize = 64,
tile = true
})
frame:SetBackdropColor(unpack(colors[i % #colors + 1]))
frame:SetBackdropBorderColor(0.5, 0.5, 0.5, 1)
HeimdallTestFrame:Add(frame, 4, 2)
end
HeimdallTestFrame:SetHeight(128)
HeimdallTestFrame:SetWidth(512)
---@diagnostic disable-next-line: missing-fields
shared.Config = {}
function shared.Config.Init()
@@ -263,59 +313,47 @@ function shared.Config.Init()
spotterEnableButtonLabel:SetAllPoints(button)
return button
end
-----@param name string
-----@param parent Frame
-----@param text string
-----@param onDone fun(text: string)
--local function CreateBasicSmallEditBox(name, parent, text, onDone)
-- local editBox = CreateFrame("EditBox", name, parent)
-- editBox.text = editBox:CreateFontString(nil, "OVERLAY", "GameFontNormal")
-- editBox.text:SetText(text)
-- editBox.text:SetPoint("TOPLEFT", editBox, "TOPLEFT", 0, 8 + 4)
-- editBox:SetNumeric(true)
-- editBox:SetSize(128 - 8, 24)
-- editBox:SetAutoFocus(false)
-- editBox:SetFontObject("GameFontNormal")
-- editBox:SetText(Heimdall_Data.config.spotter.throttleTime)
-- editBox:SetBackdrop({
-- bgFile = "Interface/Tooltips/UI-Tooltip-Background",
-- edgeFile = "Interface/Tooltips/UI-Tooltip-Border",
-- tile = true,
-- tileSize = 2,
-- edgeSize = 2,
-- insets = {
-- left = 2,
-- right = 2,
-- top = 2,
-- bottom = 2
-- }
-- })
-- editBox:SetBackdropColor(0.8, 0.8, 0.8, 1)
-- editBox:SetBackdropBorderColor(0.5, 0.5, 0.5, 1)
-- editBox:SetScript("OnEnterPressed", function()
-- onDone(editBox:GetText())
-- end)
-- editBox:SetScript("OnEscapePressed", function()
-- editBox:ClearFocus()
-- end)
-- editBox:SetScript("OnEditFocusLost", function()
-- onDone(editBox:GetText())
-- end)
---@param name string
---@param parent Frame
---@param text string
---@param onDone fun(text: string)
local function CreateBasicSmallEditBox(name, parent, text, onDone)
local container = GridFrame.new(name, parent, 1, 1)
local editBox = CreateFrame("EditBox", name .. "EditBox", container.frame)
local editBoxtext = editBox:CreateFontString(nil, "OVERLAY", "GameFontNormal")
editBoxtext:SetText(text)
editBoxtext:SetPoint("TOPLEFT", container.frame, "TOPLEFT", 0, 0)
-- editBox.PutBelow = function(a, b, offset)
-- offset = offset or {}
-- offset.x = (offset.x or 0) + 0
-- offset.y = (offset.y or 0) - 12
-- PutBelow(a, b, offset)
-- end
-- editBox.PutRight = function(a, b, offset)
-- offset = offset or {}
-- offset.x = (offset.x or 0) + 0
-- offset.y = (offset.y or 0) - 8
-- PutRight(a, b, offset)
-- end
-- return editBox
-- end
editBox:SetPoint("TOPLEFT", container.frame, "TOPLEFT", 0, -8)
editBox:SetAutoFocus(false)
editBox:SetFontObject("GameFontNormal")
editBox:SetText(Heimdall_Data.config.spotter.throttleTime)
editBox:SetBackdrop({
bgFile = "Interface/Tooltips/UI-Tooltip-Background",
edgeFile = "Interface/Tooltips/UI-Tooltip-Border",
tile = true,
tileSize = 2,
edgeSize = 2,
insets = {
left = 2,
right = 2,
top = 2,
bottom = 2
}
})
editBox:SetBackdropColor(0.8, 0.8, 0.8, 1)
editBox:SetBackdropBorderColor(0.5, 0.5, 0.5, 1)
editBox:SetScript("OnEnterPressed", function()
onDone(editBox:GetText())
end)
editBox:SetScript("OnEscapePressed", function()
editBox:ClearFocus()
end)
editBox:SetScript("OnEditFocusLost", function()
onDone(editBox:GetText())
end)
return container
end
--
local title = configFrame.frame:CreateFontString(nil, "ARTWORK", "GameFontNormal")
@@ -325,6 +363,9 @@ function shared.Config.Init()
local spotterConfigFrame = GridFrame.new("HeimdallSpotterConfig",
configFrame.frame, 12, 20)
configFrame:Add(spotterConfigFrame.frame, 6, 3)
local spotterTitle = spotterConfigFrame.frame:CreateFontString(nil, "ARTWORK", "GameFontNormal")
spotterTitle:SetText("Spotter")
spotterConfigFrame:Add(spotterTitle, 1, 12)
local spotterEnableButton = BasicButton("HeimdallSpotterConfigEnableButton",
spotterConfigFrame.frame, "Enable Spotter", function()
@@ -333,6 +374,14 @@ function shared.Config.Init()
end)
spotterConfigFrame:Add(spotterEnableButton, 1, 3)
configFrame.frame:Hide()
-- local testEditBox = CreateBasicSmallEditBox("HeimdallSpotterConfigTestEditBox",
-- UIParent, "Test", function(text)
-- print(text)
-- end)
-- testEditBox:SetHeight(200)
-- spotterConfigFrame:Add(testEditBox.frame, 2, 6)
--local spotterEveryoneButton = BasicButton("HeimdallSpotterEveryone", spotterConfigFrame, "Everyone", function(state)
-- Heimdall_Data.config.spotter.everyone = state
--end)