版本:2.11.1 | 作者:Chen Yu | 许可证:GPL-3.0
一款基于 Electron 的桌面辩论赛计时器,专为华语辩论赛场景设计。支持完整的赛事配置、环节管理、倒计时展示、提示音提醒、主题样式自定义,以及将当前配置导出为独立可执行文件(EXE)等功能。
- 所见即所得编辑界面:直接在计时器预览中编辑所有文本元素,支持点击修改内容/字体/字号/颜色,拖动调整位置
- 赛事配置:编辑赛事名称、正反方队伍与辩题
- 环节管理:支持无计时、单边计时、单边发问、中立计时、双边对辩等多种环节类型;可自由增删改环节、调整顺序
- 名称模板:通过"持方 + 辩位 + 模板名称 + 附加项"快速生成规范环节名
- 主题样式:
- 自定义单个颜色(正反方色、中立色、标题色、背景色)
- 支持纯色/渐变/图片三种背景类型,图片支持透明度、缩放、XY偏移
- 调整字体(系统字体)与字号缩放
- 支持上传自定义 TTF/OTF 字体文件(仅用于文本显示)
- 状态栏支持高度拖拽和颜色/透明度/渐变自定义
- 导入/导出配置:将当前比赛配置保存为 JSON 文件,或从外部 JSON 文件导入配置;支持背景图片 Base64 硬编码
- 导出独立计时器:将当前配置与 Electron 运行时打包为单个 EXE 可执行文件(WinRAR 自解压),双击即可启动;赛前可修改队伍名称与辩题,不可修改其他配置。无需目标电脑安装 Node.js 或 WinRAR
- 计时控制:启动/暂停、停止、重置、切换环节、环节跳转、设置时间、切换持方、全屏、音效试播等
- 现代化界面:玻璃拟态卡片、底部悬浮胶囊控制面板、数字倒计时进度条、Toast 通知系统
- 完全离线:不依赖任何外部 CDN 或网络资源,所有字体使用系统字体
- Electron 42.x
- 原生 HTML / CSS / JavaScript(无框架、无构建工具)
- Web Audio API 提示音(零外部音频文件)
- CommonJS(主进程)+ 全局脚本(渲染进程)
preload.js安全 IPC 桥接(遵循 Electron 安全最佳实践)
npm install
npm start首次启动会打开编辑页。修改配置后点击"保存配置"即可进入计时页;点击计时页控制面板的"返回(B)"可回到编辑页。也可直接点击"进入计时页"在不保存的情况下预览计时效果。
编辑页采用左侧导航栏 + 右侧内容面板布局。
- 编辑界面:
- 直接嵌入完整的计时器预览,所见即所得
- 点击文本元素(队伍名称、辩题、赛事名称等)弹出浮动工具栏,可编辑内容、字体、字号、颜色
- 拖动文本元素可调整位置,对称元素(正反方)自动同步移动
- 状态栏底部拖拽手柄可调整高度,点击空白处编辑颜色/透明度/渐变
- "修改背景"按钮进入背景编辑模式,支持纯色/渐变/图片三种类型
- 背景图片支持透明度、缩放、XY偏移,以 Base64 编码存储到配置中
- 环节管理:
- 环节管理面板采用左侧固定边栏 + 右侧可滚动列表布局
- 左侧边栏包含:
- 导航栏:纵向列出所有环节,支持鼠标拖拽排序,左键拖拽时选中项虚化,跟随鼠标显示放大倾斜预览,其他项自动滑动让位,并显示蓝色发光占位条
- 快捷操作:
+ 无计时/+ 陈词/+ 质询/+ 中立计时/+ 对辩/+ 自由辩论按钮始终可见,不受列表滚动影响 - 右键菜单:在导航栏任意环节上右键可执行:定位到该环节 / 上移 / 下移 / 删除
- 在环节卡片中修改名称、类型、时长与持方
- 使用名称模板下拉框快速生成规范名称,点击"确认名称"应用
- 通过"上移/下移/删除"调整环节顺序或移除环节
- 导入/导出:
- 导入配置:从 JSON 文件加载比赛配置,自动校验字段,兼容旧版配置
- 导出配置:将当前完整配置保存为 JSON,包含所有布局、状态栏、背景设置,便于备份或分享
- 导出独立计时器:生成一个单独的 EXE 文件,双击即可启动;打开后仅允许修改队伍名称与辩题
- 顶部操作栏:包含保存配置、重置默认、导入配置、导出配置、导出独立计时器、进入计时页等按钮
- 顶部全宽状态栏:左侧显示正方队伍(红色背景)+ 辩题,右侧显示反方队伍(蓝色背景)+ 辩题,中间显示赛事名称。状态栏高度和颜色可在编辑页自定义
- 中央显示赛事名称、当前环节名称
- 单边计时显示单个大型倒计时器,颜色随持方变化(正方红 / 反方蓝 / 中立白)
- 双边对辩显示正反方两个独立倒计时器,颜色区分
- 中立计时显示单个大型白色倒计时器,用于中场暂停或评委限时述票,不区分正方反方
- 无计时环节以超大字号展示环节名称,不显示计时器
- 进度条:单边计时和中立计时模式下数字下方显示进度条,最后 30 秒变黄,最后 5 秒变红并脉冲闪烁
- 控制面板:底部居中悬浮胶囊,半透明 + 毛玻璃背景,分组按钮(主控/导航/操作/音效/系统),hover 显示快捷键提示
- 快捷键:
Space启动/暂停(双边计时为切换发言方)P暂停Q/W/E试播 30 秒/5 秒/结束提示音F全屏B返回编辑页(独立运行时为"队伍设置")←/→切换环节C切换持方(仅对单边计时有效)
已配置 electron-builder,支持生成 Windows 安装包(NSIS)与便携版(Portable)。
npm run dist
# 输出目录:dist/
# DebateTimer Setup 2.11.1.exe —— 安装包
# DebateTimer 2.11.1.exe —— 便携版在编辑页点击"导出独立计时器",应用会将当前配置和 Electron 运行时打包为一个自解压 EXE,无需目标电脑安装任何运行环境。
.
├── main.js # Electron 主进程(窗口管理、IPC、配置持久化、日志、EXE 导出)
├── preload.js # 渲染进程 IPC 安全桥接
├── editor.html # 编辑页(所见即所得预览 + 环节管理)
├── timer.html # 计时页
├── js/
│ ├── audio.js # Web Audio API 提示音生成(零外部音频文件)
│ ├── timer-core.js # 计时引擎核心(计时逻辑、状态管理)
│ ├── timer-app.js # 计时页 UI 控制(渲染、快捷键、主题应用)
│ ├── editor-app.js # 编辑页逻辑(预览交互、文本编辑、背景编辑、环节管理、拖拽排序)
│ └── toast.js # Toast 通知系统 + 自定义确认对话框
├── styles/
│ ├── variables.css # CSS 变量系统 + 通用组件(Toast、模态框、按钮、卡片)
│ ├── editor.css # 编辑页样式(预览区域、浮动工具栏、侧边栏、环节卡片、拖拽排序、响应式)
│ └── timer.css # 计时页样式(顶栏、计时器、进度条、控制面板、模态框)
├── scripts/
│ ├── build-release.js # 发布构建脚本
│ ├── encode-vendor.js # 编码 WinRAR 二进制到 vendor
│ └── test-sfx.js # 自解压测试
├── vendor/
│ └── embedded-binaries.js # 嵌入的 WinRAR 组件与图标(rar.exe、SFX 模块、图标)
├── package.json
├── README.md
├── whatsnew.md # 版本更新日志
├── release.md # 发布说明文档
└── LICENSE # GPL-3.0
GPL-3.0
© Chen Yu 2026 All rights reserved.