mirror of
https://github.com/koreader/koreader.git
synced 2025-08-10 00:52:38 +00:00
@@ -92,6 +92,10 @@ function Document:getPageDimensions(pageno, zoom, rotation)
|
||||
return native_dimen
|
||||
end
|
||||
|
||||
function Document:getToc()
|
||||
return self._document:getToc()
|
||||
end
|
||||
|
||||
-- load implementations:
|
||||
|
||||
require "document/pdfdocument"
|
||||
|
||||
@@ -416,9 +416,8 @@ Menu = FocusManager:new{
|
||||
|
||||
item_height = 36,
|
||||
page = 1,
|
||||
current = 1,
|
||||
oldcurrent = 0,
|
||||
selected_item = nil,
|
||||
|
||||
on_select_callback = function() end,
|
||||
}
|
||||
|
||||
function Menu:init()
|
||||
@@ -440,9 +439,9 @@ function Menu:init()
|
||||
if self.is_enable_shortcut then
|
||||
self.key_events.SelectByShortCut = { {self.item_shortcuts} }
|
||||
end
|
||||
self.key_events.Select = { {"Press"}, doc = "select current menu item"}
|
||||
|
||||
self[1] = CenterContainer:new{
|
||||
dimen = {w = G_width, h = G_height},
|
||||
FrameContainer:new{
|
||||
background = 0,
|
||||
radius = math.floor(self.width/20),
|
||||
@@ -460,6 +459,7 @@ function Menu:init()
|
||||
},
|
||||
}, -- VerticalGroup
|
||||
}, -- FrameContainer
|
||||
dimen = {w = G_width, h = G_height},
|
||||
} -- CenterContainer
|
||||
|
||||
self:_updateItems()
|
||||
@@ -467,7 +467,10 @@ end
|
||||
|
||||
function Menu:_updateItems()
|
||||
self.layout = {}
|
||||
self[1][1][1][2] = VerticalGroup:new{}
|
||||
self[1]
|
||||
[1] -- FrameContainer
|
||||
[1] -- VerticalGroup
|
||||
[2] = VerticalGroup:new{}
|
||||
local item_group = self[1][1][1][2]
|
||||
|
||||
for c = 1, self.perpage do
|
||||
@@ -506,15 +509,17 @@ end
|
||||
|
||||
function Menu:onSelectByShortCut(_, keyevent)
|
||||
for k,v in ipairs(self.item_shortcuts) do
|
||||
if v == keyevent.key then
|
||||
local item = self.item_table[k]
|
||||
if k > self.perpage then
|
||||
break
|
||||
elseif v == keyevent.key then
|
||||
local item = self.item_table[(self.page-1)*self.perpage+k]
|
||||
self.item_table = nil
|
||||
UIManager:close(self)
|
||||
debug(item)
|
||||
-- send events
|
||||
self.on_select_callback(item)
|
||||
break
|
||||
end
|
||||
end
|
||||
return true
|
||||
end
|
||||
|
||||
function Menu:onNextPage()
|
||||
@@ -523,10 +528,7 @@ function Menu:onNextPage()
|
||||
self.page = self.page + 1
|
||||
self:_updateItems()
|
||||
self.selected = { x = 1, y = 1 }
|
||||
self[1][1][1][3] = TextWidget:new{
|
||||
text = "page "..self.page.."/"..self.page_num,
|
||||
face = self.fface,
|
||||
},
|
||||
self[1][1][1][3].text = "page "..self.page.."/"..self.page_num
|
||||
UIManager:setDirty(self)
|
||||
end
|
||||
return true
|
||||
@@ -538,10 +540,7 @@ function Menu:onPrevPage()
|
||||
self.page = self.page - 1
|
||||
self:_updateItems()
|
||||
self.selected = { x = 1, y = 1 }
|
||||
self[1][1][1][3] = TextWidget:new{
|
||||
text = "page "..self.page.."/"..self.page_num,
|
||||
face = self.fface,
|
||||
},
|
||||
self[1][1][1][3].text = "page "..self.page.."/"..self.page_num
|
||||
UIManager:setDirty(self)
|
||||
end
|
||||
return true
|
||||
@@ -553,6 +552,12 @@ function Menu:onShowItemDetail()
|
||||
)
|
||||
end
|
||||
|
||||
function Menu:onSelect()
|
||||
UIManager:close(self)
|
||||
self.on_select_callback(self.item_table[self.selected.y])
|
||||
return true
|
||||
end
|
||||
|
||||
function Menu:onClose()
|
||||
UIManager:close(self)
|
||||
return true
|
||||
|
||||
36
frontend/ui/reader/readertoc.lua
Normal file
36
frontend/ui/reader/readertoc.lua
Normal file
@@ -0,0 +1,36 @@
|
||||
ReaderToc = InputContainer:new{
|
||||
key_events = {
|
||||
ShowToc = { {"T"}, doc = "show Table of Content menu"},
|
||||
},
|
||||
dimen = Geom:new{ w = G_width-20, h = G_height-20},
|
||||
}
|
||||
|
||||
function ReaderToc:cleanUpTocTitle(title)
|
||||
return title:gsub("\13", "")
|
||||
end
|
||||
|
||||
function ReaderToc:onSetDimensions(dimen)
|
||||
self.dimen = dimen
|
||||
end
|
||||
|
||||
function ReaderToc:onShowToc()
|
||||
function callback(item)
|
||||
self.ui:handleEvent(Event:new("PageUpdate", item.page))
|
||||
end
|
||||
|
||||
local items = self.ui.document:getToc()
|
||||
-- build menu items
|
||||
for _,v in ipairs(items) do
|
||||
v.text = (" "):rep(v.depth-1)..self:cleanUpTocTitle(v.title)
|
||||
end
|
||||
toc_menu = Menu:new{
|
||||
title = "Table of Contents",
|
||||
item_table = items,
|
||||
width = self.dimen.w,
|
||||
height = self.dimen.h,
|
||||
on_select_callback = callback,
|
||||
}
|
||||
|
||||
UIManager:show(toc_menu)
|
||||
end
|
||||
|
||||
@@ -4,6 +4,7 @@ require "ui/reader/readerzooming"
|
||||
require "ui/reader/readerpanning"
|
||||
require "ui/reader/readerrotation"
|
||||
require "ui/reader/readerpaging"
|
||||
require "ui/reader/readertoc"
|
||||
|
||||
--[[
|
||||
This is an abstraction for a reader interface
|
||||
@@ -54,6 +55,12 @@ function ReaderUI:init()
|
||||
view = self[1],
|
||||
ui = self
|
||||
}
|
||||
-- Toc menu controller
|
||||
self[5] = ReaderToc:new{
|
||||
dialog = self.dialog,
|
||||
view = self[1],
|
||||
ui = self
|
||||
}
|
||||
-- if needed, insert a paging container
|
||||
if self.document.info.has_pages then
|
||||
local pager = ReaderPaging:new{
|
||||
|
||||
Reference in New Issue
Block a user