Add scrolling bar to TreeView
This commit is contained in:
parent
c3f5d2c144
commit
77d65fb3a1
|
@ -89,6 +89,7 @@ end
|
||||||
function TreeView:each_item()
|
function TreeView:each_item()
|
||||||
return coroutine.wrap(function()
|
return coroutine.wrap(function()
|
||||||
self:check_cache()
|
self:check_cache()
|
||||||
|
local count_lines = 0
|
||||||
local ox, oy = self:get_content_offset()
|
local ox, oy = self:get_content_offset()
|
||||||
local y = oy + style.padding.y
|
local y = oy + style.padding.y
|
||||||
local w = self.size.x
|
local w = self.size.x
|
||||||
|
@ -98,6 +99,7 @@ function TreeView:each_item()
|
||||||
local dir = core.project_directories[k]
|
local dir = core.project_directories[k]
|
||||||
local dir_cached = self:get_cached(dir.item, dir.name)
|
local dir_cached = self:get_cached(dir.item, dir.name)
|
||||||
coroutine.yield(dir_cached, ox, y, w, h)
|
coroutine.yield(dir_cached, ox, y, w, h)
|
||||||
|
count_lines = count_lines + 1
|
||||||
y = y + h
|
y = y + h
|
||||||
local i = 1
|
local i = 1
|
||||||
while i <= #dir.files and dir_cached.expanded do
|
while i <= #dir.files and dir_cached.expanded do
|
||||||
|
@ -105,6 +107,7 @@ function TreeView:each_item()
|
||||||
local cached = self:get_cached(item, dir.name)
|
local cached = self:get_cached(item, dir.name)
|
||||||
|
|
||||||
coroutine.yield(cached, ox, y, w, h)
|
coroutine.yield(cached, ox, y, w, h)
|
||||||
|
count_lines = count_lines + 1
|
||||||
y = y + h
|
y = y + h
|
||||||
i = i + 1
|
i = i + 1
|
||||||
|
|
||||||
|
@ -122,11 +125,14 @@ function TreeView:each_item()
|
||||||
end
|
end
|
||||||
end -- while files
|
end -- while files
|
||||||
end -- for directories
|
end -- for directories
|
||||||
|
self.count_lines = count_lines
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
function TreeView:on_mouse_moved(px, py)
|
function TreeView:on_mouse_moved(px, py, ...)
|
||||||
|
TreeView.super.on_mouse_moved(self, px, py, ...)
|
||||||
|
if self.dragging_scrollbar then return end
|
||||||
self.hovered_item = nil
|
self.hovered_item = nil
|
||||||
for item, x,y,w,h in self:each_item() do
|
for item, x,y,w,h in self:each_item() do
|
||||||
if px > x and py > y and px <= x + w and py <= y + h then
|
if px > x and py > y and px <= x + w and py <= y + h then
|
||||||
|
@ -152,7 +158,11 @@ local function create_directory_in(item)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
function TreeView:on_mouse_pressed(button, x, y)
|
function TreeView:on_mouse_pressed(button, x, y, clicks)
|
||||||
|
local caught = TreeView.super.on_mouse_pressed(self, button, x, y, clicks)
|
||||||
|
if caught then
|
||||||
|
return
|
||||||
|
end
|
||||||
if not self.hovered_item then
|
if not self.hovered_item then
|
||||||
return
|
return
|
||||||
elseif self.hovered_item.type == "dir" then
|
elseif self.hovered_item.type == "dir" then
|
||||||
|
@ -183,6 +193,11 @@ function TreeView:update()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function TreeView:get_scrollable_size()
|
||||||
|
return self.count_lines and self:get_item_height() * (self.count_lines + 1) or math.huge
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
function TreeView:draw()
|
function TreeView:draw()
|
||||||
self:draw_background(style.background2)
|
self:draw_background(style.background2)
|
||||||
|
|
||||||
|
@ -225,6 +240,8 @@ function TreeView:draw()
|
||||||
x = x + spacing
|
x = x + spacing
|
||||||
x = common.draw_text(style.font, color, item.name, nil, x, y, 0, h)
|
x = common.draw_text(style.font, color, item.name, nil, x, y, 0, h)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
self:draw_scrollbar()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue