Python图形化秒表:使用Turtle打造精确计时工具

⏱️ 编程基础第一期《6-30》–简易计时器/秒表,这是一个使用Python的turtle和time模块实现的简易计时器/秒表程序,提供简洁的数字时间显示。

目录

    • 🌟 功能特点
    • 🚀 使用方法
    • 🧩 程序架构设计
    • 💻 代码详解
      • 窗口和画笔创建
      • 时间和状态显示更新
      • 计时器控制逻辑
      • 计时器重置功能
      • 事件监听设置
      • 主循环及运行控制
    • 🚀总
    • ✨今日分享语录


🌟 功能特点

  1. 数字显示当前计时(时:分:秒.毫秒)
  2. 支持开始/暂停计时(空格键)
  3. 支持重置计时(R键)
  4. 状态显示(正在计时/已暂停/按空格键开始计时)
  5. 清晰的操作提示

🚀 使用方法

  1. 运行程序后,会显示初始时间(00:00:00.000)
  2. 按下空格键开始计时
  3. 再次按下空格键暂停计时
  4. 按下R键可以重置计时器回到00:00:00.000

🧩 程序架构设计

  • 核心模块:

    • turtle: 提供跨平台的图形化界面绘制功能
    • time: 提供高精度的系统时间获取功能
  • 设计模式:

    • 采用事件驱动编程模型,通过键盘事件触发状态变更
    • 利用全局状态管理计时器状态
  • 算法原理:

    • 时间计算:利用系统时间差值计算经过时间
    • 状态管理:使用布尔变量控制计时器运行状态

💻 代码详解

窗口和画笔创建

import turtle
import time# 设置窗口和基本参数
screen = turtle.Screen()
screen.title("简易计时器/秒表")
screen.bgcolor("black")
screen.setup(width=500, height=300)
screen.tracer(0)  # 关闭自动刷新# 创建显示时间的画笔
time_display = turtle.Turtle()
time_display.hideturtle() # 隐藏turtle的箭头图标,使绘图时只显示图形而不显示箭头
time_display.color("cyan") # 设置turtle绘图的颜色
time_display.penup()   #抬起turtle的笔,这样移动turtle时不会绘制线条
time_display.goto(0, 30)  # 将turtle移动到坐标(0, 30)的位置,准备从该点开始绘图或显示文本# 创建状态显示的画笔
status_display = turtle.Turtle()
status_display.hideturtle()
status_display.speed(0)
status_display.color("white")
status_display.penup()
status_display.goto(0, -30)# 创建操作提示的画笔
help_display = turtle.Turtle()
help_display.hideturtle()
help_display.speed(0)
help_display.color("yellow")
help_display.penup()
help_display.goto(0, -80)
help_display.write("空格键: 开始/暂停 | R键: 重置", align="center", font=("Arial", 14, "normal"))# 初始化秒表变量
is_running = False
start_time = 0
accumulated_time = 0

应用知识点:

  • Turtle图形对象: 创建多个Turtle对象分别负责不同UI元素的显示
  • 窗口控制: 使用screen.tracer(0)关闭自动刷新以提高性能
  • 坐标系统: 使用二维坐标系统合理布局界面元素
  • 全局状态变量: 使用全局变量跟踪计时器状态

时间和状态显示更新

# 更新时间显示
def update_time_display(elapsed_time):hours = int(elapsed_time / 3600)minutes = int((elapsed_time % 3600) / 60)seconds = int(elapsed_time % 60)milliseconds = int((elapsed_time * 1000) % 1000)time_str = f"{hours:02d}:{minutes:02d}:{seconds:02d}.{milliseconds:03d}"time_display.clear()time_display.write(time_str, align="center", font=("Arial", 40, "bold"))# 更新状态显示
def update_status():status_display.clear()if is_running:status = "正在计时..."else:if accumulated_time > 0:status = "已暂停"else:status = "按空格键开始计时"status_display.write(status, align="center", font=("Arial", 20, "normal"))

应用知识点:

  • 时间单位转换: 将秒数转换为时、分、秒、毫秒
  • 取余与整除运算: 使用整除和取余操作进行时间单位分解
  • 字符串格式化: 使用f-string和格式说明符控制显示格式
  • 状态条件判断: 根据多种状态组合提供不同的用户反馈

计时器控制逻辑

def toggle_timer():global is_running, start_time, accumulated_timeif is_running:# 暂停计时is_running = Falseaccumulated_time += time.time() - start_timeelse:# 开始计时is_running = Truestart_time = time.time()update_status()

应用知识点:

  • 全局变量修改: 使用global关键字在函数内修改全局状态
  • 高精度时间获取: 使用time.time()获取高精度Unix时间戳
  • 状态切换设计: 实现简洁的状态切换逻辑

计时器重置功能

def reset_timer():global is_running, start_time, accumulated_timeis_running = Falseaccumulated_time = 0start_time = 0update_status()update_time_display(0)

应用知识点:

  • 状态重置: 将所有计时相关变量重置为初始值
  • 函数复用: 复用更新显示的函数,避免代码冗余

事件监听设置

# 设置键盘事件
screen.listen()
screen.onkeypress(toggle_timer, "space")  # 空格键开始/暂停
screen.onkeypress(reset_timer, "r")       # R键重置

应用知识点:

  • 事件监听机制: 使用listen()方法启用事件监听
  • 回调函数绑定: 将键盘事件与特定函数绑定
  • 函数引用传递: 将函数名作为参数传递,不带括号

主循环及运行控制

def main():# 初始显示update_status()update_time_display(0)while True:if is_running:elapsed_time = accumulated_time + (time.time() - start_time)else:elapsed_time = accumulated_timeupdate_time_display(elapsed_time)screen.update()time.sleep(0.01)  # 小延迟减轻CPU负担# 启动程序
if __name__ == "__main__":try:main()except:print("程序已退出")turtle.done() 

应用知识点:

  • 无限循环: 使用while True创建游戏主循环
  • 条件计时: 根据运行状态计算不同的时间值
  • 手动屏幕刷新: 使用screen.update()手动刷新画面
  • 定时延迟: 使用time.sleep()控制循环速率,减轻CPU负担
  • 异常处理: 使用try-except捕获可能的异常,确保程序优雅退出
  • 入口点检查: 使用if __name__ == "__main__":确保直接运行时才执行主函数

🚀总

import turtle
import time# 设置窗口和基本参数
screen = turtle.Screen()
screen.title("简易计时器/秒表")
screen.bgcolor("black")
screen.setup(width=500, height=300)
screen.tracer(0)  # 关闭自动刷新# 创建显示时间的画笔
time_display = turtle.Turtle()
time_display.hideturtle() # 隐藏turtle的箭头图标,使绘图时只显示图形而不显示箭头
time_display.color("cyan") # 设置turtle绘图的颜色
time_display.penup()   #抬起turtle的笔,这样移动turtle时不会绘制线条
time_display.goto(0, 30)  # 将turtle移动到坐标(0, 30)的位置,准备从该点开始绘图或显示文本# 创建状态显示的画笔
status_display = turtle.Turtle()
status_display.hideturtle()
status_display.speed(0)
status_display.color("white")
status_display.penup()
status_display.goto(0, -30)# 创建操作提示的画笔
help_display = turtle.Turtle()
help_display.hideturtle()
help_display.speed(0)
help_display.color("yellow")
help_display.penup()
help_display.goto(0, -80)
help_display.write("空格键: 开始/暂停 | R键: 重置", align="center", font=("Arial", 14, "normal"))# 初始化秒表变量
is_running = False
start_time = 0
accumulated_time = 0# 更新时间显示
def update_time_display(elapsed_time):hours = int(elapsed_time / 3600)minutes = int((elapsed_time % 3600) / 60)seconds = int(elapsed_time % 60)milliseconds = int((elapsed_time * 1000) % 1000)time_str = f"{hours:02d}:{minutes:02d}:{seconds:02d}.{milliseconds:03d}"time_display.clear()time_display.write(time_str, align="center", font=("Arial", 40, "bold"))# 更新状态显示
def update_status():status_display.clear()if is_running:status = "正在计时..."else:if accumulated_time > 0:status = "已暂停"else:status = "按空格键开始计时"status_display.write(status, align="center", font=("Arial", 20, "normal"))def toggle_timer():global is_running, start_time, accumulated_timeif is_running:# 暂停计时is_running = Falseaccumulated_time += time.time() - start_timeelse:# 开始计时is_running = Truestart_time = time.time()update_status()def reset_timer():global is_running, start_time, accumulated_timeis_running = Falseaccumulated_time = 0start_time = 0update_status()update_time_display(0)
# 设置键盘事件
screen.listen()
screen.onkeypress(toggle_timer, "space")  # 空格键开始/暂停
screen.onkeypress(reset_timer, "r")       # R键重置def main():# 初始显示update_status()update_time_display(0)while True:if is_running:elapsed_time = accumulated_time + (time.time() - start_time)else:elapsed_time = accumulated_timeupdate_time_display(elapsed_time)screen.update()time.sleep(0.01)  # 小延迟减轻CPU负担# 启动程序
if __name__ == "__main__":try:main()except:print("程序已退出")turtle.done() 

效果
在这里插入图片描述

✨今日分享语录

“低级的欲望靠放纵,高级的欲望靠自律。”

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/910348.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/910348.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【轨物方案】轨物科技|LoRaWAN 赋能智能光伏清扫,解锁电站高效运维新时代

在大型集中式光伏电站的广袤土地上,清扫机器人的高效运行是保障发电效率的关键。然而,传统的无线通信方式在这些偏远、无4G/5G信号覆盖的区域,往往步履维艰。作为专注于工业物联网解决方案的轨物科技,我们深知这些痛点&#xff0c…

Python函数实战:从基础到高级应用

Python-函数 Python 中可以使用def关键字来定义函数。 函数定义规则: 函数代码块以 def 关键词开头,后接函数标识符名称和圆括号 ()。任何传入参数和自变量必须放在圆括号中间,圆括号之间可以用于定义参数。函数的第一行语句可以选择性地使…

Mac在局域网中突然很慢(包括SMB、NFS、SCP、SSH、Ping等场景均很慢)

今天 SMB 又突然好慢,大概只有 8-9 MB/s,而苹果 SMB 很容易突然很慢是出了名的。我就想装 NFS,但是 NFS 弄好之后还是很慢,我服了,我就检查了scp等场景,都很慢,但是互联网下载速度还是很快的。 …

UMAP:用于降维的均匀流形近似和投影实验

关键词: Uniform Manifold Approximation and Projection (UMAP):均匀流形近似与投影 一、说明 对于降维,首先看数据集是否线性,如果是线性的用pca降维;如果是非线性数据,t-SNE或者UMAP,本文针…

【Datawhale组队学习202506】YOLO-Master task03 IOU总结

系列文章目录 task01 导学课程 task02 YOLO系列发展线 文章目录 系列文章目录前言1 功能分块1.1 骨干网络 Backbone1.2 颈部网络 Neck1.3 头部网络 Head1.3.1 边界框回归头1.3.2 分类头 2 关键概念3 典型算法3.1 NMS3.2 IoU 总结 前言 Datawhale是一个专注于AI与数据科学的开…

Spring IOC容器核心揭秘:BeanFactory创建、配置加载解析并注册为BeanDefinition

文章目录 一、为何这个阶段如此重要?二、整体流程全景图三、源码级深度解析1. BeanFactory的诞生源码入口:refresh()方法核心方法:obtainFreshBeanFactory()核心实现:refreshBeanFactory()BeanFactory实例化 2. ★ 核心&#xff1…

解锁n8n:开启工作流自动化的无限可能(5/6)

文章摘要:n8n 是一款开源低代码工作流自动化平台,通过可视化拖放节点创建复杂工作流,无需大量代码。具有强大集成能力、数据转换、错误处理等功能,适用于数据同步、客户关系管理、IT 自动化等场景。相比 Zapier、IFTTT 等工具&…

数据赋能(308)——合作共享——数据交流

概述 重要性如下: 信息准确性:数据交流原则确保在数据传递过程中信息的准确性,这是决策和业务活动的基础。决策支持:准确的数据交流为决策提供有力支持,帮助组织做出更明智的决策。业务效率:有效的数据交…

TCP流量控制与拥塞控制:核心机制与区别

一、TCP流量控制(Flow Control) 定义:通过调节发送方的发送速率,确保接收方能够及时处理数据,避免缓冲区溢出。 本质:解决发送方与接收方之间的"端到端"速率匹配问题。 1. 实现机制&#xff1a…

iOS多端兼容性调试:一次iOS性能优化分工具协作排查过程

在多技术栈混合开发日益普及的今天,iOS应用中越来越多地集成了WebView、Flutter、React Native甚至小程序模块。而这些模块带来的复杂性,不仅体现在UI适配,还包括数据同步、系统权限管理、线程调度等方面的问题。 本文记录的是我们在处理一个…

秋招Day14 - MySQL - 索引

索引为什么能够提高MySQL的查询效率? 索引可以理解为目录,通过索引可以快速定位数据,避免全表扫描 一般是B树结构,查找效率是O(log n)。 索引还能加速排序、分组、连接等操作。 create index idx_name on students(name); 能简…

第5天:LSTM预测火灾温度

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 目标 复用LSTM模型实现火灾温度预测 具体实现 (一)环境 语言环境:Python 3.10 编 译 器: PyCharm 框 架: Pytorch &am…

目标检测之YOLOV11自定义数据使用OBB训练与验证

一、前置条件与环境准备 在开始训练前,确保已完成以下准备《目标检测之YOLOV11自定义数据预处理——从原始标注到YOLO-OBB格式转换与验证》: 数据目录结构: yolov11/ ├── datasets/ │ └── shrimp/ │ ├── images/ │ …

Labview教程进阶一(Labview与OPC UA设备通信)

1.Labview与OPC UA设备通信 OPC UA通信协议优势显著,具体表现如下: 跨平台兼容:支持多种操作系统和硬件平台,实现无缝数据交换。高安全性:内置加密、身份验证和授权机制,确保数据传输安全。高效数据交换:采用二进制编码和优化的传输协议,提高通信效率。复杂数据建模:…

【Comsol教程】如何求解指定范围的积分 或 在积分中去除奇异点/异常值

我们在Comsol中经常需要对物体的边界求积分,比如求物体在流场中所受的总流体牵引力,又或者是物体在电场中受到的总介电泳力。当物体的材料或者边界条件存在突变时,物体表面的粘性应力或者麦克斯韦电应力可能会存在异常值。通常解决方法有细化…

Python 多版本治理理念(Windows 平台 · 零基础友好)

🧠 Python 多版本治理理念(Windows 平台 零基础友好) 🌐 核心原则:三维治理、四级隔离、五项自治 以下是基于人工智能深度学习环境搭建实践,总结出的"零基础入门 Conda工具链 全隔离项目环境"…

Python文件管理利器之Shutil库详解

Shutil是一个Python内置的用来高效处理文件和目录迁移任务的库。Shutil不仅支持基本的文件复制、移动和删除操作,还具备处理大文件、批量迁移目录、以及跨平台兼容性等特性。通过使用Shutil,我们可以更加轻松地实现文件系统的管理和维护,本文…

学习华为 ensp 的学习心得体会

引言​ 在信息技术日新月异的今天,网络技术作为连接世界的桥梁,其重要性不言而喻。作为一名对网络技术充满热情的大一新生,我选择了 eNSP(Enterprise Network Simulation Platform,企业网络模拟平台)作为我…

jenkins-2.439.1搭建

一、 二、pipeline文件 pipeline { agent any // 可以指定特定的agent, 如 label 或 docker environment { JAVA_HOME "/usr/local/software/jdk1.8.0_451" PATH "${JAVA_HOME}/bin:${env.PATH}" } tools { …

【threejs】一天一个小案例讲解:控制面板(GUI)

# 好吧,每天更新实在有点艰巨,我尽量少量多次 代码仓 所有代码都会上传到这里,可自行clone GitHub - TiffanyHoo/three_practices: Learning three.js together! 运行效果图 ​ 知识要点 一、安装dat.gui npm i dat.gui 二、使用步骤&a…