Add scroll:bind_grid function

This commit is contained in:
Insality 2020-09-28 01:56:43 +03:00
parent c0bd3e599b
commit 0b1051b5b2
5 changed files with 67 additions and 28 deletions

View File

@ -245,17 +245,21 @@ end
-- update poses on grid elements. Default: gui.set_position -- update poses on grid elements. Default: gui.set_position
-- @function dynamic_grid:set_position_function -- @function dynamic_grid:set_position_function
-- @tparam function callback Function on node set position -- @tparam function callback Function on node set position
-- @treturn druid.dynamic_grid Current grid instance
function DynamicGrid:set_position_function(callback) function DynamicGrid:set_position_function(callback)
self._set_position_function = callback or gui.set_position self._set_position_function = callback or gui.set_position
return self
end end
--- Clear grid nodes array. GUI nodes will be not deleted! --- Clear grid nodes array. GUI nodes will be not deleted!
-- If you want to delete GUI nodes, use dynamic_grid.nodes array before grid:clear -- If you want to delete GUI nodes, use dynamic_grid.nodes array before grid:clear
-- @function dynamic_grid:clear -- @function dynamic_grid:clear
-- @treturn druid.dynamic_grid Current grid instance
function DynamicGrid:clear() function DynamicGrid:clear()
self.nodes = {} self.nodes = {}
self:_update() self:_update()
return self
end end

View File

@ -118,8 +118,11 @@ function Scroll:init(view_node, content_node)
self.selected = nil self.selected = nil
self.is_animate = false self.is_animate = false
self._is_horizontal_scroll = true self._is_horizontal_scroll = true
self._is_vertical_scroll = true self._is_vertical_scroll = true
self._grid_on_change = nil
self._grid_on_change_callback = nil
self:_update_size() self:_update_size()
end end
@ -139,6 +142,11 @@ function Scroll:update(dt)
end end
function Scroll:on_remove()
self:bind_grid(nil)
end
--- Start scroll to target point. --- Start scroll to target point.
-- @function scroll:scroll_to -- @function scroll:scroll_to
-- @tparam point vector3 Target point -- @tparam point vector3 Target point
@ -318,6 +326,28 @@ function Scroll:set_vertical_scroll(state)
end end
function Scroll:bind_grid(grid)
if self._grid_on_change then
self._grid_on_change:unsubscribe(self._grid_on_change_callback)
self._grid_on_change = nil
self._grid_on_change_callback = nil
end
if not grid then
return
end
self._grid_on_change = grid.on_change_items
self._grid_on_change_callback = self._grid_on_change:subscribe(function()
self:set_size(grid:get_size())
end)
return self
end
function Scroll:_on_scroll_drag(dx, dy) function Scroll:_on_scroll_drag(dx, dy)
local t = self.target_position local t = self.target_position
local b = self.available_pos local b = self.available_pos

View File

@ -218,14 +218,18 @@ end
-- update poses on grid elements. Default: gui.set_position -- update poses on grid elements. Default: gui.set_position
-- @function static_grid:set_position_function -- @function static_grid:set_position_function
-- @tparam function callback Function on node set position -- @tparam function callback Function on node set position
-- @treturn druid.static_grid Current grid instance
function StaticGrid:set_position_function(callback) function StaticGrid:set_position_function(callback)
self._set_position_function = callback or gui.set_position self._set_position_function = callback or gui.set_position
return self
end end
--- Clear grid nodes array. GUI nodes will be not deleted! --- Clear grid nodes array. GUI nodes will be not deleted!
-- If you want to delete GUI nodes, use static_grid.nodes array before grid:clear -- If you want to delete GUI nodes, use static_grid.nodes array before grid:clear
-- @function static_grid:clear -- @function static_grid:clear
-- @treturn druid.static_grid Current grid instance
function StaticGrid:clear() function StaticGrid:clear()
self.border.x = 0 self.border.x = 0
self.border.y = 0 self.border.y = 0
@ -234,6 +238,8 @@ function StaticGrid:clear()
self.nodes = {} self.nodes = {}
self:_update() self:_update()
return self
end end

View File

@ -27,6 +27,8 @@ function M.subscribe(self, callback)
assert(type(callback) == "function", "Callback should be function") assert(type(callback) == "function", "Callback should be function")
table.insert(self._callbacks, callback) table.insert(self._callbacks, callback)
return callback
end end

View File

@ -3,16 +3,20 @@ local druid_const = require("druid.const")
local M = {} local M = {}
local function simple_animate(node, pos)
gui.animate(node, "position", pos, gui.EASING_OUTSINE, 0.2)
end
local function remove_node(self, button, is_shift) local function remove_node(self, button, is_shift)
gui.delete_node(button.node) gui.delete_node(button.node)
self.druid:remove(button) self.druid:remove(button)
local index = self.grid_nodes:get_index_by_node(button.node) local index = self.grid_static_grid:get_index_by_node(button.node)
self.grid_nodes:remove(index, is_shift) self.grid_static_grid:remove(index, is_shift)
for i = 1, #self.grid_node_buttons do for i = 1, #self.grid_node_buttons do
if self.grid_node_buttons[i] == button then if self.grid_node_buttons[i] == button then
table.remove(self.grid_node_buttons, i) table.remove(self.grid_node_buttons, i)
self.grid_static_scroll:set_size(self.grid_nodes:get_size())
break break
end end
end end
@ -34,9 +38,7 @@ local function add_node(self, index)
table.insert(self.grid_node_buttons, button) table.insert(self.grid_node_buttons, button)
self.grid_nodes:add(cloned["grid_nodes_prefab"], index) self.grid_static_grid:add(cloned["grid_nodes_prefab"], index)
self.grid_static_scroll:set_size(self.grid_nodes:get_size())
end end
@ -51,15 +53,11 @@ local function clear_nodes(self)
end end
self.grid_node_buttons = {} self.grid_node_buttons = {}
self.grid_nodes:clear() self.grid_static_grid:clear()
end end
local function init_static_grid(self) local function init_static_grid(self)
self.grid_nodes = self.druid:new_static_grid("grid_nodes", "grid_nodes_prefab", 5)
self.grid_nodes:set_position_function(function(node, pos)
gui.animate(node, "position", pos, gui.EASING_OUTSINE, 0.2)
end)
self.grid_node_buttons = {} self.grid_node_buttons = {}
gui.set_enabled(gui.get_node("grid_nodes_prefab"), false) gui.set_enabled(gui.get_node("grid_nodes_prefab"), false)
@ -81,12 +79,11 @@ local function remove_dynamic_node(self, button)
gui.delete_node(button.node) gui.delete_node(button.node)
self.druid:remove(button) self.druid:remove(button)
local index = self.dynamic_grid:get_index_by_node(button.node) local index = self.grid_dynamic_grid:get_index_by_node(button.node)
self.dynamic_grid:remove(index) self.grid_dynamic_grid:remove(index)
for i = 1, #self.dynamic_node_buttons do for i = 1, #self.dynamic_node_buttons do
if self.dynamic_node_buttons[i] == button then if self.dynamic_node_buttons[i] == button then
table.remove(self.dynamic_node_buttons, i) table.remove(self.dynamic_node_buttons, i)
self.grid_dynamic_scroll:set_size(self.dynamic_grid:get_size())
break break
end end
end end
@ -97,13 +94,12 @@ local function add_node_dynamic(self, index, is_shift_left)
local node = gui.clone(self.prefab_dynamic) local node = gui.clone(self.prefab_dynamic)
gui.set_enabled(node, true) gui.set_enabled(node, true)
gui.set_size(node, vmath.vector3(250, math.random(60, 150), 0)) gui.set_size(node, vmath.vector3(250, math.random(60, 150), 0))
self.dynamic_grid:add(node, index, is_shift_left) self.grid_dynamic_grid:add(node, index, is_shift_left)
local button = self.druid:new_button(node, function(_, params, button) local button = self.druid:new_button(node, function(_, params, button)
remove_dynamic_node(self, button) remove_dynamic_node(self, button)
end) end)
button:set_click_zone(self.grid_dynamic_scroll.view_node) button:set_click_zone(self.grid_dynamic_scroll.view_node)
self.grid_dynamic_scroll:set_size(self.dynamic_grid:get_size())
table.insert(self.dynamic_node_buttons, button) table.insert(self.dynamic_node_buttons, button)
end end
@ -112,18 +108,13 @@ local function add_node_dynamic_hor(self, index)
local node = gui.clone(self.prefab_hor_dynamic) local node = gui.clone(self.prefab_hor_dynamic)
gui.set_enabled(node, true) gui.set_enabled(node, true)
gui.set_size(node, vmath.vector3(80 + math.random(0, 80), 80, 0)) gui.set_size(node, vmath.vector3(80 + math.random(0, 80), 80, 0))
self.dynamic_hor_grid:add(node, index) self.grid_dynamic_hor_grid:add(node, index)
self.grid_dynamic_hor_scroll:set_size(self.dynamic_hor_grid:get_size())
end end
local function init_dynamic_grid(self) local function init_dynamic_grid(self)
-- Vertical horizontal grid -- Vertical horizontal grid
self.dynamic_node_buttons = {} self.dynamic_node_buttons = {}
self.dynamic_grid = self.druid:new_dynamic_grid("grid_dynamic_nodes")
self.dynamic_grid:set_position_function(function(node, pos)
gui.animate(node, gui.PROP_POSITION, pos, gui.EASING_OUTSINE, 0.2)
end)
self.prefab_dynamic = gui.get_node("grid_dynamic_prefab") self.prefab_dynamic = gui.get_node("grid_dynamic_prefab")
gui.set_enabled(self.prefab_dynamic, false) gui.set_enabled(self.prefab_dynamic, false)
@ -132,19 +123,14 @@ local function init_dynamic_grid(self)
add_node_dynamic(self, i) add_node_dynamic(self, i)
end end
self.druid:new_button("button_add_start_dynamic/button", function() self.druid:new_button("button_add_start_dynamic/button", function()
local start_index = (self.dynamic_grid.first_index or 2) - 1 local start_index = (self.grid_dynamic_grid.first_index or 2) - 1
add_node_dynamic(self, start_index) add_node_dynamic(self, start_index)
end) end)
self.druid:new_button("button_add_end_dynamic/button", function() self.druid:new_button("button_add_end_dynamic/button", function()
add_node_dynamic(self) add_node_dynamic(self)
end) end)
-- Horizontal dynamic grid -- Horizontal dynamic grid
self.dynamic_hor_grid = self.druid:new_dynamic_grid("grid_dynamic_hor_nodes")
self.dynamic_hor_grid:set_position_function(function(node, pos)
gui.animate(node, gui.PROP_POSITION, pos, gui.EASING_OUTSINE, 0.2)
end)
self.prefab_hor_dynamic = gui.get_node("grid_dynamic_hor_prefab") self.prefab_hor_dynamic = gui.get_node("grid_dynamic_hor_prefab")
gui.set_enabled(self.prefab_hor_dynamic, false) gui.set_enabled(self.prefab_hor_dynamic, false)
@ -164,12 +150,23 @@ end
function M.setup_page(self) function M.setup_page(self)
self.grid_page_scroll = self.druid:new_scroll("grid_page", "grid_page_content") self.grid_page_scroll = self.druid:new_scroll("grid_page", "grid_page_content")
self.grid_static_grid = self.druid:new_static_grid("grid_nodes", "grid_nodes_prefab", 5)
:set_position_function(simple_animate)
self.grid_static_scroll = self.druid:new_scroll("grid_nodes_view", "grid_nodes") self.grid_static_scroll = self.druid:new_scroll("grid_nodes_view", "grid_nodes")
:set_horizontal_scroll(false) :set_horizontal_scroll(false)
:bind_grid(self.grid_static_grid)
self.grid_dynamic_grid = self.druid:new_dynamic_grid("grid_dynamic_nodes")
:set_position_function(simple_animate)
self.grid_dynamic_scroll = self.druid:new_scroll("grid_dynamic_view", "grid_dynamic_nodes") self.grid_dynamic_scroll = self.druid:new_scroll("grid_dynamic_view", "grid_dynamic_nodes")
:set_horizontal_scroll(false) :set_horizontal_scroll(false)
:bind_grid(self.grid_dynamic_grid)
self.grid_dynamic_hor_grid = self.druid:new_dynamic_grid("grid_dynamic_hor_nodes")
:set_position_function(simple_animate)
self.grid_dynamic_hor_scroll = self.druid:new_scroll("grid_dynamic_hor_view", "grid_dynamic_hor_nodes") self.grid_dynamic_hor_scroll = self.druid:new_scroll("grid_dynamic_hor_view", "grid_dynamic_hor_nodes")
:set_vertical_scroll(false) :set_vertical_scroll(false)
:bind_grid(self.grid_dynamic_hor_grid)
init_static_grid(self) init_static_grid(self)
init_dynamic_grid(self) init_dynamic_grid(self)