class TrayIco: def __init__(self): self.menu_options = (("Open window", None, restore), ) self.tray_instance = SysTrayIcon(resource_path("ghost.ico"), "Ready!", self.menu_options, on_quit=ask_quit) def init_icon_tray(self): self.tray_instance.start() def kill_icon_tray(self): self.tray_instance.shutdown() def tip_info(self, text='Example', coords=(0, 0)): self.text = text self.tip = Toplevel(root) if coords == (0, 0): x1, y1 = work_area[2] - 310, work_area[3] - 20 coords = (x1, y1) self.tip.wm_overrideredirect(1) self.tip.wm_geometry("+%d+%d" % coords) label = Label(self.tip, text=self.text, justify=LEFT, foreground="white", background=theme_color, relief=SOLID, borderwidth=2, font=("tahoma", "9", "normal")) label.pack(ipadx=1) self.tip.after(1200, self.tip_kill) def tip_kill(self): self.tip.after(1400, lambda: self.tip.wm_attributes('-alpha', 0.6)) self.tip.after(1600, lambda: self.tip.wm_attributes('-alpha', 0.5)) self.tip.after(1800, lambda: self.tip.wm_attributes('-alpha', 0.3)) self.tip.after(2000, lambda: self.tip.wm_attributes('-alpha', 0.2)) self.tip.after(2200, lambda: self.tip.wm_attributes('-alpha', 0.1)) self.tip.after(2400, self.tip.destroy)
class WindowsSystemTray(object): def __init__(self): self.image_dir = os.path.join(plexpy.PROG_DIR, 'data/interfaces/', plexpy.CONFIG.INTERFACE, 'images') if plexpy.UPDATE_AVAILABLE: self.icon = os.path.join(self.image_dir, 'logo-circle-update.ico') self.hover_text = common.PRODUCT + ' - Update Available!' else: self.icon = os.path.join(self.image_dir, 'logo-circle.ico') self.hover_text = common.PRODUCT if plexpy.CONFIG.LAUNCH_STARTUP: launch_start_icon = os.path.join(self.image_dir, 'check-solid.ico') else: launch_start_icon = None if plexpy.CONFIG.LAUNCH_BROWSER: launch_browser_icon = os.path.join(self.image_dir, 'check-solid.ico') else: launch_browser_icon = None self.menu = [['Open Tautulli', None, self.tray_open, 'default'], ['', None, 'separator', None], [ 'Start Tautulli at Login', launch_start_icon, self.tray_startup, None ], [ 'Open Browser when Tautulli Starts', launch_browser_icon, self.tray_browser, None ], ['', None, 'separator', None], ['Check for Updates', None, self.tray_check_update, None], ['Restart', None, self.tray_restart, None]] if not plexpy.FROZEN: self.menu.insert(6, ['Update', None, self.tray_update, None]) self.tray_icon = SysTrayIcon(self.icon, self.hover_text, self.menu, on_quit=self.tray_quit) def start(self): logger.info("Launching Windows system tray icon.") try: self.tray_icon.start() except Exception as e: logger.error("Unable to launch system tray icon: %s." % e) def shutdown(self): self.tray_icon.shutdown() def update(self, **kwargs): self.tray_icon.update(**kwargs) def tray_open(self, tray_icon): plexpy.launch_browser(plexpy.CONFIG.HTTP_HOST, plexpy.HTTP_PORT, plexpy.HTTP_ROOT) def tray_startup(self, tray_icon): plexpy.CONFIG.LAUNCH_STARTUP = not plexpy.CONFIG.LAUNCH_STARTUP set_startup() def tray_browser(self, tray_icon): plexpy.CONFIG.LAUNCH_BROWSER = not plexpy.CONFIG.LAUNCH_BROWSER set_startup() def tray_check_update(self, tray_icon): versioncheck.check_update() def tray_update(self, tray_icon): if plexpy.UPDATE_AVAILABLE: plexpy.SIGNAL = 'update' else: hover_text = common.PRODUCT + ' - No Update Available' self.update(hover_text=hover_text) def tray_restart(self, tray_icon): plexpy.SIGNAL = 'restart' def tray_quit(self, tray_icon): plexpy.SIGNAL = 'shutdown' def change_tray_update_icon(self): if plexpy.UPDATE_AVAILABLE: self.icon = os.path.join(self.image_dir, 'logo-circle-update.ico') self.hover_text = common.PRODUCT + ' - Update Available!' else: self.icon = os.path.join(self.image_dir, 'logo-circle.ico') self.hover_text = common.PRODUCT + ' - No Update Available' self.update(icon=self.icon, hover_text=self.hover_text) def change_tray_icons(self): if plexpy.CONFIG.LAUNCH_STARTUP: launch_start_icon = os.path.join(self.image_dir, 'check-solid.ico') else: launch_start_icon = None if plexpy.CONFIG.LAUNCH_BROWSER: launch_browser_icon = os.path.join(self.image_dir, 'check-solid.ico') else: launch_browser_icon = None self.menu[2][1] = launch_start_icon self.menu[3][1] = launch_browser_icon self.update(menu_options=self.menu)
def __init__(self): '''GUI的初始化 ''' self.logger = logging.getLogger(__name__) self.logger.info("开始记录日志") try: self.logger.info("开始检查网络连接") # requests.get("https://www.baidu.com", verify=False) # 访问百度以验证网络是否通畅 # self.logger.info("网络连接成功") self.logger.info("开始加载配置文件") self.cf = Config() self.APP_ID = self.cf.APP_ID self.API_KEY = self.cf.API_KEY self.SECRET_KEY = self.cf.SECRET_KEY self.MK_APIKEY = self.cf.MK_APIKEY self.logger.info("开始加载窗体") self.window = tk.Tk() self.window.title('截图翻译工具(V4.5)') self.window.attributes("-alpha", 0.9) self.window['background'] = 'PowderBlue' self.filename = resource_path(os.path.join("res", "bitbug_favicon.ico")) self.window.iconbitmap(self.filename) self.window.resizable(0, 0) self.menubar = tk.Menu(self.window) self.filemenu = tk.Menu(self.menubar, tearoff=0) self.menubar.add_cascade(label='导入文件', menu=self.filemenu) self.filemenu.add_command(label='从文本文件导入', command=self.getFromTXT) self.filemenu.add_command(label='从图像文件导入', command=self.getFromImage) self.setmenu = tk.Menu(self.menubar, tearoff=0) self.menubar.add_cascade(label='设置', menu=self.setmenu) self.setmenu.add_command(label='查看APP_ID', command=self.getAppId) self.setmenu.add_command(label='生成配置文件', command=self.useConfig) self.picButton = tk.IntVar() self.picButton.set(0) self.setmenu.add_checkbutton(label='只监听图片', variable=self.picButton) self.helpmenu = tk.Menu(self.menubar, tearoff=0) self.menubar.add_cascade(label='帮助', menu=self.helpmenu) self.helpmenu.add_command(label='关于', command=self.aboutClick) self.helpmenu.add_command(label='更新与反馈', command=self.upClick) self.window.config(menu=self.menubar) tk.Label(self.window, text="原文:", background='PowderBlue').grid( row=0, column=0, sticky=tk.W) self.comboxlist0 = ttk.Combobox(self.window) self.comboxlist0["values"] = ("使用百度翻译","使用谷歌翻译", "C/C++代码美化") self.comboxlist0.bind("<<ComboboxSelected>>", self.comboxlist0_msg) self.comboxlist0["state"] = "readonly" self.comboxlist0.current(0) self.comboxlist0.grid(row=0, column=0, columnspan=2, padx=38, sticky=tk.W) self.comboxlist = ttk.Combobox(self.window) self.comboxlist["values"] = ("翻译为中文(简体)", "翻译为中文(繁体)", "翻译为英文", "翻译为日文", "翻译为韩文") self.comboxlist["state"] = "readonly" self.comboxlist.current(0) self.comboxlist.grid(row=0, column=1, sticky=tk.E) self.inputText = tk.Text(self.window, height=12, width=50) self.inputText.grid(row=1, column=0, columnspan=2, padx=8, pady=8) self.inputTextsection = section() self.inputTextsection.s = self.inputText self.inputTextmenu = tk.Menu(self.window, tearoff=0) self.inputTextmenu.add_command(label="复制", command=self.inputTextsection.onCopy) self.inputTextmenu.add_separator() self.inputTextmenu.add_command(label="粘贴", command=self.inputTextsection.onPaste) self.inputTextmenu.add_separator() self.inputTextmenu.add_command(label="剪切", command=self.inputTextsection.onCut) self.inputText.bind("<Button-3>", lambda event: self.inputTextmenu.post(event.x_root, event.y_root)) tk.Label(self.window, text="译文:", background='PowderBlue').grid( row=2, column=0, sticky=tk.W) self.translateBtn = tk.Button( self.window, text="翻译", bg='Lavender', command=self.translateBtnClick) self.translateBtn.grid(row=2, column=0, padx=40, sticky=tk.W) self.OCRLANGUAGE = 'eng' self.comboxlist1 = ttk.Combobox(self.window) self.comboxlist1["values"] = ("使用百度OCR") self.comboxlist1.bind("<<ComboboxSelected>>", self.comboxlist1_OCR) self.comboxlist1["state"] = "readonly" self.comboxlist1.current(0) self.comboxlist1.grid(row=2, column=0, padx=80, columnspan=2, sticky=tk.W) self.clearBtn = tk.Button( self.window, text="清屏", bg='Lavender', command=self.clearBtnClick) self.clearBtn.grid(row=2, column=1, padx=90, sticky=tk.E) self.cb1var = tk.IntVar() self.cb1var.set(1) self.cb1 = tkinter.Checkbutton( self.window, text='监听剪切板', background='PowderBlue', variable=self.cb1var) self.cb1.grid(row=2, column=0, columnspan=2, sticky=tk.E) self.outText = tk.Text(self.window, height=12, width=50) self.outText.grid(row=3, column=0, columnspan=2, padx=8, pady=8) self.outTextsection = section() self.outTextsection.s = self.outText self.outTextmenu = tk.Menu(self.window, tearoff=0) self.outTextmenu.add_command(label="复制", command=self.outTextsection.onCopy) self.outTextmenu.add_separator() self.outTextmenu.add_command(label="粘贴", command=self.outTextsection.onPaste) self.outTextmenu.add_separator() self.outTextmenu.add_command(label="剪切", command=self.outTextsection.onCut) self.outText.bind("<Button-3>", lambda event: self.outTextmenu.post(event.x_root, event.y_root)) # self.window.bind(sequence="<Key>", func=self.outTexeP) self.window.state('normal') self.window.wm_attributes('-topmost', 1) self.window.protocol("WM_DELETE_WINDOW", self.on_closing) self.menu_options = (("显示", None, self.showwin),) systray = SysTrayIcon(self.filename, "截图翻译工具", self.menu_options, on_quit=self.on_quit_callback) systray.start() self.logger.info("窗体加载成功") self.logger.info("开始加载插件模块") self.maindll = WinDLL(resource_path(os.path.join("res", "pymain.dll"))) dlllist = [i for i in glob.glob(r"*.dll") if i[0]=='p' and i[1] == 'y'] self.logger.info("搜寻到如下插件{0}" .format(str(dlllist))) self.logger.info("开始载入dll") self.dlllist = [] s = create_string_buffer(''.encode(), 8192) #in dll is 8192 for i in dlllist: self.logger.info("正在载入{0}".format(i)) dll = WinDLL(os.path.join(os.getcwd(), i)) self.dlllist.append(dll) self.logger.info("载入{0}成功".format(i)) self.logger.info("正在获取{0}的名字".format(i)) s = create_string_buffer(''.encode(), 9000) #in dll is 8192 dll.name(s) s = string_at(s).decode('utf-8') self.logger.info("{0}的名字为:{1}".format(i,s)) self.comboxlist0["values"] = self.comboxlist0["values"] + (s,) self.logger.info("开始启动插件事件监听线程") _thread.start_new_thread(self.apiloop, ("",)) # 用于插件的监听 self.logger.info("插件事件监听线程启动成功") self.logger.info("开始启动剪切板事件监听线程") _thread.start_new_thread(self.thread_fun, (self.window, self.inputText, self.outText)) self.logger.info("剪切板事件监听线程启动成功") self.logger.info("进入窗体消息循环") self.window.mainloop() except Exception as e: self.logger.error(str(e)) tk.messagebox.showerror( title="致命错误", message="请将具体信息发送给开发者:\n网页:https://github.com/super1207/translate\n错误信息:" + str(e))