2017-04-02 10:42:25 +00:00
|
|
|
local Blitbuffer = require("ffi/blitbuffer")
|
2013-10-18 20:38:07 +00:00
|
|
|
local BottomContainer = require("ui/widget/container/bottomcontainer")
|
2017-04-02 10:42:25 +00:00
|
|
|
local Device = require("device")
|
|
|
|
local Event = require("ui/event")
|
|
|
|
local Font = require("ui/font")
|
2013-10-18 20:38:07 +00:00
|
|
|
local FrameContainer = require("ui/widget/container/framecontainer")
|
2017-04-02 10:42:25 +00:00
|
|
|
local Geom = require("ui/geometry")
|
2013-12-15 12:19:06 +00:00
|
|
|
local HorizontalGroup = require("ui/widget/horizontalgroup")
|
2016-03-12 08:59:15 +00:00
|
|
|
local HorizontalSpan = require("ui/widget/horizontalspan")
|
2017-04-02 10:42:25 +00:00
|
|
|
local ProgressWidget = require("ui/widget/progresswidget")
|
|
|
|
local RightContainer = require("ui/widget/container/rightcontainer")
|
2013-10-18 20:38:07 +00:00
|
|
|
local TextWidget = require("ui/widget/textwidget")
|
2013-12-15 12:19:06 +00:00
|
|
|
local UIManager = require("ui/uimanager")
|
2017-04-02 10:42:25 +00:00
|
|
|
local WidgetContainer = require("ui/widget/container/widgetcontainer")
|
|
|
|
local util = require("util")
|
2015-03-12 06:35:43 +00:00
|
|
|
local _ = require("gettext")
|
2017-04-02 10:42:25 +00:00
|
|
|
local Screen = Device.screen
|
2013-02-23 18:25:57 +00:00
|
|
|
|
2016-02-04 03:28:50 +00:00
|
|
|
|
2016-04-28 07:02:15 +00:00
|
|
|
local MODE = {
|
|
|
|
off = 0,
|
|
|
|
page_progress = 1,
|
|
|
|
time = 2,
|
|
|
|
pages_left = 3,
|
|
|
|
battery = 4,
|
|
|
|
percentage = 5,
|
|
|
|
book_time_to_read = 6,
|
|
|
|
chapter_time_to_read = 7,
|
2016-10-16 17:22:26 +00:00
|
|
|
frontlight = 8,
|
2017-03-11 12:22:44 +00:00
|
|
|
mem_usage = 9,
|
2016-04-28 07:02:15 +00:00
|
|
|
}
|
2016-11-02 08:38:52 +00:00
|
|
|
|
2017-03-11 12:22:44 +00:00
|
|
|
local MODE_NB = 0
|
2016-04-28 07:02:15 +00:00
|
|
|
local MODE_INDEX = {}
|
|
|
|
for k,v in pairs(MODE) do
|
|
|
|
MODE_INDEX[v] = k
|
2017-03-11 12:22:44 +00:00
|
|
|
MODE_NB = MODE_NB + 1
|
2016-04-28 07:02:15 +00:00
|
|
|
end
|
|
|
|
|
2016-11-02 08:38:52 +00:00
|
|
|
-- functions that generates footer text for each mode
|
|
|
|
local footerTextGeneratorMap = {
|
|
|
|
empty = function() return "" end,
|
|
|
|
frontlight = function()
|
|
|
|
if not Device:hasFrontlight() then return "L: NA" end
|
|
|
|
local powerd = Device:getPowerDevice()
|
|
|
|
if powerd.is_fl_on ~= nil and powerd.is_fl_on == true then
|
|
|
|
if powerd.fl_intensity ~= nil then
|
2017-04-11 09:44:58 +00:00
|
|
|
return ("L: %d%%"):format(powerd.fl_intensity)
|
2016-11-02 08:38:52 +00:00
|
|
|
end
|
|
|
|
else
|
|
|
|
return "L: Off"
|
|
|
|
end
|
|
|
|
end,
|
|
|
|
battery = function()
|
|
|
|
local powerd = Device:getPowerDevice()
|
|
|
|
return "B:" .. (powerd:isCharging() and "+" or "") .. powerd:getCapacity() .. "%"
|
|
|
|
end,
|
|
|
|
time = function()
|
|
|
|
return os.date("%H:%M")
|
|
|
|
end,
|
|
|
|
page_progress = function(footer)
|
|
|
|
if footer.pageno then
|
2017-04-11 09:44:58 +00:00
|
|
|
return ("%d / %d"):format(footer.pageno, footer.pages)
|
2016-11-02 08:38:52 +00:00
|
|
|
else
|
2017-04-11 09:44:58 +00:00
|
|
|
return ("%d / %d"):format(footer.position, footer.doc_height)
|
2016-11-02 08:38:52 +00:00
|
|
|
end
|
|
|
|
end,
|
|
|
|
pages_left = function(footer)
|
|
|
|
local left = footer.ui.toc:getChapterPagesLeft(
|
|
|
|
footer.pageno, footer.toc_level)
|
|
|
|
return "=> " .. (left and left or footer.pages - footer.pageno)
|
|
|
|
end,
|
|
|
|
percentage = function(footer)
|
2017-04-11 09:44:58 +00:00
|
|
|
return ("R:%1.f%%"):format(footer.progress_bar.percentage * 100)
|
2016-11-02 08:38:52 +00:00
|
|
|
end,
|
|
|
|
book_time_to_read = function(footer)
|
|
|
|
local current_page
|
|
|
|
if footer.view.document.info.has_pages then
|
|
|
|
current_page = footer.ui.paging.current_page
|
|
|
|
else
|
|
|
|
current_page = footer.view.document:getCurrentPage()
|
|
|
|
end
|
|
|
|
return footer:getDataFromStatistics("TB: ", footer.pages - current_page)
|
|
|
|
end,
|
|
|
|
chapter_time_to_read = function(footer)
|
|
|
|
local left = footer.ui.toc:getChapterPagesLeft(
|
|
|
|
footer.pageno, footer.toc_level)
|
|
|
|
return footer:getDataFromStatistics(
|
|
|
|
"TC: ", (left and left or footer.pages - footer.pageno))
|
|
|
|
end,
|
2017-03-11 12:22:44 +00:00
|
|
|
mem_usage = function(footer)
|
|
|
|
local statm = io.open("/proc/self/statm", "r")
|
|
|
|
if statm then
|
|
|
|
local infos = statm:read("*all")
|
|
|
|
statm:close()
|
|
|
|
local rss = infos:match("^%S+ (%S+) ")
|
|
|
|
-- we got the nb of 4Kb-pages used, that we convert to Mb
|
|
|
|
rss = math.floor(tonumber(rss) * 4096 / 1024 / 1024)
|
2017-04-11 09:44:58 +00:00
|
|
|
return ("M:%d"):format(rss)
|
2017-03-11 12:22:44 +00:00
|
|
|
end
|
|
|
|
return ""
|
|
|
|
end,
|
2016-11-02 08:38:52 +00:00
|
|
|
}
|
|
|
|
|
2016-12-25 20:13:30 +00:00
|
|
|
local ReaderFooter = WidgetContainer:extend{
|
2016-04-28 07:02:15 +00:00
|
|
|
mode = MODE.page_progress,
|
2014-03-13 13:52:43 +00:00
|
|
|
pageno = nil,
|
|
|
|
pages = nil,
|
2014-10-07 09:09:37 +00:00
|
|
|
toc_level = 0,
|
2014-03-13 13:52:43 +00:00
|
|
|
progress_percentage = 0.0,
|
2016-11-02 08:38:52 +00:00
|
|
|
footer_text = nil,
|
2014-03-13 13:52:43 +00:00
|
|
|
text_font_face = "ffont",
|
2014-09-27 10:56:47 +00:00
|
|
|
text_font_size = DMINIBAR_FONT_SIZE,
|
2014-11-20 22:07:39 +00:00
|
|
|
bar_height = Screen:scaleBySize(DMINIBAR_HEIGHT),
|
|
|
|
height = Screen:scaleBySize(DMINIBAR_CONTAINER_HEIGHT),
|
2016-03-12 08:59:15 +00:00
|
|
|
horizontal_margin = Screen:scaleBySize(10),
|
|
|
|
text_left_margin = Screen:scaleBySize(10),
|
2015-03-12 06:35:43 +00:00
|
|
|
settings = {},
|
2016-11-02 08:38:52 +00:00
|
|
|
-- added to expose them to unit tests
|
|
|
|
textGeneratorMap = footerTextGeneratorMap,
|
2013-02-23 18:25:57 +00:00
|
|
|
}
|
|
|
|
|
2013-02-24 07:25:08 +00:00
|
|
|
function ReaderFooter:init()
|
2015-03-12 06:35:43 +00:00
|
|
|
self.settings = G_reader_settings:readSetting("footer") or {
|
2017-04-11 09:44:58 +00:00
|
|
|
-- enable progress bar by default
|
|
|
|
-- disable_progress_bar = true,
|
2015-03-12 06:35:43 +00:00
|
|
|
disabled = false,
|
|
|
|
all_at_once = false,
|
|
|
|
toc_markers = true,
|
|
|
|
battery = true,
|
|
|
|
time = true,
|
|
|
|
page_progress = true,
|
2015-03-12 07:51:59 +00:00
|
|
|
pages_left = true,
|
2015-03-12 06:35:43 +00:00
|
|
|
percentage = true,
|
2015-11-27 15:13:01 +00:00
|
|
|
book_time_to_read = true,
|
|
|
|
chapter_time_to_read = true,
|
2016-10-16 17:22:26 +00:00
|
|
|
frontlight = false,
|
2017-03-11 12:22:44 +00:00
|
|
|
mem_usage = false,
|
2015-03-12 06:35:43 +00:00
|
|
|
}
|
2016-11-02 08:38:52 +00:00
|
|
|
|
2016-03-12 21:59:49 +00:00
|
|
|
if self.settings.disabled then
|
2016-11-02 08:38:52 +00:00
|
|
|
-- footer featuren disabled completely, stop initialization now
|
|
|
|
self:disableFooter()
|
2016-03-12 21:59:49 +00:00
|
|
|
return
|
|
|
|
end
|
|
|
|
|
2017-04-11 09:44:58 +00:00
|
|
|
self.pageno = self.view.state.page
|
2016-11-02 08:38:52 +00:00
|
|
|
self.has_no_mode = true
|
|
|
|
for _, m in ipairs(MODE_INDEX) do
|
|
|
|
if self.settings[m] then
|
|
|
|
self.has_no_mode = false
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
self.footer_text = TextWidget:new{
|
2016-03-12 08:59:15 +00:00
|
|
|
text = '',
|
2014-03-13 13:52:43 +00:00
|
|
|
face = Font:getFace(self.text_font_face, self.text_font_size),
|
|
|
|
}
|
2016-11-02 08:38:52 +00:00
|
|
|
-- all width related values will be initialized in self:resetLayout()
|
|
|
|
self.text_width = 0
|
2014-06-05 04:48:48 +00:00
|
|
|
self.progress_bar = ProgressWidget:new{
|
2016-11-02 08:38:52 +00:00
|
|
|
width = nil,
|
2014-07-17 13:27:35 +00:00
|
|
|
height = self.bar_height,
|
2014-06-05 04:48:48 +00:00
|
|
|
percentage = self.progress_percentage,
|
2014-10-07 09:09:37 +00:00
|
|
|
tick_width = DMINIBAR_TOC_MARKER_WIDTH,
|
2016-03-19 06:22:17 +00:00
|
|
|
ticks = nil, -- ticks will be populated in self:updateFooterText
|
|
|
|
last = nil, -- last will be initialized in self:updateFooterText
|
2014-06-05 04:48:48 +00:00
|
|
|
}
|
2016-03-12 08:59:15 +00:00
|
|
|
self.text_container = RightContainer:new{
|
2016-12-04 06:57:57 +00:00
|
|
|
dimen = Geom:new{ w = 0, h = self.height },
|
2016-11-02 08:38:52 +00:00
|
|
|
self.footer_text,
|
2014-03-13 13:52:43 +00:00
|
|
|
}
|
2017-04-11 09:44:58 +00:00
|
|
|
|
|
|
|
local margin_span = HorizontalSpan:new{ width = self.horizontal_margin }
|
|
|
|
self.horizontal_group = HorizontalGroup:new{
|
|
|
|
margin_span,
|
|
|
|
self.progress_bar,
|
|
|
|
self.text_container,
|
|
|
|
margin_span,
|
|
|
|
}
|
2016-12-04 06:57:57 +00:00
|
|
|
|
|
|
|
self.footer_content = FrameContainer:new{
|
|
|
|
self.horizontal_group,
|
|
|
|
background = Blitbuffer.COLOR_WHITE,
|
|
|
|
bordersize = 0,
|
|
|
|
padding = 0,
|
|
|
|
}
|
|
|
|
self.footer_container = BottomContainer:new{
|
|
|
|
dimen = Geom:new{ w = 0, h = self.height*2 },
|
|
|
|
self.footer_content,
|
|
|
|
}
|
|
|
|
self.footer_positioner = BottomContainer:new{
|
2016-11-02 08:38:52 +00:00
|
|
|
dimen = Geom:new{},
|
2016-12-04 06:57:57 +00:00
|
|
|
self.footer_container,
|
2014-03-13 13:52:43 +00:00
|
|
|
}
|
2016-12-04 06:57:57 +00:00
|
|
|
self[1] = self.footer_positioner
|
2016-03-08 06:42:46 +00:00
|
|
|
|
2016-11-02 08:38:52 +00:00
|
|
|
self.mode = G_reader_settings:readSetting("reader_footer_mode") or self.mode
|
|
|
|
if self.settings.all_at_once then
|
|
|
|
self.view.footer_visible = (self.mode ~= MODE.off)
|
|
|
|
self:updateFooterTextGenerator()
|
|
|
|
else
|
|
|
|
self:applyFooterMode()
|
|
|
|
end
|
2016-03-08 06:42:46 +00:00
|
|
|
|
|
|
|
if self.settings.auto_refresh_time then
|
2016-11-02 08:38:52 +00:00
|
|
|
self:setupAutoRefreshTime()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:setupAutoRefreshTime()
|
|
|
|
if not self.autoRefreshTime then
|
|
|
|
self.autoRefreshTime = function()
|
|
|
|
self:updateFooter()
|
|
|
|
UIManager:scheduleIn(61 - tonumber(os.date("%S")), self.autoRefreshTime)
|
2016-03-08 06:42:46 +00:00
|
|
|
end
|
|
|
|
end
|
2016-11-02 08:38:52 +00:00
|
|
|
self.onCloseDocument = function()
|
|
|
|
UIManager:unschedule(self.autoRefreshTime)
|
|
|
|
end
|
|
|
|
UIManager:scheduleIn(61 - tonumber(os.date("%S")), self.autoRefreshTime)
|
2016-03-08 06:42:46 +00:00
|
|
|
end
|
|
|
|
|
2016-12-04 06:57:57 +00:00
|
|
|
function ReaderFooter:setupTouchZones()
|
|
|
|
if not Device:isTouchDevice() then return end
|
|
|
|
local footer_screen_zone = {
|
|
|
|
ratio_x = DTAP_ZONE_MINIBAR.x, ratio_y = DTAP_ZONE_MINIBAR.y,
|
|
|
|
ratio_w = DTAP_ZONE_MINIBAR.w, ratio_h = DTAP_ZONE_MINIBAR.h,
|
|
|
|
}
|
|
|
|
self.ui:registerTouchZones({
|
|
|
|
{
|
2016-12-19 04:27:56 +00:00
|
|
|
id = "readerfooter_tap",
|
2016-12-04 06:57:57 +00:00
|
|
|
ges = "tap",
|
|
|
|
screen_zone = footer_screen_zone,
|
2017-04-02 10:42:25 +00:00
|
|
|
handler = function(ges) return self:onTapFooter(ges) end,
|
2016-12-19 04:27:56 +00:00
|
|
|
overrides = {
|
|
|
|
'tap_forward', 'tap_backward',
|
|
|
|
},
|
2016-12-04 06:57:57 +00:00
|
|
|
},
|
|
|
|
{
|
2016-12-19 04:27:56 +00:00
|
|
|
id = "readerfooter_hold",
|
2016-12-04 06:57:57 +00:00
|
|
|
ges = "hold",
|
|
|
|
screen_zone = footer_screen_zone,
|
|
|
|
handler = function() return self:onHoldFooter() end,
|
2017-01-23 14:54:14 +00:00
|
|
|
overrides = {'readerhighlight_hold'},
|
2016-12-04 06:57:57 +00:00
|
|
|
},
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|
|
|
|
-- call this method whenever the screen size changes
|
2016-03-08 06:42:46 +00:00
|
|
|
function ReaderFooter:resetLayout()
|
2016-03-12 08:59:15 +00:00
|
|
|
local new_screen_width = Screen:getWidth()
|
|
|
|
if new_screen_width == self._saved_screen_width then return end
|
|
|
|
local new_screen_height = Screen:getHeight()
|
|
|
|
|
2017-04-11 09:44:58 +00:00
|
|
|
if self.settings.disable_progress_bar then
|
|
|
|
self.progress_bar.width = 0
|
|
|
|
else
|
|
|
|
self.progress_bar.width = math.floor(
|
|
|
|
new_screen_width - self.text_width - self.horizontal_margin*2)
|
|
|
|
end
|
2016-03-08 06:42:46 +00:00
|
|
|
self.horizontal_group:resetLayout()
|
2016-12-04 06:57:57 +00:00
|
|
|
self.footer_positioner.dimen.w = new_screen_width
|
|
|
|
self.footer_positioner.dimen.h = new_screen_height
|
|
|
|
self.footer_container.dimen.w = new_screen_width
|
|
|
|
self.dimen = self.footer_positioner:getSize()
|
2016-03-08 06:42:46 +00:00
|
|
|
|
2016-03-12 08:59:15 +00:00
|
|
|
self._saved_screen_width = new_screen_width
|
2013-02-23 18:25:57 +00:00
|
|
|
end
|
|
|
|
|
2016-11-02 08:38:52 +00:00
|
|
|
function ReaderFooter:getHeight()
|
|
|
|
return self.footer_text:getSize().h
|
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:disableFooter()
|
|
|
|
self.onReaderReady = function() end
|
|
|
|
self.resetLayout = function() end
|
|
|
|
self.onCloseDocument = nil
|
|
|
|
self.onPageUpdate = function() end
|
|
|
|
self.onPosUpdate = function() end
|
|
|
|
self.onUpdatePos = function() end
|
|
|
|
self.onSetStatusLine = function() end
|
|
|
|
self.mode = MODE.off
|
|
|
|
self.view.footer_visible = false
|
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:updateFooterTextGenerator()
|
|
|
|
local footerTextGenerators = {}
|
|
|
|
for _, m in pairs(MODE_INDEX) do
|
|
|
|
if self.settings[m] then
|
|
|
|
table.insert(footerTextGenerators,
|
|
|
|
footerTextGeneratorMap[m])
|
|
|
|
if not self.settings.all_at_once then
|
|
|
|
-- if not show all at once, then one is enough
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if #footerTextGenerators == 0 then
|
|
|
|
-- all modes are disabled
|
|
|
|
self.genFooterText = footerTextGeneratorMap.empty
|
|
|
|
elseif #footerTextGenerators == 1 then
|
|
|
|
-- there is only one mode enabled, simplify the generator
|
|
|
|
-- function to that one
|
|
|
|
self.genFooterText = footerTextGenerators[1]
|
|
|
|
else
|
|
|
|
self.footerTextGenerators = footerTextGenerators
|
|
|
|
self.genFooterText = self.genAllFooterText
|
|
|
|
end
|
|
|
|
-- notify caller that UI needs update
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
|
|
|
|
local option_titles = {
|
2015-03-12 06:35:43 +00:00
|
|
|
all_at_once = _("Show all at once"),
|
2017-04-07 21:07:35 +00:00
|
|
|
toc_markers = _("Show chapter markers"),
|
2015-03-20 13:22:14 +00:00
|
|
|
page_progress = _("Current page"),
|
2016-11-02 08:38:52 +00:00
|
|
|
time = _("Current time"),
|
2017-04-07 21:07:35 +00:00
|
|
|
pages_left = _("Pages left in chapter"),
|
2016-11-02 08:38:52 +00:00
|
|
|
battery = _("Battery status"),
|
2015-03-20 13:22:14 +00:00
|
|
|
percentage = _("Progress percentage"),
|
2015-11-27 15:13:01 +00:00
|
|
|
book_time_to_read = _("Book time to read"),
|
|
|
|
chapter_time_to_read = _("Chapter time to read"),
|
2016-10-16 17:22:26 +00:00
|
|
|
frontlight = _("Frontlight level"),
|
2017-03-11 12:22:44 +00:00
|
|
|
mem_usage = _("KOReader memory usage"),
|
2015-03-12 06:35:43 +00:00
|
|
|
}
|
|
|
|
|
2017-03-03 15:03:12 +00:00
|
|
|
function ReaderFooter:addToMainMenu(menu_items)
|
2016-04-26 02:45:55 +00:00
|
|
|
local sub_items = {}
|
2017-03-03 15:03:12 +00:00
|
|
|
menu_items.status_bar = {
|
2016-11-02 08:38:52 +00:00
|
|
|
text = _("Status bar"),
|
|
|
|
sub_item_table = sub_items,
|
2017-02-28 21:46:32 +00:00
|
|
|
}
|
2016-11-02 08:38:52 +00:00
|
|
|
|
|
|
|
-- menu item to fake footer tapping when touch area is disabled
|
2016-04-26 02:45:55 +00:00
|
|
|
if Geom:new{
|
|
|
|
x = DTAP_ZONE_MINIBAR.x,
|
|
|
|
y = DTAP_ZONE_MINIBAR.y,
|
|
|
|
w = DTAP_ZONE_MINIBAR.w,
|
|
|
|
h = DTAP_ZONE_MINIBAR.h
|
2016-12-04 23:13:49 +00:00
|
|
|
}:area() == 0 then
|
2016-04-26 02:45:55 +00:00
|
|
|
table.insert(sub_items, {
|
2016-11-02 08:38:52 +00:00
|
|
|
text = _("Toggle mode"),
|
2016-04-26 02:45:55 +00:00
|
|
|
enabled_func = function()
|
|
|
|
return not self.view.flipping_visible
|
|
|
|
end,
|
2016-11-02 08:38:52 +00:00
|
|
|
callback = function() self:onTapFooter() end,
|
2016-04-26 02:45:55 +00:00
|
|
|
})
|
|
|
|
end
|
2016-11-02 08:38:52 +00:00
|
|
|
|
|
|
|
local getMinibarOption = function(option, callback)
|
|
|
|
return {
|
|
|
|
text = option_titles[option],
|
|
|
|
checked_func = function()
|
|
|
|
return self.settings[option] == true
|
|
|
|
end,
|
|
|
|
callback = function()
|
|
|
|
self.settings[option] = not self.settings[option]
|
|
|
|
G_reader_settings:saveSetting("footer", self.settings)
|
|
|
|
-- only case that we don't need a UI update is enable/disable
|
|
|
|
-- non-current mode when all_at_once is disabled.
|
|
|
|
local should_update = false
|
|
|
|
local first_enabled_mode_num
|
|
|
|
local prev_has_no_mode = self.has_no_mode
|
|
|
|
self.has_no_mode = true
|
|
|
|
for mode_num, m in pairs(MODE_INDEX) do
|
|
|
|
if self.settings[m] then
|
|
|
|
first_enabled_mode_num = mode_num
|
|
|
|
self.has_no_mode = false
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if callback then
|
|
|
|
should_update = callback(self)
|
|
|
|
elseif self.settings.all_at_once then
|
|
|
|
should_update = self:updateFooterTextGenerator()
|
|
|
|
elseif (MODE[option] == self.mode and self.settings[option] == false)
|
|
|
|
or (prev_has_no_mode ~= self.has_no_mode) then
|
|
|
|
-- current mode got disabled, redraw footer with other
|
|
|
|
-- enabled modes. if all modes are disabled, then only show
|
|
|
|
-- progress bar
|
|
|
|
if not self.has_no_mode then
|
|
|
|
self.mode = first_enabled_mode_num
|
|
|
|
end
|
|
|
|
should_update = true
|
|
|
|
self:applyFooterMode()
|
|
|
|
end
|
|
|
|
if should_update then
|
|
|
|
self:updateFooter()
|
|
|
|
UIManager:setDirty("all", "partial")
|
|
|
|
end
|
|
|
|
end,
|
|
|
|
}
|
2016-10-16 17:22:26 +00:00
|
|
|
end
|
|
|
|
|
2016-11-02 08:38:52 +00:00
|
|
|
table.insert(sub_items,
|
|
|
|
getMinibarOption("all_at_once", self.updateFooterTextGenerator))
|
2017-04-11 09:44:58 +00:00
|
|
|
table.insert(sub_items, {
|
|
|
|
text = _("Progress bar"),
|
|
|
|
sub_item_table = {
|
|
|
|
{
|
|
|
|
text = _("Show progress bar"),
|
|
|
|
checked_func = function()
|
|
|
|
return not self.settings.disable_progress_bar
|
|
|
|
end,
|
|
|
|
callback = function()
|
|
|
|
self.settings.disable_progress_bar = not self.settings.disable_progress_bar
|
|
|
|
self:updateFooter()
|
|
|
|
UIManager:setDirty("all", "partial")
|
|
|
|
end,
|
|
|
|
},
|
|
|
|
getMinibarOption("toc_markers", self.setTocMarkers),
|
|
|
|
}
|
|
|
|
})
|
|
|
|
table.insert(sub_items, {
|
|
|
|
text = _("Auto refresh time"),
|
|
|
|
checked_func = function()
|
|
|
|
return self.settings.auto_refresh_time == true
|
|
|
|
end,
|
|
|
|
-- only enable auto refresh when time is shown
|
|
|
|
enabled_func = function() return self.settings.time end,
|
|
|
|
callback = function()
|
|
|
|
self.settings.auto_refresh_time = not self.settings.auto_refresh_time
|
|
|
|
G_reader_settings:saveSetting("footer", self.settings)
|
|
|
|
if self.settings.auto_refresh_time then
|
|
|
|
self:setupAutoRefreshTime()
|
|
|
|
else
|
|
|
|
UIManager:unschedule(self.autoRefreshTime)
|
|
|
|
self.onCloseDocument = nil
|
|
|
|
end
|
2016-11-02 08:38:52 +00:00
|
|
|
end
|
2017-04-11 09:44:58 +00:00
|
|
|
})
|
2016-11-02 08:38:52 +00:00
|
|
|
table.insert(sub_items, getMinibarOption("page_progress"))
|
|
|
|
table.insert(sub_items, getMinibarOption("time"))
|
|
|
|
table.insert(sub_items, getMinibarOption("pages_left"))
|
|
|
|
table.insert(sub_items, getMinibarOption("battery"))
|
|
|
|
table.insert(sub_items, getMinibarOption("percentage"))
|
|
|
|
table.insert(sub_items, getMinibarOption("book_time_to_read"))
|
|
|
|
table.insert(sub_items, getMinibarOption("chapter_time_to_read"))
|
2017-04-13 16:54:30 +00:00
|
|
|
if Device:hasFrontlight() then
|
|
|
|
table.insert(sub_items, getMinibarOption("frontlight"))
|
|
|
|
end
|
2017-03-11 12:22:44 +00:00
|
|
|
table.insert(sub_items, getMinibarOption("mem_usage"))
|
2014-10-07 09:09:37 +00:00
|
|
|
end
|
|
|
|
|
2016-11-02 08:38:52 +00:00
|
|
|
-- this method will be updated at runtime based on user setting
|
|
|
|
function ReaderFooter:genFooterText() end
|
2014-10-07 09:09:37 +00:00
|
|
|
|
2016-11-02 08:38:52 +00:00
|
|
|
function ReaderFooter:genAllFooterText()
|
|
|
|
local info = {}
|
|
|
|
for _, gen in ipairs(self.footerTextGenerators) do
|
|
|
|
table.insert(info, gen(self))
|
2016-03-12 08:59:15 +00:00
|
|
|
end
|
2016-11-02 08:38:52 +00:00
|
|
|
return table.concat(info, " | ")
|
2014-10-07 09:09:37 +00:00
|
|
|
end
|
|
|
|
|
2017-04-11 09:44:58 +00:00
|
|
|
-- this method should never get called when footer is disabled
|
2016-11-02 08:38:52 +00:00
|
|
|
function ReaderFooter:setTocMarkers()
|
|
|
|
if self.settings.toc_markers then
|
|
|
|
if self.progress_bar.ticks ~= nil then return end
|
|
|
|
local ticks_candidates = {}
|
|
|
|
if self.ui.toc then
|
|
|
|
local max_level = self.ui.toc:getMaxDepth()
|
|
|
|
for i = 0, -max_level, -1 do
|
|
|
|
local ticks = self.ui.toc:getTocTicks(i)
|
|
|
|
table.insert(ticks_candidates, ticks)
|
|
|
|
end
|
|
|
|
-- find the finest toc ticks by sorting out the largest one
|
|
|
|
table.sort(ticks_candidates, function(a, b) return #a > #b end)
|
|
|
|
end
|
2015-03-12 06:35:43 +00:00
|
|
|
|
2016-11-02 08:38:52 +00:00
|
|
|
if #ticks_candidates > 0 then
|
|
|
|
self.progress_bar.ticks = ticks_candidates[1]
|
|
|
|
self.progress_bar.last = self.pages or self.view.document:getPageCount()
|
|
|
|
else
|
|
|
|
-- we still set ticks here so self.progress_bar.ticks will not be
|
|
|
|
-- initialized again if ticks_candidates is empty
|
|
|
|
self.progress_bar.ticks = {}
|
|
|
|
end
|
2015-12-26 04:54:13 +00:00
|
|
|
else
|
2016-11-02 08:38:52 +00:00
|
|
|
self.progress_bar.ticks = nil
|
2015-12-26 04:54:13 +00:00
|
|
|
end
|
2016-11-24 13:44:19 +00:00
|
|
|
-- notify caller that UI needs update
|
|
|
|
return true
|
2015-11-27 15:13:01 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:getDataFromStatistics(title, pages)
|
|
|
|
local statistics_data = self.ui.doc_settings:readSetting("stats")
|
2015-12-23 06:35:46 +00:00
|
|
|
local sec = 'na'
|
2015-11-27 15:13:01 +00:00
|
|
|
if statistics_data and statistics_data.performance_in_pages then
|
2016-01-29 06:37:46 +00:00
|
|
|
local read_pages = util.tableSize(statistics_data.performance_in_pages)
|
2015-11-27 15:13:01 +00:00
|
|
|
local average_time_per_page = statistics_data.total_time_in_sec / read_pages
|
2015-12-23 06:35:46 +00:00
|
|
|
sec = util.secondsToClock(pages * average_time_per_page, true)
|
2015-11-27 15:13:01 +00:00
|
|
|
end
|
2015-12-23 06:35:46 +00:00
|
|
|
return title .. sec
|
2015-11-27 15:13:01 +00:00
|
|
|
end
|
|
|
|
|
2016-03-12 08:59:15 +00:00
|
|
|
function ReaderFooter:updateFooter()
|
|
|
|
if self.pageno then
|
|
|
|
self:updateFooterPage()
|
|
|
|
else
|
|
|
|
self:updateFooterPos()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-02-12 07:26:56 +00:00
|
|
|
function ReaderFooter:updateFooterPage()
|
2014-03-13 13:52:43 +00:00
|
|
|
if type(self.pageno) ~= "number" then return end
|
|
|
|
self.progress_bar.percentage = self.pageno / self.pages
|
2016-03-12 08:59:15 +00:00
|
|
|
self:updateFooterText()
|
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:updateFooterPos()
|
|
|
|
if type(self.position) ~= "number" then return end
|
|
|
|
self.progress_bar.percentage = self.position / self.doc_height
|
|
|
|
self:updateFooterText()
|
|
|
|
end
|
|
|
|
|
2016-06-03 08:31:46 +00:00
|
|
|
-- updateFooterText will start as a noop. After onReaderReady event is
|
2016-07-24 00:57:29 +00:00
|
|
|
-- received, it will initialized as _updateFooterText below
|
2016-03-12 08:59:15 +00:00
|
|
|
function ReaderFooter:updateFooterText()
|
2016-06-03 08:31:46 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- only call this function after document is fully loaded
|
|
|
|
function ReaderFooter:_updateFooterText()
|
2016-11-02 08:38:52 +00:00
|
|
|
self.footer_text:setText(self:genFooterText())
|
2017-04-11 09:44:58 +00:00
|
|
|
if self.settings.disable_progress_bar then
|
|
|
|
if self.has_no_mode then
|
|
|
|
self.text_width = 0
|
|
|
|
else
|
|
|
|
self.text_width = self.footer_text:getSize().w
|
|
|
|
end
|
|
|
|
self.progress_bar.width = 0
|
2014-07-02 08:43:24 +00:00
|
|
|
else
|
2017-04-11 09:44:58 +00:00
|
|
|
if self.has_no_mode then
|
|
|
|
self.text_width = 0
|
|
|
|
else
|
|
|
|
self.text_width = self.footer_text:getSize().w + self.text_left_margin
|
|
|
|
end
|
|
|
|
self.progress_bar.width = math.floor(
|
|
|
|
self._saved_screen_width - self.text_width - self.horizontal_margin*2)
|
2014-07-02 08:43:24 +00:00
|
|
|
end
|
2016-03-12 08:59:15 +00:00
|
|
|
self.text_container.dimen.w = self.text_width
|
|
|
|
self.horizontal_group:resetLayout()
|
2016-12-04 06:57:57 +00:00
|
|
|
UIManager:setDirty(self.view.dialog, "ui", self.footer_content.dimen)
|
2014-02-12 07:26:56 +00:00
|
|
|
end
|
|
|
|
|
2013-02-24 07:25:08 +00:00
|
|
|
function ReaderFooter:onPageUpdate(pageno)
|
2014-03-13 13:52:43 +00:00
|
|
|
self.pageno = pageno
|
2016-03-19 06:22:17 +00:00
|
|
|
self.pages = self.view.document:getPageCount()
|
2014-03-13 13:52:43 +00:00
|
|
|
self:updateFooterPage()
|
2014-02-12 07:26:56 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:onPosUpdate(pos)
|
2014-03-13 13:52:43 +00:00
|
|
|
self.position = pos
|
|
|
|
self.doc_height = self.view.document.info.doc_height
|
|
|
|
self:updateFooterPos()
|
2013-02-23 18:25:57 +00:00
|
|
|
end
|
2013-10-18 20:38:07 +00:00
|
|
|
|
2014-07-22 13:52:41 +00:00
|
|
|
-- recalculate footer sizes when document page count is updated
|
2016-03-12 08:59:15 +00:00
|
|
|
-- see documentation for more info about this event.
|
2016-11-02 08:38:52 +00:00
|
|
|
ReaderFooter.onUpdatePos = ReaderFooter.updateFooter
|
2014-07-22 13:52:41 +00:00
|
|
|
|
2016-06-03 08:31:46 +00:00
|
|
|
function ReaderFooter:onReaderReady()
|
2016-12-25 20:13:30 +00:00
|
|
|
self.ui.menu:registerToMainMenu(self)
|
2016-12-04 06:57:57 +00:00
|
|
|
self:setupTouchZones()
|
|
|
|
self:resetLayout() -- set widget dimen
|
2016-11-02 08:38:52 +00:00
|
|
|
self:setTocMarkers()
|
2016-06-03 08:31:46 +00:00
|
|
|
self.updateFooterText = self._updateFooterText
|
|
|
|
self:updateFooter()
|
|
|
|
end
|
2016-03-19 06:22:17 +00:00
|
|
|
|
2014-05-19 06:23:31 +00:00
|
|
|
function ReaderFooter:applyFooterMode(mode)
|
2014-04-04 13:20:26 +00:00
|
|
|
-- three modes switcher for reader footer
|
|
|
|
-- 0 for footer off
|
|
|
|
-- 1 for footer page info
|
2014-07-02 08:32:17 +00:00
|
|
|
-- 2 for footer time info
|
|
|
|
-- 3 for footer next_chapter info
|
2014-07-04 12:42:36 +00:00
|
|
|
-- 4 for battery status
|
2015-03-12 06:35:43 +00:00
|
|
|
-- 5 for progress percentage
|
2015-11-27 15:13:01 +00:00
|
|
|
-- 6 for from statistics book time to read
|
|
|
|
-- 7 for from statistics chapter time to read
|
2016-10-16 17:22:26 +00:00
|
|
|
-- 8 for front light level
|
2017-03-11 12:22:44 +00:00
|
|
|
-- 9 for memory usage
|
2014-05-19 06:23:31 +00:00
|
|
|
if mode ~= nil then self.mode = mode end
|
2016-04-28 07:02:15 +00:00
|
|
|
self.view.footer_visible = (self.mode ~= MODE.off)
|
2016-11-02 08:38:52 +00:00
|
|
|
if not self.view.footer_visible or self.settings.all_at_once then return end
|
|
|
|
|
|
|
|
local mode_name = MODE_INDEX[self.mode]
|
|
|
|
if not self.settings[mode_name] or self.has_no_mode then
|
|
|
|
-- all modes disabled, only show progress bar
|
|
|
|
mode_name = "empty"
|
|
|
|
end
|
|
|
|
self.genFooterText = footerTextGeneratorMap[mode_name]
|
2014-04-04 13:20:26 +00:00
|
|
|
end
|
|
|
|
|
2014-05-19 06:23:31 +00:00
|
|
|
function ReaderFooter:onEnterFlippingMode()
|
|
|
|
self.orig_mode = self.mode
|
2016-04-28 07:02:15 +00:00
|
|
|
self:applyFooterMode(MODE.page_progress)
|
2014-05-19 06:23:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:onExitFlippingMode()
|
|
|
|
self:applyFooterMode(self.orig_mode)
|
|
|
|
end
|
|
|
|
|
2017-04-02 10:42:25 +00:00
|
|
|
function ReaderFooter:onTapFooter(ges)
|
2014-03-13 13:52:43 +00:00
|
|
|
if self.view.flipping_visible then
|
|
|
|
local pos = ges.pos
|
|
|
|
local dimen = self.progress_bar.dimen
|
2014-05-19 06:23:31 +00:00
|
|
|
-- if reader footer is not drawn before the dimen value should be nil
|
|
|
|
if dimen then
|
|
|
|
local percentage = (pos.x - dimen.x)/dimen.w
|
|
|
|
self.ui:handleEvent(Event:new("GotoPercentage", percentage))
|
|
|
|
end
|
2014-03-13 13:52:43 +00:00
|
|
|
else
|
2016-11-02 08:38:52 +00:00
|
|
|
if self.settings.all_at_once or self.has_no_mode then
|
2016-04-28 07:02:15 +00:00
|
|
|
if self.mode >= 1 then
|
|
|
|
self.mode = MODE.off
|
|
|
|
else
|
|
|
|
self.mode = MODE.page_progress
|
|
|
|
end
|
|
|
|
else
|
2017-03-11 12:22:44 +00:00
|
|
|
self.mode = (self.mode + 1) % MODE_NB
|
2016-04-28 07:02:15 +00:00
|
|
|
for i, m in ipairs(MODE_INDEX) do
|
|
|
|
if self.mode == MODE.off then break end
|
|
|
|
if self.mode == i then
|
|
|
|
if self.settings[m] then
|
|
|
|
break
|
|
|
|
else
|
2017-03-11 12:22:44 +00:00
|
|
|
self.mode = (self.mode + 1) % MODE_NB
|
2016-04-28 07:02:15 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2014-07-02 08:32:17 +00:00
|
|
|
end
|
2014-04-04 13:20:26 +00:00
|
|
|
self:applyFooterMode()
|
2014-11-30 17:28:18 +00:00
|
|
|
G_reader_settings:saveSetting("reader_footer_mode", self.mode)
|
2014-03-13 13:52:43 +00:00
|
|
|
end
|
2016-03-12 08:59:15 +00:00
|
|
|
self:updateFooter()
|
2014-04-04 13:20:26 +00:00
|
|
|
return true
|
2013-12-15 12:19:06 +00:00
|
|
|
end
|
|
|
|
|
2016-12-04 06:57:57 +00:00
|
|
|
function ReaderFooter:onHoldFooter()
|
2016-04-28 07:02:15 +00:00
|
|
|
if self.mode == MODE.off then return end
|
2014-03-13 13:52:43 +00:00
|
|
|
self.ui:handleEvent(Event:new("ShowGotoDialog"))
|
|
|
|
return true
|
2014-02-12 12:41:16 +00:00
|
|
|
end
|
|
|
|
|
2014-02-12 07:26:56 +00:00
|
|
|
function ReaderFooter:onSetStatusLine(status_line)
|
2016-07-24 00:57:29 +00:00
|
|
|
-- 1 is min progress bar while 0 is full cre header progress bar
|
|
|
|
if status_line == 1 then
|
|
|
|
self.view.footer_visible = (self.mode ~= MODE.off)
|
|
|
|
else
|
|
|
|
self:applyFooterMode(MODE.off)
|
|
|
|
end
|
2014-03-13 13:52:43 +00:00
|
|
|
self.ui.document:setStatusLineProp(status_line)
|
|
|
|
self.ui:handleEvent(Event:new("UpdatePos"))
|
2014-02-12 07:26:56 +00:00
|
|
|
end
|
|
|
|
|
2017-03-24 17:57:07 +00:00
|
|
|
function ReaderFooter:onResume()
|
|
|
|
self:updateFooter()
|
2017-04-04 18:24:06 +00:00
|
|
|
if self.settings.auto_refresh_time then
|
|
|
|
self:setupAutoRefreshTime()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
function ReaderFooter:onSuspend()
|
|
|
|
if self.settings.auto_refresh_time then
|
|
|
|
UIManager:unschedule(self.autoRefreshTime)
|
|
|
|
self.onCloseDocument = nil
|
|
|
|
end
|
2017-03-24 17:57:07 +00:00
|
|
|
end
|
|
|
|
|
2013-10-18 20:38:07 +00:00
|
|
|
return ReaderFooter
|