DesktopTimer | 桌面计时器
DesktopTimer | 桌面计时器
基于 PyQt6 的轻量级桌面计时器,支持正计时/倒计时/时钟模式,系统托盘、快捷键、音效与闪烁提醒、多语言(中/英)以及丰富的外观自定义;
下载最新版本 • 查看源码 • 报告 Bug • 提出新特性
本 README 同时面向“用户”和“开发者”,上来就想用的看“快速开始”,想参与开发的看“开发者指南”。
🚀 快速开始(用户)
- 支持系统:Windows 10/11(x64)
- 推荐环境:Python 3.13(仅源码运行需用到),普通用户可直接使用安装包或便携版
- 安装程序(建议)
- 前往 Releases 下载 DesktopTimer-Setup.exe
- 双击安装,按向导完成;从开始菜单或桌面快捷方式启动
- 便携版
- 下载 DesktopTimer.zip → 解压 → 直接运行 DesktopTimer.exe
- 从源码运行(开发者)
- 克隆仓库并安装依赖后运行
main.py(见下文“开发者指南”)
✨ 功能一览
- ⏰ 三种计时:正计时、倒计时、时钟(12/24 小时制、可选“秒/日期”)
- 🔔 提醒方式:自定义音效(可调音量)、系统 Beep、窗口闪烁、托盘气泡、Windows 通知(可开关)
- 🌐 双语言:中文 / English 一键切换
- 🎯 预设管理:设置页支持自定义/排序/搜索/多选删除倒计时预设,排序方式可记忆,可为中/英文界面分别命名并同步托盘快捷菜单
- 🎨 外观:字体/字号、颜色、圆角、透明度、夜读模式、窗口尺寸、主题(浅/深/跟随系统)
- 🧰 系统托盘:暂停/继续、重置、模式切换、倒计时预设(含自定义单次输入)、显示/隐藏、锁定/解锁、打开设置、退出
- 🔒 窗口锁定:固定位置并可启用“点击穿透”
- ⌨️ 快捷键:常用操作一键直达
- 🖥️ 全屏模式:F11 一键切换,简拍/展示更方便
🧭 使用说明(核心操作)
- 设置倒计时:在设置页输入小时/分钟/秒,或托盘菜单选择预设/自定义单次倒计时
- 开始/暂停/继续:托盘菜单或快捷键 Ctrl+Space;也可在设置中启用“启动自动开始”
- 重置计时:托盘菜单或快捷键 Ctrl+R
- 窗口锁定:托盘菜单或 Ctrl+L(锁定后支持点击穿透)
- 切换模式:设置页或托盘“模式切换”菜单
- 显示/隐藏:托盘菜单或 Ctrl+H
- 配置保存:所有设置自动保存至
settings/timer_settings.json
⌨️ 快捷键
| 快捷键 | 功能 |
|---|---|
| Ctrl+Space | 暂停/继续 |
| Ctrl+R | 重置 |
| Ctrl+H | 显示/隐藏窗口 |
| Ctrl+L | 锁定/解锁窗口 |
| Ctrl+, | 打开设置 |
| F11 | 全屏/退出全屏 |
🛠️ 开发者指南
开发环境要求
- Python 3.13
- Windows 10/11
- 依赖管理:UV
注:如需 Qt Designer 等工具,可另行安装
pyqt6-tools(与项目运行依赖无关)。
源码运行
1 | # 克隆与进入目录 |
打包为可执行文件
1 | # 打包需要安装开发依赖 |
打包完成后生成 dist/DesktopTimer.exe。请将 img/、lang/、sounds/ 一并放入 dist/ 目录。
也可直接使用内置脚本一键完成清理、打包、复制资源与压缩:
1 | tools\pyinstaller.bat |
文件结构
1 | DesktopTimer/ |
架构与实现要点
- i18n:多语言加载(lang/*.json)
- SettingsDialog:设置对话框(外观/模式/预设/通用/关于)
- TimerWindow:主窗口/计时/托盘/提醒/快捷键(含模式切换菜单、倒计时预设与自定义单次输入)
- 路径管理:自动识别开发/打包环境,动态定位资源
- 配置管理:JSON 持久化,包含版本兼容处理
要点:使用 sys.frozen 识别打包环境;相对路径存储确保可移植;QTimer/QMediaPlayer/QSystemTrayIcon 组合
📦 打包与发布
- 使用
DesktopTimer.spec进行 onefile 打包,输出dist/DesktopTimer.exe - 将
img/、lang/、sounds/复制到dist/下,确保资源可用 - 可使用 Inno Setup 生成安装程序(参考
setup/SetUp.iss)
❓ 常见问题(FAQ)
打包后没有声音/语言不生效?
- 请确认已将
img/、lang/、sounds/整个目录复制到dist/。
- 请确认已将
托盘图标不显示/找不到?
- 检查系统托盘的“隐藏的图标”区域;确保 Explorer 正常;程序最小化到托盘时可通过 Ctrl+H 显示/隐藏。
锁定后无法操作窗口怎么办?
- 使用快捷键 Ctrl+L 解锁,或通过系统托盘菜单解锁。
源码运行报依赖错误?
- 重新执行
uv sync,确保网络正常。 - 若提示 Python 版本不匹配,请确认项目使用 Python 3.13。
- 重新执行
打包后资源路径异常?
- 本项目已兼容
sys.frozen场景;若自定义了运行目录,请保持资源与可执行文件同级。
- 本项目已兼容
DesktopTimer.egg-info/是什么?- 这是 setuptools 构建产生的元数据目录,可在发布包或清理时忽略/删除。
切换语言后界面没变化?
- 语言下拉框一旦切换就会立即应用到主窗口与托盘;若仍看到旧语言,可确认设置文件是否可写或查看日志输出。
🧭 开发路线图
✅ 已完成功能
- 正计时/倒计时/时钟三种模式
- 系统托盘常驻与快捷操作
- 多种提醒方式(音效/闪烁/通知)
- 中英文双语支持
- 外观完全自定义
- 快捷键支持
- 番茄钟快捷预设
- 窗口锁定功能(位置固定 + 点击穿透)
- 快捷键自定义
- 托盘模式切换与即席自定义倒计时
- 预设支持中英文双描述,可在创建时同步填写
📌 计划中的功能
- 结束提醒增强:音量、循环次数、渐入渐出;播放列表/多音频轮播
- Windows 原生通知按钮(如“再来 5 分钟”“停止”)
- 托盘与主题:暗/亮主题托盘图标,自定义图标包
- 设置管理:设置导出/导入备份,一键恢复默认
- 自动更新:检查 Releases 新版本并提示下载
- 开机自启动(用户可选)
- 多语言扩展:支持更多语言(日文、韩文等)
- 可视化窗口滑块:为字体/窗口大小提供滑块+“恢复默认”按钮,并显示实时数值
- 全屏专用主题:进入全屏时可使用独立的背景/文字/透明度样式
- 自定义快捷预设:允许用户在设置中增删 Pomodoro 预设并同步到托盘/右键菜单
- 配置导入/导出:一键备份或应用
settings/*.json,方便在不同设备间迁移 - 预设导入/导出能力(JSON 备份/恢复)
- 预设列表排序、搜索或分组功能
- 语言切换提示(关闭设置前提醒“需点击应用/确定”)
- 设置中添加调试日志开关(无需依赖环境变量)
- 更易用的预设多语言编辑视图(统一列表,可批量维护)
- 替换 win10toast 或移除其中的
pkg_resources依赖以适配未来环境
🧩 使用到的技术栈
- PyQt6 - GUI 框架
- PyQt6-Fluent-Widgets - Fluent 风格组件库(设置页 UI)
- PyInstaller - 打包工具
- win10toast - Windows 通知(可选)
- Inno Setup - 安装程序制作
🤝 贡献指南
欢迎通过 Issues 或 Pull Requests 参与贡献!
如何参与开源项目
- Fork 本仓库
- 新建分支:
git checkout -b feature/your-feature - 提交改动:
git commit -m "feat: your message" - 推送分支:
git push origin feature/your-feature - 发起 Pull Request
🔖 版本控制
项目使用 Git 管理版本;发布版本在 Releases/Tags 标注。
👤 作者
TikaRa
📧 邮箱:[email protected]
🌐 个人网站:https://re-tikara.fun
🐙 GitHub:https://github.com/RE-TikaRa/DesktopTimer
📺 B 站主页:https://space.bilibili.com/374412219
📄 版权说明
本项目采用 GNU GPL v3 或更高版本。
允许:自由使用、修改与再发布(包含商用),需保留版权与许可声明,并在发布衍生作品时继续采用 GPL v3 或更高版本。
要求:发布二进制时需同时提供对应源码;不得移除许可证文本。
完整条款参见仓库中的 LICENSE 文件。
🙏 鸣谢
- PyQt6 - 提供强大的 GUI 框架
- PyInstaller - Python 打包为可执行文件
- Qt - 跨平台 GUI 框架
- Inno Setup - Windows 安装程序制作工具
- Shields.io - 项目徽章
- GitHub Pages - 文档托管
- 标题:
- 作者: 亓翎_Re-Tikara
- 创建于 : 2026-03-12 21:21:48
- 更新于 : 2026-02-07 02:01:49
- 链接: https://re-tikara.fun/Blog/posts/0/
- 版权声明: 本文章采用 CC BY-NC-SA 4.0 进行许可。