Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/pdfview.py
diff options
context:
space:
mode:
authorLucian Branescu Mihaila <lucian.branescu@gmail.com>2010-07-19 16:28:10 (GMT)
committer Lucian Branescu Mihaila <lucian.branescu@gmail.com>2010-07-19 16:28:10 (GMT)
commitc0fb71b99b70bc3c0e52f4c52d61cb895668ff2b (patch)
tree5792d2160d4d28a0d5419f32e13ce9a4ebb5839c /pdfview.py
parent90605dd362635ea334f9c25d6c9f5d8dea3e8614 (diff)
Dumb down clever trick in webtoolbar.py. Flesh out pdfview with a better test harness.
Diffstat (limited to 'pdfview.py')
-rw-r--r--pdfview.py74
1 files changed, 68 insertions, 6 deletions
diff --git a/pdfview.py b/pdfview.py
index 3c63d14..8d1afed 100644
--- a/pdfview.py
+++ b/pdfview.py
@@ -14,33 +14,95 @@
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+import sys
+from gettext import gettext as _
+
import gtk
import evince
-def get_view(uri='file:///home/lucian/test.pdf'):
+from sugar.graphics.toolbutton import ToolButton
+
+def _get_ev_view():
view = evince.View()
try: # assuming evince 2.30
doc = evince.document_factory_get_document(uri)
model = evince.DocumentModel()
model.set_document(doc)
-
view.set_model(model)
+
except AttributeError: # we're probably on evince 2.28 or older
doc = evince.factory_get_document(uri)
view.set_document(doc)
return view
+class PDFView(gtk.VBox):
+ __gtype_name__ = 'PDFView'
+
+ def __init__(self, uri):
+ super(PDFView, self).__init__()
+
+ self.uri = uri
+ self._ev_view = _get_ev_view(uri)
+
+ self._toolbar = PDFToolbar(self._ev_view)
+ self.pack_start(self._toolbar)
+ self._toolbar.show()
+
+ self.pack_start(self._ev_view)
+ self._ev_view.show()
+
+class PDFToolbar(gtk.Toolbar):
+ def __init__(self, ev_view):
+ super(PDFToolbar, self).__init__()
+
+ self._ev_view = ev_view
+
+ self.journal = ToolButton('save')
+ self.journal.set_tooltip(_('Save to Journal'))
+ self.journal.connect('clicked', self.__journal_clicked_cb)
+ self.insert(self.journal, -1)
+ self.journal.show()
+
+ self.separator = gtk.SeparatorToolItem()
+ self.separator.set_draw(True)
+ self.insert(self.separator, -1)
+ self.separator.show()
+
+ self.zoomout = ToolButton('zoom-out')
+ self.zoomout.set_tooltip(_('Zoom out'))
+ self.zoomout.connect('clicked', self.__zoomout_clicked_cb)
+ self.insert(self.zoomout, -1)
+ self.zoomout.show()
+
+ self.zoomin = ToolButton('zoom-in')
+ self.zoomin.set_tooltip(_('Zoom in'))
+ self.zoomin.connect('clicked', self.__zoomin_clicked_cb)
+ self.insert(self.zoomin, -1)
+ self.zoomin.show()
+
+ def __zoomin_clicked_cb(self, button):
+ self._ev_view.zoom_in()
+
+ def __zoomout_clicked_cb(self, button):
+ self._ev_view.zoom_out()
+
+ def __journal_clicked_cb(self, button):
+ pass
+
if __name__ == '__main__':
win = gtk.Window(gtk.WINDOW_TOPLEVEL)
win.set_size_request(400, 300)
win.connect('destroy', gtk.main_quit)
- win.show()
-
- v = get_view()
- win.add(v)
+ if len(sys.argv) > 1:
+ v = PDFView(sys.argv[1])
+ else:
+ v = PDFView('file:///home/lucian/test.pdf')
v.show()
+
+ win.add(v)
+ win.show_all()
gtk.main()