2012-03-05 01:46:16 +00:00
|
|
|
require "unireader"
|
|
|
|
|
|
|
|
DJVUReader = UniReader:new{
|
|
|
|
newDC = function()
|
|
|
|
print("djvu.newDC")
|
|
|
|
return djvu.newDC()
|
|
|
|
end,
|
|
|
|
}
|
|
|
|
|
|
|
|
function DJVUReader:init()
|
|
|
|
self.nulldc = self.newDC()
|
|
|
|
end
|
|
|
|
|
|
|
|
-- open a DJVU file and its settings store
|
2012-03-05 01:58:19 +00:00
|
|
|
-- DJVU does not support password yet
|
2012-03-05 01:46:16 +00:00
|
|
|
function DJVUReader:open(filename)
|
|
|
|
self.doc = djvu.openDocument(filename)
|
2012-03-05 01:58:19 +00:00
|
|
|
return self:loadSettings(filename)
|
2012-03-05 01:46:16 +00:00
|
|
|
end
|
2012-03-19 03:05:23 +00:00
|
|
|
|
|
|
|
function DJVUReader:_isWordInScreenRange(w)
|
|
|
|
return (self.cur_full_height-(w.y0*self.globalzoom) <=
|
|
|
|
-self.offset_y + width) and
|
|
|
|
(self.cur_full_height-(w.y1*self.globalzoom) >=
|
|
|
|
-self.offset_y)
|
|
|
|
end
|
|
|
|
|
2012-03-19 13:22:45 +00:00
|
|
|
------------------------------------------------
|
|
|
|
-- @text text object returned from doc:getPageText()
|
|
|
|
-- @l0 start line
|
|
|
|
-- @w0 start word
|
|
|
|
-- @l1 end line
|
|
|
|
-- @w1 end word
|
|
|
|
--
|
|
|
|
-- get words from the w0th word in l0th line
|
|
|
|
-- to w1th word in l1th line (not included).
|
|
|
|
------------------------------------------------
|
2012-03-19 03:05:23 +00:00
|
|
|
function DJVUReader:_genTextIter(text, l0, w0, l1, w1)
|
|
|
|
local word_items = {}
|
|
|
|
local count = 0
|
|
|
|
local l = l0
|
|
|
|
local w = w0
|
|
|
|
local tmp_w1 = 0
|
|
|
|
|
2012-03-19 13:22:45 +00:00
|
|
|
print(l0, w0, l1, w1)
|
|
|
|
|
|
|
|
if l0 < 1 or w0 < 1 or l0 > l1 then
|
|
|
|
return function() return nil end
|
|
|
|
end
|
|
|
|
|
2012-03-19 03:05:23 +00:00
|
|
|
-- build item table
|
|
|
|
while l <= l1 do
|
|
|
|
local words = text[l].words
|
|
|
|
|
|
|
|
if l == l1 then
|
2012-03-19 13:22:45 +00:00
|
|
|
tmp_w1 = w1 - 1
|
|
|
|
if tmp_w1 == 0 then
|
|
|
|
break
|
|
|
|
end
|
2012-03-19 03:05:23 +00:00
|
|
|
else
|
|
|
|
tmp_w1 = #words
|
|
|
|
end
|
|
|
|
|
|
|
|
while w <= tmp_w1 do
|
|
|
|
if self:_isWordInScreenRange(words[w]) then
|
|
|
|
table.insert(word_items, words[w])
|
|
|
|
end -- EOF if isInScreenRange
|
|
|
|
w = w + 1
|
|
|
|
end -- EOF while words
|
|
|
|
-- goto next line, reset j
|
|
|
|
w = 1
|
|
|
|
l = l + 1
|
|
|
|
end -- EOF for while
|
|
|
|
|
|
|
|
return function() count = count + 1 return word_items[count] end
|
|
|
|
end
|
|
|
|
|
|
|
|
function DJVUReader:_drawTextHighLight(text_iter)
|
|
|
|
for i in text_iter do
|
2012-03-19 13:22:45 +00:00
|
|
|
fb.bb:invertRect(
|
2012-03-19 03:05:23 +00:00
|
|
|
i.x0*self.globalzoom,
|
|
|
|
self.offset_y+self.cur_full_height-(i.y1*self.globalzoom),
|
|
|
|
(i.x1-i.x0)*self.globalzoom,
|
|
|
|
(i.y1-i.y0)*self.globalzoom, 15)
|
|
|
|
end -- EOF for
|
|
|
|
end
|
|
|
|
|
|
|
|
function DJVUReader:startHighLightMode()
|
|
|
|
local t = self.doc:getPageText(self.pageno)
|
|
|
|
|
2012-03-19 13:22:45 +00:00
|
|
|
local function _nextWord(t, cur_l, cur_w)
|
|
|
|
local new_l = cur_l
|
|
|
|
local new_w = cur_w
|
|
|
|
|
|
|
|
if new_w >= #(t[new_l].words) then
|
|
|
|
-- already the last word, goto next line
|
|
|
|
new_l = new_l + 1
|
|
|
|
if new_l > #t or #(t[new_l].words) == 0 then
|
|
|
|
return cur_l, cur_w
|
|
|
|
end
|
|
|
|
new_w = 1
|
|
|
|
else
|
|
|
|
-- simply move to next word in the same line
|
|
|
|
new_w = new_w + 1
|
|
|
|
end
|
|
|
|
|
|
|
|
return new_l, new_w
|
|
|
|
end
|
|
|
|
|
|
|
|
local function _prevWord(t, cur_l, cur_w)
|
|
|
|
local new_l = cur_l
|
|
|
|
local new_w = cur_w
|
|
|
|
|
|
|
|
if new_w == 1 then
|
|
|
|
-- already the first word, goto previous line
|
|
|
|
new_l = new_l - 1
|
|
|
|
if new_l == 0 or #(t[new_l].words) == 0 then
|
|
|
|
return cur_l, cur_w
|
|
|
|
end
|
|
|
|
new_w = #(t[new_l].words) + 1
|
|
|
|
else
|
|
|
|
-- simply move to previous word in the same line
|
|
|
|
new_w = new_w - 1
|
|
|
|
end
|
|
|
|
|
|
|
|
return new_l, new_w
|
|
|
|
end
|
|
|
|
|
|
|
|
local function _nextLine(t, cur_l, cur_w)
|
|
|
|
local new_l = cur_l
|
|
|
|
local new_w = cur_w
|
|
|
|
|
|
|
|
if new_l >= #t then
|
|
|
|
return cur_l, cur_w
|
|
|
|
end
|
|
|
|
|
|
|
|
new_l = new_l + 1
|
|
|
|
new_w = math.min(new_w, #t[new_l].words+1)
|
|
|
|
|
|
|
|
return new_l, new_w
|
|
|
|
end
|
|
|
|
|
|
|
|
local function _prevLine(t, cur_l, cur_w)
|
|
|
|
local new_l = cur_l
|
|
|
|
local new_w = cur_w
|
|
|
|
|
|
|
|
if new_l == 1 then
|
|
|
|
return cur_l, cur_w
|
|
|
|
end
|
|
|
|
|
|
|
|
new_l = new_l - 1
|
|
|
|
new_w = math.min(new_w, #t[new_l].words+1)
|
|
|
|
|
|
|
|
return new_l, new_w
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
-- next to be marked word position
|
|
|
|
local cur_l = 1
|
|
|
|
--local cur_w = #(t[1].words)
|
|
|
|
local cur_w = 1
|
|
|
|
local new_l = 1
|
|
|
|
local new_w = 1
|
|
|
|
local iter
|
|
|
|
|
|
|
|
while true do
|
|
|
|
local ev = input.waitForEvent()
|
|
|
|
ev.code = adjustKeyEvents(ev)
|
|
|
|
if ev.type == EV_KEY and ev.value == EVENT_VALUE_KEY_PRESS then
|
|
|
|
if ev.code == KEY_FW_RIGHT then
|
|
|
|
new_l, new_w = _nextWord(t, cur_l, cur_w)
|
|
|
|
iter = self:_genTextIter(t, cur_l, cur_w, new_l, new_w)
|
|
|
|
elseif ev.code == KEY_FW_LEFT then
|
|
|
|
new_l, new_w = _prevWord(t, cur_l, cur_w)
|
|
|
|
iter = self:_genTextIter(t, new_l, new_w, cur_l, cur_w)
|
|
|
|
elseif ev.code == KEY_FW_DOWN then
|
|
|
|
new_l, new_w = _nextLine(t, cur_l, cur_w)
|
|
|
|
iter = self:_genTextIter(t, cur_l, cur_w, new_l, new_w)
|
|
|
|
elseif ev.code == KEY_FW_UP then
|
|
|
|
new_l, new_w = _prevLine(t, cur_l, cur_w)
|
|
|
|
iter = self:_genTextIter(t, new_l, new_w, cur_l, cur_w)
|
|
|
|
end
|
|
|
|
self:_drawTextHighLight(iter)
|
|
|
|
fb:refresh(0)
|
|
|
|
cur_l, cur_w = new_l, new_w
|
|
|
|
end
|
|
|
|
end
|
2012-03-19 03:05:23 +00:00
|
|
|
end
|
|
|
|
|