基于PYQT5的截图翻译工具

功能介绍

  1. 翻译功能
  2. 截图功能(快捷键 + 截图存储到剪切板中)
  3. 文字识别OCR(基于百度API的文字识别)

UI 界面

截图

截图可以使用第三方截图 或 使用PyQt5截图

此文章使用PyQt5的截图

class Snipper(QtWidgets.QWidget):
def __init__(self, parent=None, flags=Qt.WindowFlags()):
super().__init__(parent=parent, flags=flags) self.setWindowTitle("TextShot")
self.setWindowFlags( # 设置窗口属性,窗口置顶
Qt.FramelessWindowHint | Qt.WindowStaysOnTopHint | Qt.Dialog
) self.setWindowState(self.windowState() | Qt.WindowFullScreen)
self.screen = QtGui.QScreen.grabWindow(
QtWidgets.QApplication.primaryScreen(), # 获取当前屏幕分辨率(屏幕大小)
QtWidgets.QApplication.desktop().winId(),
)
palette = QtGui.QPalette() # 调色板QPalette类
palette.setBrush(self.backgroundRole(), QtGui.QBrush(self.screen))
self.setPalette(palette)
# 改变鼠标形状
QtWidgets.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.CrossCursor))
self.start, self.end = QtCore.QPoint(), QtCore.QPoint() def keyPressEvent(self, event):
if event.key() == Qt.Key_Escape:
QtWidgets.QApplication.quit()
return super().keyPressEvent(event) def paintEvent(self, event):
painter = QtGui.QPainter(self)
painter.setPen(Qt.NoPen)
painter.setBrush(QtGui.QColor(0, 0, 0, 100))
painter.drawRect(0, 0, self.width(), self.height()) if self.start == self.end:
return super().paintEvent(event) painter.setPen(QtGui.QPen(QtGui.QColor(255, 255, 255), 3))
painter.setBrush(painter.background())
painter.drawRect(QtCore.QRect(self.start, self.end))
return super().paintEvent(event) def mousePressEvent(self, event):
self.start = self.end = QtGui.QCursor.pos()
self.update()
return super().mousePressEvent(event) def mouseMoveEvent(self, event):
self.end = QtGui.QCursor.pos()
self.update()
return super().mousePressEvent(event) def mouseReleaseEvent(self, event):
if self.start == self.end:
return super().mouseReleaseEvent(event)
self.hide()
QtWidgets.QApplication.processEvents()
if self.start.x() < self.end.x():
shot = self.screen.copy(QtCore.QRect(self.start, self.end))
else:
shot = self.screen.copy(QtCore.QRect(self.end, self.start))
QtWidgets.QApplication.quit()

翻译

翻译功能可以请求百度翻译或者有道翻译,网上有很多这里就不多赘述。

文字识别

文字识别本文字使用的百度云的文字识别OCR 百度云文字识别

全局热键(快捷键)

开启多线程捕获全局全局热键,防止主线程阻塞导致假死。

安装

pip install system_hotkey

示例

from system_hotkey import SystemHotkey
from PyQt5.QtCore import QObject, pyqtSignal, Qt class HotKeyThread(QObject):
trigger = pyqtSignal(str)
def __init__(self):
super().__init__()
# 1. 自定义热键响应
self.trigger.connect(self.hotKeyEvent)
# 2.初始化热键
self.hot_key = SystemHotkey()
# 3.绑定快捷键发送信号
self.hot_key.register(('control','1'),, callback=lambda x: self.sendKeyEvent("按下"))
def sendKeyEvent(self,data):
self.trigger.emit(data)
def hotKeyEvent(self,data):
print("接收信号:{}".format(data))

托盘管理

托盘管理使用pyqt5的 QSystemTrayIcon 实现

class Tray(QSystemTrayIcon):
def __init__(self, UI):
super(Tray, self).__init__()
self.ui = UI
self.setIcon(QIcon('icons/1.ico')) # 托盘图标
self.setToolTip('小工具') # 鼠标移动到托盘图标上的提示
self.activated.connect(self.clickedIcon) # 点击信号
self.menu()
self.show()
def clickedIcon(self,reason):
# reason:鼠标点击托盘图标时传递的整数型信号
# 1表示单击右键
# 2表示双击左键
# 3表示单击左键
# 4表示点击中键
# 下面定义单击左键是弹出或隐藏界面,单击右键是弹出菜单。
if reason == 3:
self.trayClickedEvent()
elif reason == 1:
self.contextMenu()
def menu(self):
menu = QMenu()
action = QAction('退出', self, triggered=self.triggered)
menu.addAction(action)
self.setContextMenu(menu)
def trayClickedEvent(self):
if self.ui.isHidden():
self.ui.setHidden(False)
if self.ui.windowState() == Qt.WindowMinimized:
self.ui.showNormal() # 正常显示窗口
self.ui.raise_() # 控制在上层
self.ui.activateWindow() # 活动窗口
else:
self.ui.setHidden(True) # 设置隐藏窗口
def triggered(self):
self.deleteLater() # 删除托盘图标,无此操作的话,程序退出后托盘图标不会自动清除
qApp.quit() # 会重写closeEvent,换一个退出程序的命令

主代码

import sys
import time
from tray import Tray
from ui import Ui_MainWindow
from demo import translate,Child_Dialog from PyQt5.QtGui import QIcon
from PyQt5.QtCore import QThread,pyqtSignal,Qt
from PyQt5.QtWidgets import QApplication,QSystemTrayIcon,QMenu,QAction,qApp class HotKeyThread(QThread,SystemHotkey):
# 开启多线程全局热键
trigger = pyqtSignal()
def __init__(self,UI):
self.ui = UI
super(HotKeyThread,self).__init__()
self.register(('control', '1'), callback=lambda x: self.start())
self.trigger.connect(self.hotKeyEvent) def run(self):
self.trigger.emit() def hotKeyEvent(self):
self.ui.screenshots_and_translate() class MainFunction(Ui_MainWindow):
# 主程序
def __init__(self):
super().__init__()
self.trigger() def trigger(self):
self.status = False
self.tray = Tray(self)
self.hotKey = HotKeyThread(self)
self.pushButton_2.setToolTip("截图(Ctrl+1)") # 给按钮2 添加提示气泡,显示快捷键方法
self.pushButton_1.clicked.connect(self.screenshots_and_translate) # 按钮1 翻译
self.pushButton_2.clicked.connect(self.screenshots_and_translate) # 按钮2 截图 def screenshots_and_translate(self):
butname = self.sender().objectName()
if butname == "pushButton1":
text = self.textedit.toPlainText()
res = None
if len(text) > 0:
res = translate(text)
self.textBrowser.setText(res)
else:
if not self.status:
self.status = True
self.showMinimized()
time.sleep(0.5)
self.activateWindow()
self.child_window = Child_Dialog(self) # 截图
self.child_window.dialogSignel.connect(self.slot_emit)
self.child_window.show() def slot_emit(self, flag, str):
self.activateWindow()
self.showNormal()
self.status = False
if flag == 1:
if self.checkBox.isChecked():
res = translate(str)
else:
res = str
self.textBrowser.setText(res) def closeEvent(self,QCloseEvent):
QCloseEvent.ignore()
self.hide() if __name__ == '__main__':
app = QApplication(sys.argv)
ex = MainFunction()
sys.exit(app.exec_())

基于PYQT5的截图翻译工具的更多相关文章

  1. 制作属于自己的翻译软件(基于PyQt5+Python+实时翻译)

    目录 制作属于自己的翻译软件(基于PyQt5+Python+实时翻译) 翻译软件上传到github上. 软件截图 主要的思想 界面方面 程序方面 制作属于自己的翻译软件(基于PyQt5+Python+ ...

  2. 基于百度翻译API开发属于自己的翻译工具

    你是否每天使用着网页翻译工具?你是否遇到过这种情况,上网过程中遇到一个很长的单词但是又不能复制,要开两个浏览器,一个打开百度翻译,照着另一个网页输入单词?你安装了各种翻译软件后,又删除,只因忍受不了那 ...

  3. You-Get——基于Python3的媒体下载工具

    You-Get是一个基于 Python 3 的下载工具.使用 You-Get 可以很轻松的下载到网络上的视频.图片及音乐. 项目主页:https://github.com/soimort/you-ge ...

  4. 基于WebServices简易网络聊天工具的设计与实现

    基于WebServices简易网络聊天工具的设计与实现 Copyright 朱向洋 Sunsea ALL Right Reserved 一.项目内容 本次课程实现一个类似QQ的网络聊天软件的功能:服务 ...

  5. 基于OpenCL的深度学习工具:AMD MLP及其使用详解

    基于OpenCL的深度学习工具:AMD MLP及其使用详解 http://www.csdn.net/article/2015-08-05/2825390 发表于2015-08-05 16:33| 59 ...

  6. 简单翻译工具--必应词典第三方api使用方法

    之前做过一个桌面翻译工具,桌面每日一句--桌面翻译工具(有道翻译,微软翻译,Google翻译) 获取金山每日一句,目前因为 金山每日一句页面改变导致每日一句功能失败,不过这工具自己用得最多的还是翻译功 ...

  7. Hive -- 基于Hadoop的数据仓库分析工具

    Hive是一个基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,通过类SQL语句快速实现简单的MapReduce统计,不必开发专门的MapReduce应用,十分适合数据仓库 ...

  8. Processon 一款基于HTML5的在线作图工具

    CSDN的蒋涛不久前在微博上评价说ProcessOn是web版的visio,出于好奇私下对ProcessOn进行了一番研究.最后发现无论是在用户体验上,还是在技术上,ProcessOn都比微软的Vis ...

  9. 基于Web的IIS管理工具

    Servant:基于Web的IIS管理工具   Servant for IIS是个管理IIS的简单.自动化的Web管理工具.安装Servant的过程很简单,只要双击批处理文件Install Serva ...

随机推荐

  1. Java/C++实现装饰模式---模拟手机功能的升级过程

    用装饰模式模拟手机功能的升级过程:简单的手机(SimplePhone)在接收来电时,会发出声音提醒主人:而JarPhone除了声音还能振动:更高级的手机(ComplexPhone)除了声音.振动外,还 ...

  2. java中什么是局部内部类Local inner class?

    5.局部内部类Local inner class 马克-to-win:什么叫局部内部类?内部类声明位置:1.它的外部类的范围之内.2.在几个程序块的范围之内.例如,由方法定义的块中或甚至在for循环体 ...

  3. 使用 ssm 实现登录日志记录

    使用 ssm 实现登录日志记录 学习总结 一.基础准备 1. 实现效果 2. 数据表 2.1 登陆日志信息表 2.3 员工表 二.代码实现 1. SysLogLogin 实体类 2. LogAspec ...

  4. window nginx 简单搭建服务器访问静态资源

    nginx命令: 启动: start nginx 停止:nginx -s stop ||  nginx -s quit 注:stop是快速停止nginx,可能并不保存相关信息:quit是完整有序的停止 ...

  5. css实现超出部分显示省略号

     /* 显示一行,省略号 */       white-space: nowrap;     text-overflow: ellipsis;     overflow: hidden;     wo ...

  6. nodejs创建服务器

      'use strict'; //加载http模块: const http = require('http'); //创建一个http服务: const server = http.createSe ...

  7. 第一阶段:Java基础之异常和处理

    文章目录 Java中异常处理机制的简单和应用 一.异常的体系结构&分类 二.问题扩展 三.应用场景 Java中异常处理机制的简单和应用 异常也是一种对象,Java中有很多异常类,并且定义了基类 ...

  8. nacos集群模式搭建踩坑记录

    首先数据库使用的本地的mysql 1.看日志提示no set datasource,使用虚拟机ping本地后发现无法ping通,原因是本地没有关闭防火墙. 2.看日志提示不允许建立数据库连接,原因是r ...

  9. Python数据展示 - 生成表格图片

    前言 前一篇文章介绍了推送信息到企业微信群里,其中一个项目推送的信息是使用Python自动生成的表格,本文来讲讲如何用Python生成表格图片. 选一个合适库 Python最大的优点就是第三方库丰富, ...

  10. Java语言学习day26--7月01日

    ###14内部类 * A: 内部类的概述 将类写在其他类的内部,可以写在其他类的成员位置和局部位置,这时写在其他类内部的类就称为内部类. 其他类也称为外部类. * B: 什么时候使用内部类 在描述事物 ...