core/menusystem: use a more logical naming scheme for variables in grids

This commit is contained in:
Kazhnuz 2019-02-13 18:25:41 +01:00
parent ce5b4ea20b
commit 8c53f69663

View file

@ -3,14 +3,14 @@ local Menu = require(cwd .. "parent")
local GridBox = Menu:extend()
function GridBox:new(menusystem, name, x, y, w, h, slots_hor, slots_vert)
self.slots = slots_hor * slots_vert
self.slots_hor = slots_hor
self.slots_vert = slots_vert
function GridBox:new(menusystem, name, x, y, w, h, colNumber, lineNumber)
self.view.slotNumber = colNumber * lineNumber
self.view.colNumber = colNumber
self.view.colNumber = lineNumber
GridBox.super.new(self, menusystem, name, x, y, w, h)
self.begin = 1
self.h = slots_vert * self.widget.h -- On fait en sorte que la hauteur
self.w = slots_hor * self.widget.w -- et la largeur
self.h = lineNumber * self.widget.h -- On fait en sorte que la hauteur
self.w = colNumber * self.widget.w -- et la largeur
-- soit un multiple du nombre de slot et de leur dimensions
self.cursor = {}
self.cursor.x = 0
@ -18,36 +18,36 @@ function GridBox:new(menusystem, name, x, y, w, h, slots_hor, slots_vert)
-- La gridbox possède la particularité de pouvoir fusioner des slots, on fait
-- donc une liste de slots disponibles, qui serviront par la suite.
self.listSlot = {}
for i= 1, self.slots do
self.listSlot[i] = {}
self.listSlot[i].sizeH = 1
self.listSlot[i].sizeW = 1
self.listSlot[i].isChild = 0
self.listSlot[i].widgetID = i
self.slots = {}
for i= 1, self.view.slotNumber do
self.slots[i] = {}
self.slots[i].height = 1
self.slots[i].width = 1
self.slots[i].isChild = 0
self.slots[i].widgetID = i
end
end
function GridBox:updateWidgetSize()
self.widget.h = math.floor( self.h / self.slots_vert )
self.widget.w = math.floor( self.w / self.slots_hor )
self.widget.h = math.floor( self.h / self.view.colNumber )
self.widget.w = math.floor( self.w / self.view.colNumber )
end
function GridBox:update(dt)
self.begin = 1
local slotID = self:getSlotbyCoord(self.cursor.x, self.cursor.y)
if self.listSlot[slotID].isChild > 0 then
slotID = self.listSlot[slotID].isChild
if self.slots[slotID].isChild > 0 then
slotID = self.slots[slotID].isChild
end
self.widget.selected = self.listSlot[slotID].widgetID
self.widget.selected = self.slots[slotID].widgetID
self.cursor.x, self.cursor.y = self:getCoord(slotID)
end
function GridBox:regenSlots()
local widgetID = 1
for i,v in ipairs(self.listSlot) do
for i,v in ipairs(self.slots) do
if v.isChild == 0 and (widgetID <= #self.widget.list) then
self.listSlot[i].widgetID = widgetID
self.slots[i].widgetID = widgetID
widgetID = widgetID + 1
end
end
@ -55,41 +55,41 @@ end
function GridBox:addCol(slotID)
local col, line = self:getCoord(slotID)
if (col + self.listSlot[slotID].sizeW + 1) <= self.slots_hor then
slotChild = slotID + self.listSlot[slotID].sizeW
for i = 1, self.listSlot[slotID].sizeH do
self.listSlot[slotChild + ((i-1)* self.slots_hor)].isChild = slotID
if (col + self.slots[slotID].width + 1) <= self.view.colNumber then
slotChild = slotID + self.slots[slotID].width
for i = 1, self.slots[slotID].height do
self.slots[slotChild + ((i-1)* self.view.colNumber)].isChild = slotID
end
self.listSlot[slotID].sizeW = self.listSlot[slotID].sizeW + 1
self.slots[slotID].width = self.slots[slotID].width + 1
end
end
function GridBox:addLine(slotID)
local col, line = self:getCoord(slotID)
if (line + self.listSlot[slotID].sizeH + 1) <= self.slots_vert then
slotChild = slotID + (self.listSlot[slotID].sizeH * self.slots_hor)
for i = 1, self.listSlot[slotID].sizeW do
self.listSlot[slotChild + (i-1)].isChild = slotID
if (line + self.slots[slotID].height + 1) <= self.view.colNumber then
slotChild = slotID + (self.slots[slotID].height * self.view.colNumber)
for i = 1, self.slots[slotID].width do
self.slots[slotChild + (i-1)].isChild = slotID
end
self.listSlot[slotID].sizeH = self.listSlot[slotID].sizeH + 1
self.slots[slotID].height = self.slots[slotID].height + 1
end
end
function GridBox:getCoord(id_selected)
id_selected = id_selected - 1 -- On simplifie les calcul en prenant 0 comme départ
local line, col
line = math.floor(id_selected / self.slots_hor)
col = id_selected - (line * self.slots_hor)
line = math.floor(id_selected / self.view.colNumber)
col = id_selected - (line * self.view.colNumber)
return col, line
end
function GridBox:getSlotbyCoord(col, line)
return (line * self.slots_hor) + col + 1
return (line * self.view.colNumber) + col + 1
end
function GridBox:getSlot(widgetID)
local slotID
for i,v in ipairs(self.listSlot) do
for i,v in ipairs(self.slots) do
if v.widgetID == widgetID then
return i
end
@ -103,25 +103,25 @@ function GridBox:moveCursor(newcol, newline)
self.cursor.x, self.cursor.y = newcol, newline
while self.cursor.y < 0 do
self.cursor.y = self.cursor.y + self.slots_vert
self.cursor.y = self.cursor.y + self.view.colNumber
end
while self.cursor.x < 0 do
self.cursor.x = self.cursor.x + self.slots_hor
self.cursor.x = self.cursor.x + self.view.colNumber
end
while self.cursor.y >= self.slots_vert do
self.cursor.y = self.cursor.y - self.slots_vert
while self.cursor.y >= self.view.colNumber do
self.cursor.y = self.cursor.y - self.view.colNumber
end
while self.cursor.x >= self.slots_hor do
self.cursor.x = self.cursor.x - self.slots_hor
while self.cursor.x >= self.view.colNumber do
self.cursor.x = self.cursor.x - self.view.colNumber
end
previousSlot = self:getSlotbyCoord(col, line)
newSlot = self:getSlotbyCoord(self.cursor.x, self.cursor.y)
if (self.listSlot[newSlot].isChild > 0) or (self.listSlot[newSlot].widgetID > #self.widget.list) then
if (self.listSlot[newSlot].isChild == previousSlot) or (self.listSlot[newSlot].widgetID > #self.widget.list) then
if (self.slots[newSlot].isChild > 0) or (self.slots[newSlot].widgetID > #self.widget.list) then
if (self.slots[newSlot].isChild == previousSlot) or (self.slots[newSlot].widgetID > #self.widget.list) then
self:moveCursor(self.cursor.x + relcol, self.cursor.y + relline)
end
end
@ -182,15 +182,15 @@ function GridBox:mousepressed(x, y, button, isTouch)
newline = beginline + math.floor(y / self.widget.h)
newcol = math.floor(x / self.widget.w)
newselect = (newline * self.slots_hor) + newcol + 1
newselect = (newline * self.view.colNumber) + newcol + 1
if self.listSlot[newselect].isChild > 0 then
slotID = self.listSlot[newselect].isChild
if self.slots[newselect].isChild > 0 then
slotID = self.slots[newselect].isChild
else
slotID = newselect
end
self.widget.selected = self.listSlot[slotID].widgetID
self.widget.selected = self.slots[slotID].widgetID
if #self.widget.list > 0 and self.widget.selected > 1 and self.widget.selected <= #self.widget.list then
self.widget.list[self.widget.selected]:action()
@ -202,7 +202,7 @@ function GridBox:draw()
local widgetx = self.x
self:regenSlots() -- On reget les slots au cas où :p
for i,v in ipairs(self.listSlot) do
for i,v in ipairs(self.slots) do
if (v.isChild == 0) and (v.widgetID <= #self.widget.list) then
--self.widget.list[v.widgetID]:draw(widgetx, widgety, self.widget.w * v.sizeW, self.widget.h * v.sizeH)
if self.widget.selected == v.widgetID and self:haveFocus() == true then