Pot (派了个萌的翻译器)

🌈 一个跨平台的划词翻译软件 ( QQ 频道 )

  • 支持插件系统 ( 插件系统 )
  • 支持所有 PC 平台 (Windows, macOS, Linux)
  • 支持 Wayland (在 KDE、Gnome 以及 Hyprland 上测试)
  • 多语言支持
  • OpenAI
  • 智谱 AI
  • Gemini Pro
  • Ollama (离线)
  • 腾讯翻译君
  • 腾讯交互翻译
  • Google
  • Bing 词典
  • DeepL
  • Yandex
  • Lingva ( 插件 )
  • Tatoeba ( 插件 )
  • ECDICT ( 插件 )
  • 更多接口支持见 插件系统

  • 系统 OCR (离线)
  • Windows.Media.OCR on Windows
  • Apple Vision Framework on MacOS
  • Tesseract OCR on Linux
  • Tesseract.js (离线)
  • 腾讯图片翻译
  • 百度图片翻译
  • Simple LaTeX
  • OCRSpace ( 插件 )
  • Rapid (离线 插件 )
  • Paddle (离线 插件 )
  • 更多接口支持见 插件系统

  • Lingva
  • 更多接口支持见 插件系统

  • 有道 ( 插件 )
  • 扇贝 ( 插件 )
  • 更多接口支持见 插件系统

    软件内置接口数量有限,但是您可以通过插件系统来扩展软件的功能。

    你可以在 Plugin List 查找你需要的插件,然后前往插件仓库下载插件。

    pot 插件的扩展名为 .potext , 下载得到 .potext 文件之后, 在 偏好设置-服务设置-添加外部插件-安装外部插件 选择对应的 .potext 即可安装成功,添加到服务列表中即可像内置服务一样正常使用了。

    找不到指定的模块 (Windows)

    出现类似这样的报错是因为系统缺少 C++库,前往 这里 安装即可解决问题。

    不是有效的 Win32 应用程序 (Windows)

    出现类似这样的报错说明你没有下载对应系统或者架构的插件,前往插件仓库下载正确的插件即可解决问题。

    Plugin List 中的 模板 章节提供了各种插件的开发模板,具体的开发文档请查看对应的模板仓库。

    Windows

    通过 Winget 安装

    winget install Pylogmon.pot

    Release 页面下载最新 exe 安装包。

  • 64 位机器下载 pot_{version}_x64-setup.exe
  • 32 位机器下载 pot_{version}_x86-setup.exe
  • arm64 机器下载 pot_{version}_arm64-setup.exe
  • 双击安装包进行安装。

    启动后没有界面,点击托盘图标没有反应

    检查是否卸载/禁用了 WebView2,如果卸载/禁用了 WebView2,请手动安装 WebView2 或将其恢复。

    如果是企业版系统不方便安装或无法安装 WebView2,请尝试在 Release 下载内置 WebView2 的版本 pot_{version}_{arch}_fix_webview2_runtime-setup.exe

    若问题仍然存在请尝试使用 Windows7 兼容模式启动。

    MacOS

    通过 Brew 安装

  • 添加我们的 tap:
  • brew tap pot-app/homebrew-tap
  • 安装 pot:
  • brew install --cask pot
  • 更新 pot
  • brew upgrade --cask pot
  • Release 页面下载最新的 dmg 安装包。(如果您使用的是 M1 芯片,请下载名为 pot_{version}_aarch64.dmg 的安装包,否则请下载名为 pot_{version}_x64.dmg 的安装包)
  • 双击下载的文件后将 pot 拖入 Applications 文件夹即可完成安装。
  • 由于开发者无法验证,“pot”无法打开。

    点击 取消 按钮,然后去 设置 -> 隐私与安全性 页面,点击 仍要打开 按钮,然后在弹出窗口里点击 打开 按钮即可,以后打开 pot 就再也不会有任何弹窗告警了

    如果在 隐私与安全性 中找不到以上选项,或启动时提示文件损坏。打开 Terminal.app,并输入以下命令,然后重启 pot 即可:

    sudo xattr -d com.apple.quarantine /Applications/pot.app

    如果每次打开时都遇到辅助功能权限提示,或者无法进行划词翻译,请前往设置 -> 隐私与安全 -> 辅助功能,移除 “pot”,并重新添加 “pot”。

    Linux

    Debian/Ubuntu

    Release 页面下载最新的对应架构的 deb 安装包。

    使用 apt-get 进行安装

    sudo apt-get install ./pot_{version}_amd64.deb

    Arch/Manjaro

    Warning

    在最新版本的 Webkit2Gtk (2.42.0) 中,由于 Nvidia 专有驱动未完全实现 DMABUF,将导致无法启动和崩溃的情况发生。
    请降级或在 /etc/environment (或者其他设置环境变量的地方)中加入 WEBKIT_DISABLE_DMABUF_RENDERER=1 环境变量关闭 DMABUF 的使用。

  • AUR 查看
  • 使用 AUR helper 安装:

    yay -S pot-translation # 或 pot-translation-bin
    # paru -S pot-translation # 或 pot-translation-bin
  • 如果你使用 archlinuxcn 源,可以直接使用 pacman 安装
  • sudo pacman -S pot-translation

    Flatpak

    Warning

    Flatpak 版本缺失托盘图标。

    Pot 提供了完整的 HTTP 接口,以便可以被其他软件调用。您可以通过向 127.0.0.1:port 发送 HTTP 请求来调用 pot,其中的 port 是 pot 监听的端口号,默认为 60828 ,可以在软件设置中进行更改。

    API 文档:

    POST "/" => 翻译指定文本(body为需要翻译的文本),
    GET "/config" => 打开设置,
    POST "/translate" => 翻译指定文本(同"/"),
    GET "/selection_translate" => 划词翻译,
    GET "/input_translate" => 输入翻译,
    GET "/ocr_recognize" => 截图OCR,
    GET "/ocr_translate" => 截图翻译,
    GET "/ocr_recognize?screenshot=false" => 截图OCR(不使用软件内截图),
    GET "/ocr_translate?screenshot=false" => 截图翻译(不使用软件内截图),
    GET "/ocr_recognize?screenshot=true" => 截图OCR,
    GET "/ocr_translate?screenshot=true" => 截图翻译,

    调用划词翻译:

    如果想要调用 pot 划词翻译,只需向 127.0.0.1:port 发送请求即可。

    例如通过 curl 发送请求:

    curl "127.0.0.1:60828/selection_translate"

    不使用软件内截图

    这一功能可以让您在不使用软件内截图的情况下调用截图 OCR/截图翻译功能,这样您就可以使用您喜欢的截图工具来截图了,也可以解决在某些平台下 pot 自带的截图无法使用的问题。

  • 使用其他截图工具截图
  • 将截图保存在 $CACHE/com.pot-app.desktop/pot_screenshot_cut.png
  • 127.0.0.1:port/ocr_recognize?screenshot=false 发送请求即可调用成功
  • $CACHE 为系统缓存目录,例如在 Windows 上为 C:\Users\{用户名}\AppData\Local\com.pot-app.desktop\pot_screenshot_cut.png

    在 Linux 下调用 Flameshot 进行截图 OCR:

    rm ~/.cache/com.pot-app.desktop/pot_screenshot_cut.png && flameshot gui -s -p ~/.cache/com.pot-app.desktop/pot_screenshot_cut.png && curl "127.0.0.1:60828/ocr_recognize?screenshot=false"

    现有用法 (快捷划词翻译)

    SnipDo (Windows)

  • Microsoft Store 下载安装 SnipDo。
  • Release 下载 pot 的 SnipDo 扩展 (pot.pbar)
  • 双击下载的扩展文件完成安装。
  • 选中文字,可以看到弹出的 SnipDo 工具条,点击翻译按钮即可翻译。
  • PopClip (MacOS)

  • App Store 下载安装 PopClip
  • Release 下载 pot 的 PopClip 扩展 (pot.popclipextz)
  • 双击下载的扩展文件完成安装。
  • 在 PopClip 的扩展中启用 pot 扩展,选中文本即可点击翻译。
  • Starry (Linux)

    Starry 目前仍处于开发阶段,因此您只能手动编译它。

    Github: ccslykx/Starry

    Wayland 支持

    由于各大发行版对于 Wayland 的支持程度不同,所以 pot 本身没法做到特别完美的支持,这里可以提供一些常见问题的解决方案,通过合理的设置之后,pot 也可以在 Wayland 下完美运行。

    快捷键无法使用

    由于 Tauri 的快捷键方案并没有支持 Wayland,所以 pot 应用内的快捷键设置在 Wayland 下无法使用。 您可以设置系统快捷用 curl 发送请求来触发 pot,详见 外部调用

    截图无法使用

    在一些纯 Wayland 桌面环境/窗口管理器(如 Hyprland)上,pot 内置的截图无法使用,这时可以通过使用其他截图工具代替,详见 不使用软件内截图

    下面给出在 Hyprland 下的配置示例(通过 grim 和 slurp 实现截图):

    bind = ALT, X, exec, grim -g "$(slurp)" ~/.cache/com.pot-app.desktop/pot_screenshot_cut.png && curl "127.0.0.1:60828/ocr_recognize?screenshot=false"
    bind = ALT, C, exec, grim -g "$(slurp)" ~/.cache/com.pot-app.desktop/pot_screenshot_cut.png && curl "127.0.0.1:60828/ocr_translate?screenshot=false"
    

    其他桌面环境/窗口管理器也是类似的操作

    划词翻译窗口跟随鼠标位置

    由于目前 pot 在 Wayland 下还无法获取到正确的鼠标坐标,所以内部的实现无法工作。 对于某些桌面环境/窗口管理器,可以通过设置窗口规则来实现窗口跟随鼠标位置,这里以 Hyprland 为例:

    windowrulev2 = float, class:(pot), title:(Translator|OCR|PopClip|Screenshot Translate) # Translation window floating
    windowrulev2 = move cursor 0 0, class:(pot), title:(Translator|PopClip|Screenshot Translate) # Translation window follows the mouse position.
    

    国际化(Weblate)

    安装依赖(仅 Linux 需要)

    sudo apt-get install -y libgtk-3-dev libwebkit2gtk-4.0-dev libayatana-appindicator3-dev librsvg2-dev patchelf libxdo-dev libxcb1 libxrandr2 libdbus-1-3
    pnpm tauri dev # Run the app in development mode
    pnpm tauri build # Build into installation package
  • Bob 灵感来源
  • bob-plugin-openai-translator OpenAI 接口参考
  • @uiYzzi 实现思路
  • @Lichenkass 维护 Deepin 应用商店中的 pot
  • Tauri 好用的 GUI 框架
  •