Add 'read from right to left' in readerrolling

- Fix problems in readerpaging.lua;
- Add the same feature in readerrolling.lua.
pull/2075/head
chihyang 8 years ago
parent 8b14209249
commit a948ecb19a

@ -131,6 +131,7 @@ function ReaderPaging:onReadSettings(config)
self.flipping_zoom_mode = config:readSetting("flipping_zoom_mode") or "page" self.flipping_zoom_mode = config:readSetting("flipping_zoom_mode") or "page"
self.flipping_scroll_mode = config:readSetting("flipping_scroll_mode") or false self.flipping_scroll_mode = config:readSetting("flipping_scroll_mode") or false
self.inverse_reading_order = config:readSetting("inverse_reading_order") or false self.inverse_reading_order = config:readSetting("inverse_reading_order") or false
self:updateReadOrder()
end end
function ReaderPaging:onSaveSettings() function ReaderPaging:onSaveSettings()
@ -859,9 +860,9 @@ function ReaderPaging:updateReadOrder()
y = Screen:getHeight()*DTAP_ZONE_FORWARD.y, y = Screen:getHeight()*DTAP_ZONE_FORWARD.y,
w = Screen:getWidth()*DTAP_ZONE_FORWARD.w, w = Screen:getWidth()*DTAP_ZONE_FORWARD.w,
h = Screen:getHeight()*DTAP_ZONE_FORWARD.h, h = Screen:getHeight()*DTAP_ZONE_FORWARD.h,
}, }
} }
}, }
self.ges_events.TapBackward = { self.ges_events.TapBackward = {
GestureRange:new{ GestureRange:new{
ges = "tap", ges = "tap",
@ -870,9 +871,9 @@ function ReaderPaging:updateReadOrder()
y = Screen:getHeight()*DTAP_ZONE_BACKWARD.y, y = Screen:getHeight()*DTAP_ZONE_BACKWARD.y,
w = Screen:getWidth()*DTAP_ZONE_BACKWARD.w, w = Screen:getWidth()*DTAP_ZONE_BACKWARD.w,
h = Screen:getHeight()*DTAP_ZONE_BACKWARD.h, h = Screen:getHeight()*DTAP_ZONE_BACKWARD.h,
}, }
} }
}, }
else else
self.ges_events.TapForward = { self.ges_events.TapForward = {
GestureRange:new{ GestureRange:new{

@ -34,6 +34,7 @@ local ReaderRolling = InputContainer:new{
old_doc_height = nil, old_doc_height = nil,
old_page = nil, old_page = nil,
current_pos = 0, current_pos = 0,
inverse_reading_order = false,
-- only used for page view mode -- only used for page view mode
current_page= nil, current_page= nil,
doc_height = nil, doc_height = nil,
@ -97,7 +98,7 @@ function ReaderRolling:init()
self.ui.menu:registerToMainMenu(self) self.ui.menu:registerToMainMenu(self)
end end
-- This method will be called in onSetDimensions handler -- This method will be called in onSetDimensions handler
function ReaderRolling:initGesListener() function ReaderRolling:initGesListener()
self.ges_events = { self.ges_events = {
TapForward = { TapForward = {
@ -166,6 +167,7 @@ function ReaderRolling:initGesListener()
} }
}, },
} }
self:updateReadOrder()
end end
function ReaderRolling:onReadSettings(config) function ReaderRolling:onReadSettings(config)
@ -207,6 +209,8 @@ function ReaderRolling:onReadSettings(config)
if self.show_overlap_enable == nil then if self.show_overlap_enable == nil then
self.show_overlap_enable = DSHOWOVERLAP self.show_overlap_enable = DSHOWOVERLAP
end end
self.inverse_reading_order = config:readSetting("inverse_reading_order") or false
self:updateReadOrder()
end end
function ReaderRolling:onSaveSettings() function ReaderRolling:onSaveSettings()
@ -215,6 +219,7 @@ function ReaderRolling:onSaveSettings()
self.ui.doc_settings:saveSetting("last_xpointer", self.xpointer) self.ui.doc_settings:saveSetting("last_xpointer", self.xpointer)
self.ui.doc_settings:saveSetting("percent_finished", self:getLastPercent()) self.ui.doc_settings:saveSetting("percent_finished", self:getLastPercent())
self.ui.doc_settings:saveSetting("show_overlap_enable", self.show_overlap_enable) self.ui.doc_settings:saveSetting("show_overlap_enable", self.show_overlap_enable)
self.ui.doc_settings:saveSetting("inverse_reading_order", self.inverse_reading_order)
end end
function ReaderRolling:getLastProgress() function ReaderRolling:getLastProgress()
@ -269,10 +274,22 @@ function ReaderRolling:onTapBackward()
end end
function ReaderRolling:onSwipe(arg, ges) function ReaderRolling:onSwipe(arg, ges)
if ges.direction == "west" or ges.direction == "north" then if ges.direction == "north" then
self:onGotoViewRel(1) self:onGotoViewRel(1)
elseif ges.direction == "east" or ges.direction == "south" then elseif ges.direction == "south" then
self:onGotoViewRel(-1) self:onGotoViewRel(-1)
elseif ges.direction == "west" then
if self.inverse_reading_order then
self:onPagingRel(-1)
else
self:onPagingRel(1)
end
elseif ges.direction == "east" then
if self.inverse_reading_order then
self:onPagingRel(1)
else
self:onPagingRel(-1)
end
end end
end end
@ -525,4 +542,54 @@ function ReaderRolling:updateBatteryState()
end end
end end
function ReaderRolling:updateReadOrder()
if self.inverse_reading_order then
self.ges_events.TapForward = {
GestureRange:new{
ges = "tap",
range = Geom:new{
x = Screen:getWidth()*(1-DTAP_ZONE_FORWARD.x-DTAP_ZONE_FORWARD.w),
y = Screen:getHeight()*DTAP_ZONE_FORWARD.y,
w = Screen:getWidth()*DTAP_ZONE_FORWARD.w,
h = Screen:getHeight()*DTAP_ZONE_FORWARD.h,
}
}
}
self.ges_events.TapBackward = {
GestureRange:new{
ges = "tap",
range = Geom:new{
x = Screen:getWidth()*(1-DTAP_ZONE_BACKWARD.x-DTAP_ZONE_BACKWARD.w),
y = Screen:getHeight()*DTAP_ZONE_BACKWARD.y,
w = Screen:getWidth()*DTAP_ZONE_BACKWARD.w,
h = Screen:getHeight()*DTAP_ZONE_BACKWARD.h,
}
}
}
else
self.ges_events.TapForward = {
GestureRange:new{
ges = "tap",
range = Geom:new{
x = Screen:getWidth()*DTAP_ZONE_FORWARD.x,
y = Screen:getHeight()*DTAP_ZONE_FORWARD.y,
w = Screen:getWidth()*DTAP_ZONE_FORWARD.w,
h = Screen:getHeight()*DTAP_ZONE_FORWARD.h,
}
}
}
self.ges_events.TapBackward = {
GestureRange:new{
ges = "tap",
range = Geom:new{
x = Screen:getWidth()*DTAP_ZONE_BACKWARD.x,
y = Screen:getHeight()*DTAP_ZONE_BACKWARD.y,
w = Screen:getWidth()*DTAP_ZONE_BACKWARD.w,
h = Screen:getHeight()*DTAP_ZONE_BACKWARD.h,
}
}
}
end
end
return ReaderRolling return ReaderRolling

Loading…
Cancel
Save