From c0fb71b99b70bc3c0e52f4c52d61cb895668ff2b Mon Sep 17 00:00:00 2001 From: Lucian Branescu Mihaila Date: Mon, 19 Jul 2010 16:28:10 +0000 Subject: Dumb down clever trick in webtoolbar.py. Flesh out pdfview with a better test harness. --- (limited to 'pdfview.py') 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() -- cgit v0.9.1