基于PyQt5制作一个截图翻译工具

 更新时间:2022年05月31日 10:33:24   作者:Hp_mzx  
这篇文章主要为大家介绍了如何利用PyQt5制作一个简单的截图翻译工具,具有截图功能、翻译功能和文字识别OCR,需要的可以参考一下

功能介绍

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制作一个截图翻译工具的文章就介绍到这了,更多相关PyQt5截图翻译内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 利用Python批量生成任意尺寸的图片

    利用Python批量生成任意尺寸的图片

    不知道大家有没有遇到过,因检验需要1000张,分别从1*1到1000*1000像素的图片。搜索一番过后发现还是Python实现比较方便,遂决定用Python实现这一功能,下面分享给大家,有需要的可以参考。
    2016-08-08
  • python turtle库画圣诞树详细代码教程

    python turtle库画圣诞树详细代码教程

    这篇文章主要介绍了python turtle库画圣诞树详细代码教程,圣诞节快到了,下面小编就来利用python turtle库画一颗圣诞树, 主要成分有圣诞树的本体、大小蝴蝶结、星星、圣诞帽和袜子,需要的朋友可以参考一下
    2021-12-12
  • Python纯代码通过神经网络实现线性回归的拟合方式

    Python纯代码通过神经网络实现线性回归的拟合方式

    这篇文章主要介绍了Python纯代码通过神经网络实现线性回归的拟合方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • 图文详解感知机算法原理及Python实现

    图文详解感知机算法原理及Python实现

    感知机是二类分类的线性分类模型,其输入为实例的特征向量,输出为实例的类别(取+1和-1二值)。本文将为大家详细讲讲感知机算法的原理及实现,需要的可以参考一下
    2022-08-08
  • Python调用C语言的实现

    Python调用C语言的实现

    这篇文章主要介绍了Python调用C语言的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • python flask开发的简单基金查询工具

    python flask开发的简单基金查询工具

    基于python flask开发的简单基金查询工具,支持大盘指数实时情况查看,总持仓实际涨幅、预估涨幅等功能,感兴趣的朋友可以下载该项目来查看使用
    2021-06-06
  • python 实现以相同规律打乱多组数据

    python 实现以相同规律打乱多组数据

    这篇文章主要介绍了python 实现以相同规律打乱多组数据,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • 使用Python实现快速搭建本地HTTP服务器

    使用Python实现快速搭建本地HTTP服务器

    这篇文章主要介绍了如何使用Python快速搭建本地HTTP服务器,轻松实现一键 HTTP 文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了解下
    2025-04-04
  • python中单下划线与双下划线的区别及说明

    python中单下划线与双下划线的区别及说明

    这篇文章主要介绍了python中单下划线与双下划线的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Python多维/嵌套字典数据无限遍历的实现

    Python多维/嵌套字典数据无限遍历的实现

    下面小编就为大家带来一篇Python多维/嵌套字典数据无限遍历的实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11

最新评论