mirror of
https://github.com/Insality/druid
synced 2025-06-29 11:27:44 +02:00
Return grid binding
This commit is contained in:
parent
74efdbfe71
commit
e038d70039
@ -224,14 +224,6 @@ function DynamicGrid.get_size(self, border)
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
function DynamicGrid.get_size_for(self, count)
|
|
||||||
return vmath.vector3(
|
|
||||||
self.border.z - self.border.x,
|
|
||||||
self.border.y - self.border.w,
|
|
||||||
0)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--- Return grid content borders
|
--- Return grid content borders
|
||||||
-- @tparam DynamicGrid self
|
-- @tparam DynamicGrid self
|
||||||
-- @treturn vector3 The grid content borders
|
-- @treturn vector3 The grid content borders
|
||||||
|
@ -86,47 +86,22 @@ function M:_refresh()
|
|||||||
self:_remove_at(index)
|
self:_remove_at(index)
|
||||||
end
|
end
|
||||||
self:_check_elements()
|
self:_check_elements()
|
||||||
self:_recalc_scroll_size()
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
function M:_check_elements_old()
|
|
||||||
local pos = gui.get_position(self.scroll.content_node)
|
|
||||||
pos.y = -pos.y
|
|
||||||
|
|
||||||
local top_index = self.grid:get_index(pos) - self.grid.in_row
|
|
||||||
local last_index = (top_index - 1) + (self.elements_view_count.x * self.elements_view_count.y) + self.grid.in_row
|
|
||||||
|
|
||||||
-- Clear outside elements
|
|
||||||
for index, _ in pairs(self.nodes) do
|
|
||||||
if index < top_index or index > last_index then
|
|
||||||
self:_remove_at(index)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Spawn current elements
|
|
||||||
for index = top_index, last_index do
|
|
||||||
if self.data[index] and not self.nodes[index] then
|
|
||||||
self:_add_at(index)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
function M:_check_elements()
|
function M:_check_elements()
|
||||||
local top_index = self.top_index
|
|
||||||
self.last_index = self.top_index
|
self.last_index = self.top_index
|
||||||
|
|
||||||
for index, node in pairs(self.nodes) do
|
for index, node in pairs(self.nodes) do
|
||||||
if self.scroll:is_node_in_view(node) then
|
if self.scroll:is_node_in_view(node) then
|
||||||
top_index = index
|
self.top_index = index
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- make items from (top_index upside
|
-- make items from (top_index upside
|
||||||
local is_top_outside = false
|
local is_top_outside = false
|
||||||
local cur_index = top_index - 1
|
local cur_index = self.top_index - 1
|
||||||
while not is_top_outside do
|
while not is_top_outside do
|
||||||
if not self.data[cur_index] then
|
if not self.data[cur_index] then
|
||||||
break
|
break
|
||||||
@ -152,7 +127,7 @@ function M:_check_elements()
|
|||||||
|
|
||||||
-- make items from [top_index downsize
|
-- make items from [top_index downsize
|
||||||
local is_bot_outside = false
|
local is_bot_outside = false
|
||||||
cur_index = top_index
|
cur_index = self.top_index
|
||||||
while not is_bot_outside do
|
while not is_bot_outside do
|
||||||
if not self.data[cur_index] then
|
if not self.data[cur_index] then
|
||||||
break
|
break
|
||||||
@ -176,14 +151,6 @@ function M:_check_elements()
|
|||||||
|
|
||||||
cur_index = cur_index + 1
|
cur_index = cur_index + 1
|
||||||
end
|
end
|
||||||
|
|
||||||
self.top_index = top_index
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
function M:_recalc_scroll_size()
|
|
||||||
local element_size = self.grid:get_size_for(#self.data)
|
|
||||||
self.scroll:set_size(element_size)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user