def item_activated_cb(self, gl, item): h = item.data menu = Menu(self.win) menu.item_add( None, "Resume" if h.is_paused() else "Pause", None, self.resume_torrent_cb if h.is_paused() else self.pause_torrent_cb, h) q = menu.item_add(None, "Queue", None, None) menu.item_add(q, "Up", None, lambda x, y: h.queue_position_up()) menu.item_add(q, "Down", None, lambda x, y: h.queue_position_down()) menu.item_add(q, "Top", None, lambda x, y: h.queue_position_top()) menu.item_add(q, "Bottom", None, lambda x, y: h.queue_position_bottom()) rem = menu.item_add(None, "Remove torrent", None, self.remove_torrent_cb, item, h, False) menu.item_add(rem, "and data files", None, self.remove_torrent_cb, item, h, True) menu.item_add(None, "Force re-check", None, self.force_recheck, h) menu.item_separator_add(None) menu.item_add(None, "Torrent preferences", None, self.torrent_preferences_cb, h) menu.move(*self.win.evas.pointer_canvas_xy_get()) menu.show()
def cb_map_mouse_down(Map, evtinfo): (x,y) = evtinfo.position.canvas (lon, lat) = Map.canvas_to_region_convert(x, y) if evtinfo.button == 3: m = Menu(Map) mi = m.item_add(None, "Lat: %f" % lat) mi.disabled = True mi = m.item_add(None, "Lon: %f" % lon) mi.disabled = True mi = m.item_add(None, "Move") m.item_add(mi, "Show Sydney", None, cb_menu_show, Map, 151.175274, -33.859126) m.item_add(mi, "Show Paris", None, cb_menu_show, Map, 2.342913, 48.853701) m.item_add(mi, "Bringin Sydney", None, cb_menu_bringin, Map, 151.175274, -33.859126) m.item_add(mi, "Bringin Paris", None, cb_menu_bringin, Map, 2.342913, 48.853701) mi = m.item_add(None, "Add overlay") m.item_add(mi, "Normal", None, cb_menu_overlay_normal, Map, lon, lat) m.item_add(mi, "Icon", None, cb_menu_overlay_icon, Map, lon, lat) m.item_add(mi, "Custom content", None, cb_menu_overlay_custom, Map, lon, lat) m.item_add(mi, "Random color", None, cb_menu_overlay_random_color, Map, lon, lat) m.item_add(mi, "Min zoom 4", None, cb_menu_overlay_min_zoom, Map, lon, lat) m.item_add(mi, "16 grouped", None, cb_menu_overlay_grouped, Map, lon, lat) m.item_add(mi, "Bubble attached", None, cb_menu_overlay_bubble, Map, lon, lat) m.item_add(mi, "Line", None, cb_menu_overlay_line, Map, lon, lat) m.item_add(mi, "Polygon", None, cb_menu_overlay_poly, Map, lon, lat) m.item_add(mi, "Circle", None, cb_menu_overlay_circle, Map, lon, lat) m.item_add(mi, "Scale", None, cb_menu_overlay_scale, Map, x, y) mi = m.item_add(None, "Overlays") m.item_add(mi, "Clear", None, cb_menu_overlays_clear, Map) m.item_add(mi, "Show (BROKEN)", None, cb_menu_overlays_show, Map) m.item_add(mi, "ungroup (BROKEN)", None, cb_menu_overlays_ungroup, Map) mi = m.item_add(None, "Route") m.item_add(mi, "Set start point", None, cb_menu_route_start, Map, lon, lat) m.item_add(mi, "Set end point", None, cb_menu_route_end, Map, lon, lat) m.move(x, y) m.show()
def __init__(self, parent, path, pos=None, zoom=1.0): self.doc_path = path self._zoom = zoom self.doc_pos = pos self.pages = [] self.doc = None self.doc_title = os.path.splitext(os.path.basename(path))[0] self.visible_pages = [] super(Document, self).__init__(parent, size_hint_weight=EXPAND_BOTH, size_hint_align=FILL_BOTH) scr = self.scr = Scroller(self, size_hint_weight=EXPAND_BOTH, size_hint_align=FILL_BOTH) scr.callback_scroll_add(self._scrolled) self.pack(scr, 0, 0, 4, 1) scr.show() box = self.page_box = Box(scr, size_hint_weight=EXPAND_BOTH, size_hint_align=(0.5, 0.0)) scr.content = box self.on_resize_add(self._resized) btn = Button(self, text="Toggle outlines", size_hint_align=ALIGN_LEFT) btn.callback_clicked_add(lambda x: self.ol_p.toggle()) self.pack(btn, 0, 1, 1, 1) btn.show() spn = self.spn = Spinner(self, round=1.0, size_hint_weight=EXPAND_HORIZ, size_hint_align=FILL_HORIZ) spn.special_value_add(1, "First") spn.editable = True self.pack(spn, 1, 1, 1, 1) spn.show() btn = Button(self, text="show page", size_hint_weight=EXPAND_HORIZ, size_hint_align=ALIGN_LEFT) btn.callback_clicked_add(self._show_page_cb, spn) self.pack(btn, 2, 1, 1, 1) btn.show() menu = Menu(self.top_widget) menu.item_add(None, "Zoom In", "zoom-in", lambda x, y: self.zoom_in()) menu.item_add(None, "Zoom Out", "zoom-out", lambda x, y: self.zoom_out()) menu.item_add(None, "Zoom 1:1", "zoom-original", lambda x, y: self.zoom_orig()) menu.item_add(None, "Zoom Fit", "zoom-fit-best", lambda x, y: self.zoom_fit()) def z_clicked(btn): x, y = btn.evas.pointer_canvas_xy_get() menu.move(x, y) menu.show() zlbl = self.zlbl = Button(self, text="%1.0f %%" % (self.zoom * 100.0), size_hint_weight=EXPAND_HORIZ, size_hint_align=ALIGN_RIGHT) zlbl.callback_clicked_add(z_clicked) self.pack(zlbl, 3, 1, 1, 1) zlbl.show() n = self.page_notify = Notify(scr, align=(0.02, 0.02)) b = Box(n, horizontal=True, padding=(6, 0)) n.content = b n = self.load_notify = Notify(scr, align=(0.98, 0.98)) pb = Progressbar(n, pulse_mode=True, style="wheel") n.content = pb pb.pulse(True) n.show() p = self.ol_p = Panel( self, orient=ELM_PANEL_ORIENT_LEFT, size_hint_weight=EXPAND_BOTH, size_hint_align=FILL_BOTH, ) #scrollable=True, scrollable_content_size=0.35) p.hidden = True scr.on_move_add(lambda x: p.move(*x.pos)) scr.on_resize_add(lambda x: p.resize(x.size[0] * 0.35, x.size[1])) ol_gl = self.ol_gl = Genlist(p, size_hint_weight=EXPAND_BOTH, size_hint_align=FILL_BOTH, mode=ELM_LIST_COMPRESS, homogeneous=True, select_mode=ELM_OBJECT_SELECT_MODE_ALWAYS) p.content = ol_gl ol_gl.callback_contract_request_add(self._gl_contract_req) ol_gl.callback_contracted_add(self._gl_contracted) ol_gl.callback_expand_request_add(self._gl_expand_req) ol_gl.callback_expanded_add(self._gl_expanded) ol_gl.show() p.show() self.show() def read_worker(): t1 = self.t1 = time.clock() try: self.doc = PyPDF2.PdfFileReader(path) self.page_count = self.doc.getNumPages() except Exception as e: log.exception("Document could not be opened because: %r", e) self.doc = None self.display_error(e) return t2 = time.clock() log.info("Reading the doc took: %f", t2 - t1) t = Thread(target=read_worker) t.daemon = True t.start() def worker_check(t): if t.is_alive(): return True elif self.doc and self.page_count: spn.special_value_add(self.page_count, "Last") spn.min_max = (1, self.page_count) if self.doc.isEncrypted: PasswordPrompt(self) return False self.metadata_read() self.populate_pages() return False timer = Timer(0.2, worker_check, t) self.parent.callback_delete_request_add(lambda x: timer.delete())