From 12049adf27177ab173c0acc902ed5f6a9d8feda3 Mon Sep 17 00:00:00 2001 From: Insality Date: Thu, 26 Sep 2019 08:53:47 +0300 Subject: [PATCH 1/3] #24 cherry-pick, add simple blocker component --- druid/base/blocker.lua | 33 +++++++++++++++++++++++++++++++++ druid/druid.lua | 1 + 2 files changed, 34 insertions(+) create mode 100644 druid/base/blocker.lua diff --git a/druid/base/blocker.lua b/druid/base/blocker.lua new file mode 100644 index 0000000..14f3fc2 --- /dev/null +++ b/druid/base/blocker.lua @@ -0,0 +1,33 @@ +--- Component to block input on specify zone (node) +-- @module base.blocker + +local const = require("druid.const") +local helper = require("druid.helper") + + +local M = {} +M.interest = { + const.ON_SWIPE +} + + +function M.init(self, node) + self.node = helper.get_node(node) + self.event = const.ACTION_TOUCH +end + + +function M.on_input(self, action_id, action) + if not helper.is_enabled(self.node) then + return false + end + + if gui.pick_node(self.node, action.x, action.y) then + return true + end + + return false +end + + +return M diff --git a/druid/druid.lua b/druid/druid.lua index ad3618c..1b3b50c 100644 --- a/druid/druid.lua +++ b/druid/druid.lua @@ -9,6 +9,7 @@ local _fct_metatable = {} M.comps = { button = require("druid.base.button"), + blocker = require("druid.base.blocker"), android_back = require("druid.base.android_back"), text = require("druid.base.text"), timer = require("druid.base.timer"), From dc3d311236ef5197b531c4ed366bb38106e75fa2 Mon Sep 17 00:00:00 2001 From: Insality Date: Thu, 26 Sep 2019 00:27:27 +0300 Subject: [PATCH 2/3] #25 cherry-pick slider component --- druid/base/slider.lua | 82 +++++++++++++++++++++++++++++++++++++++++++ druid/druid.lua | 1 + 2 files changed, 83 insertions(+) create mode 100644 druid/base/slider.lua diff --git a/druid/base/slider.lua b/druid/base/slider.lua new file mode 100644 index 0000000..0caa56f --- /dev/null +++ b/druid/base/slider.lua @@ -0,0 +1,82 @@ +--- Druid slider component +-- @module base.slider + +local helper = require("druid.helper") +local const = require("druid.const") + +local M = {} +M.interest = { + const.ON_SWIPE +} + + +local function on_change_value(self) + if self.callback then + self.callback(self.parent.parent, self.value) + end +end + + +function M.init(self, node, end_pos, callback) + self.node = helper.get_node(node) + + self.start_pos = gui.get_position(self.node) + self.pos = gui.get_position(self.node) + self.target_pos = self.pos + self.end_pos = end_pos + + self.dist = self.end_pos - self.start_pos + self.is_drag = false + self.value = 0 + self.callback = callback + + assert(self.dist.x == 0 or self.dist.y == 0, "Slider for now can be only vertical or horizontal") +end + + +function M.on_input(self, action_id, action) + if action_id ~= const.ACTION_TOUCH then + return false + end + + if gui.pick_node(self.node, action.x, action.y) then + if action.pressed then + self.pos = gui.get_position(self.node) + self.is_drag = true + end + end + + if self.is_drag and not action.pressed then + -- move + self.pos.x = self.pos.x + action.dx + self.pos.y = self.pos.y + action.dy + + local prev_x = self.target_pos.x + local prev_y = self.target_pos.y + + self.target_pos.x = helper.clamp(self.pos.x, self.start_pos.x, self.end_pos.x) + self.target_pos.y = helper.clamp(self.pos.y, self.start_pos.y, self.end_pos.y) + + gui.set_position(self.node, self.target_pos) + + if prev_x ~= self.target_pos.x or prev_y ~= self.target_pos.y then + + if self.dist.x > 0 then + self.value = (self.target_pos.x - self.start_pos.x) / self.dist.x + end + + if self.dist.y > 0 then + self.value = (self.target_pos.y - self.start_pos.y) / self.dist.y + end + + on_change_value(self) + end + end + + if action.released then + self.is_drag = false + end +end + + +return M diff --git a/druid/druid.lua b/druid/druid.lua index ad3618c..c8a744a 100644 --- a/druid/druid.lua +++ b/druid/druid.lua @@ -15,6 +15,7 @@ M.comps = { progress = require("druid.base.progress"), grid = require("druid.base.grid"), scroll = require("druid.base.scroll"), + slider = require("druid.base.slider"), progress_rich = require("druid.rich.progress_rich"), } From 2abfe8b0d4bb86a33935fdcd280d4ff7f102b137 Mon Sep 17 00:00:00 2001 From: Insality Date: Thu, 26 Sep 2019 00:52:29 +0300 Subject: [PATCH 3/3] #25 cherry-pick, update slider component --- druid/base/slider.lua | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/druid/base/slider.lua b/druid/base/slider.lua index 0caa56f..ff2881f 100644 --- a/druid/base/slider.lua +++ b/druid/base/slider.lua @@ -76,6 +76,17 @@ function M.on_input(self, action_id, action) if action.released then self.is_drag = false end + + return self.is_drag +end + + +function M.set(self, value) + value = helper.clamp(value, 0, 1) + + gui.set_position(self.node, self.start_pos + self.dist * value) + self.value = value + on_change_value(self) end