2
0
mirror of https://github.com/koreader/koreader synced 2024-11-10 01:10:34 +00:00

AltStatusBar: take the PowerCover into account in the battery level (#8741)

Don't show [+] in top status line when device is charging
from a power cover, but the sum of both battery levels.
This commit is contained in:
zwim 2022-02-01 21:15:49 +01:00 committed by GitHub
parent c1c89dd611
commit 43f14b313f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 22 additions and 4 deletions

View File

@ -50,14 +50,14 @@ function ReaderCoptListener:onReadSettings(config)
local status_line = config:readSetting("copt_status_line") or G_reader_settings:readSetting("copt_status_line", 1) local status_line = config:readSetting("copt_status_line") or G_reader_settings:readSetting("copt_status_line", 1)
self.ui:handleEvent(Event:new("SetStatusLine", status_line)) self.ui:handleEvent(Event:new("SetStatusLine", status_line))
self.old_battery_level = Device:getPowerDevice():getCapacity() self.old_battery_level = self.ui.rolling:updateBatteryState()
-- Have this ready in case auto-refresh is enabled, now or later -- Have this ready in case auto-refresh is enabled, now or later
self.headerRefresh = function() self.headerRefresh = function()
-- Only draw it if the header is shown... -- Only draw it if the header is shown...
if self.document.configurable.status_line == 0 and self.view.view_mode == "page" then if self.document.configurable.status_line == 0 and self.view.view_mode == "page" then
-- ...and something has changed -- ...and something has changed
local new_battery_level = Device:getPowerDevice():getCapacity() local new_battery_level = self.ui.rolling:updateBatteryState()
if self.clock == 1 or (self.battery == 1 and new_battery_level ~= self.old_battery_level) then if self.clock == 1 or (self.battery == 1 and new_battery_level ~= self.old_battery_level) then
self.old_battery_level = new_battery_level self.old_battery_level = new_battery_level
self:updateHeader() self:updateHeader()
@ -92,7 +92,6 @@ end
function ReaderCoptListener:updateHeader() function ReaderCoptListener:updateHeader()
-- Have crengine display accurate time and battery on its next drawing -- Have crengine display accurate time and battery on its next drawing
self.ui.rolling:updateBatteryState()
self.ui.document:resetBufferCache() -- be sure next repaint is a redrawing self.ui.document:resetBufferCache() -- be sure next repaint is a redrawing
-- Force a refresh if we're not hidden behind another widget -- Force a refresh if we're not hidden behind another widget
if UIManager:getTopWidget() == "ReaderUI" then if UIManager:getTopWidget() == "ReaderUI" then
@ -165,6 +164,7 @@ function ReaderCoptListener:setAndSave(setting, property, value)
self.ui.document._document:setIntProperty(property, value) self.ui.document._document:setIntProperty(property, value)
G_reader_settings:saveSetting(setting, value) G_reader_settings:saveSetting(setting, value)
-- Have crengine redraw it (even if hidden by the menu at this time) -- Have crengine redraw it (even if hidden by the menu at this time)
self.ui.rolling:updateBatteryState()
self:updateHeader() self:updateHeader()
-- And see if we should auto-refresh -- And see if we should auto-refresh
self:rescheduleHeaderRefreshIfNeeded() self:rescheduleHeaderRefreshIfNeeded()

View File

@ -1106,12 +1106,30 @@ function ReaderRolling:updateBatteryState()
if self.view.view_mode == "page" and self.cre_top_bar_enabled then if self.view.view_mode == "page" and self.cre_top_bar_enabled then
logger.dbg("update battery state") logger.dbg("update battery state")
local powerd = Device:getPowerDevice() local powerd = Device:getPowerDevice()
local main_batt_lvl = powerd:getCapacity()
-- -1 is CR_BATTERY_STATE_CHARGING @ crengine/crengine/include/lvdocview.h -- -1 is CR_BATTERY_STATE_CHARGING @ crengine/crengine/include/lvdocview.h
local state = powerd:isCharging() and -1 or powerd:getCapacity() local state = powerd:isCharging() and -1 or main_batt_lvl
if powerd.device:hasAuxBattery() and powerd:isAuxBatteryConnected() and
not powerd:isAuxCharging() then
-- The first few reads after connecting to the PowerCover may fail, so default to zero
local aux_batt_lvl = powerd:getAuxCapacity()
-- If aux_battery not charging, but present -> don't show '[ + ]' in header
-- but show the average (as both battery have the same maximum capacity).
if G_reader_settings:readSetting("cre_header_battery_percent") ~= 0 then
-- if percentage is wanted, show the total capacity of reader plus power-cover
state = main_batt_lvl + aux_batt_lvl
else
-- if icon is wanted, show the total average capacity of reader and power-cover
-- (as this is the shows graphically what capacity is left in total)
state = math.floor((main_batt_lvl + aux_batt_lvl) / 2)
end
end
if state then if state then
self.ui.document:setBatteryState(state) self.ui.document:setBatteryState(state)
end end
return state
end end
return 0
end end
function ReaderRolling:handleEngineCallback(ev, ...) function ReaderRolling:handleEngineCallback(ev, ...)