#!./kpdfview --[[ KindlePDFViewer: a reader implementation Copyright (C) 2011 Hans-Werner Hilse This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . ]]-- require "alt_getopt" require "keys" require "tilecache" -- option parsing: longopts = { password = "p", goto = "g", gamma = "G", device = "d", help = "h" } optarg, optind = alt_getopt.get_opts(ARGV, "p:G:hg:d:", longopts) if optarg["h"] or ARGV[optind] == nil then print("usage: ./reader.lua [OPTION] ... DOCUMENT.PDF") print("Read PDFs on your E-Ink reader") print("") print("-p, --password=PASSWORD set password for reading PDF document") print("-g, --goto=page start reading on page") print("-G, --gamma=GAMMA set gamma correction") print(" (floating point notation, e.g. \"1.5\")") print("-d, --device=DEVICE set device specific configuration,") print(" currently one of \"kdxg\" (default), \"k3\"") print("-h, --help show this usage help") print("") print("This software is licensed under the GPLv3.") print("See http://github.com/hwhw/kindlepdfviewer for more info.") return end rcount = 5 rcountmax = 5 globalzoom = -1 globalgamma = -1.0 if optarg["d"] == "k3" then -- for now, the only difference is the additional input device input.open("/dev/input/event0") input.open("/dev/input/event1") input.open("/dev/input/event2") elseif optarg["d"] == "emu" then input.open("") -- SDL key codes set_emu_keycodes() else input.open("/dev/input/event0") input.open("/dev/input/event1") end if optarg["G"] ~= nil then globalgamma = optarg["G"] end doc = pdf.openDocument(ARGV[optind], optarg["p"] or "") print("pdf has "..doc:getPages().." pages.") fb = einkfb.open("/dev/fb0") width, height = fb:getSize() nulldc = pdf.newDC() function setzoom(page, cacheslot) local dc = pdf.newDC() local pwidth, pheight = page:getSize(nulldc) -- default zoom: fit to page local zoom = width / pwidth local offset_x = 0 local offset_y = (height - (zoom * pheight)) / 2 if height / pheight < zoom then zoom = height / pheight offset_x = (width - (zoom * pwidth)) / 2 offset_y = 0 end dc:setZoom(zoom) dc:setOffset(offset_x, offset_y) -- set gamma here, we don't have any other good place for this right now: if globalgamma ~= -1.0 then print("gamma correction: "..globalgamma) dc:setGamma(globalgamma) end return dc end function show(no) local slot = draworcache(no,globalzoom,0,0,width,height,globalgamma) fb:blitFullFrom(cache[slot].bb) if rcount == rcountmax then print("full refresh") rcount = 1 fb:refresh(0) else print("partial refresh") rcount = rcount + 1 fb:refresh(1) end slot_visible = slot; end function goto(no) if no < 1 or no > doc:getPages() then return end pageno = no show(no) if no < doc:getPages() then -- always pre-cache next page draworcache(no+1,globalzoom,0,0,width,height,globalgamma) end end function modify_gamma(offset) if globalgamma == -1 then globalgamma = 1 end print("modify_gamma, gamma="..globalgamma.." offset="..offset) globalgamma = globalgamma + offset; clearcache() goto(pageno) end function mainloop() while 1 do local ev = input.waitForEvent() if ev.type == EV_KEY and ev.value == EVENT_VALUE_KEY_PRESS then local secs, usecs = util.gettime() if ev.code == KEY_PAGEUP then goto(pageno + 1) elseif ev.code == KEY_PAGEDOWN then goto(pageno - 1) elseif ev.code == KEY_BACK then return elseif ev.code == KEY_UP then modify_gamma( 0.2 ) elseif ev.code == KEY_DOWN then modify_gamma( -0.2 ) end local nsecs, nusecs = util.gettime() local dur = (nsecs - secs) * 1000000 + nusecs - usecs print("E: T="..ev.type.." V="..ev.value.." C="..ev.code.." DUR="..dur) end end end goto(tonumber(optarg["g"]) or 1) mainloop()