Python 写的《桌面时钟》屏保

Python 写的《桌面时钟》屏保

原代码:

# 日历式时钟 # 导入所需的库 # 作者:Hoye # 日期:2024年12月16日 # 功能:显示当前日期、星期、时间,并显示模拟时钟 import tkinter as tk from tkinter import ttk import time import math import sys def exit_screensaver(event=None): root.quit() def draw_clock_face(): # 清除画布 clock_canvas.delete("all") # 获取当前时间 current_time = time.localtime() hours = current_time.tm_hour % 12 minutes = current_time.tm_min seconds = current_time.tm_sec # 时钟外圈 clock_canvas.create_oval(10, 10, 390, 390, width=2, outline="#ECF0F1") # 绘制刻度和数字 for i in range(12): angle = i * math.pi/6 - math.pi/2 # 刻度线 start_x = 200 + 190 * math.cos(angle) start_y = 200 + 190 * math.sin(angle) end_x = 200 + 180 * math.cos(angle) end_y = 200 + 180 * math.sin(angle) width = 3 if i % 3 == 0 else 1 clock_canvas.create_line(start_x, start_y, end_x, end_y, fill="#ECF0F1", width=width) # 添加数字 num = 12 if i == 0 else i text_x = 200 + 155 * math.cos(angle) text_y = 200 + 155 * math.sin(angle) clock_canvas.create_text(text_x, text_y, text=str(num), font=("Microsoft YaHei UI", 20, "bold"), fill="#ECF0F1") # 时针 hour_angle = (hours + minutes/60) * math.pi/6 - math.pi/2 hour_x = 200 + 100 * math.cos(hour_angle) hour_y = 200 + 100 * math.sin(hour_angle) clock_canvas.create_line(200, 200, hour_x, hour_y, fill="#3498DB", width=8) # 分针 min_angle = minutes * math.pi/30 - math.pi/2 min_x = 200 + 140 * math.cos(min_angle) min_y = 200 + 140 * math.sin(min_angle) clock_canvas.create_line(200, 200, min_x, min_y, fill="#ECF0F1", width=6) # 秒针 sec_angle = seconds * math.pi/30 - math.pi/2 sec_x = 200 + 160 * math.cos(sec_angle) sec_y = 200 + 160 * math.sin(sec_angle) clock_canvas.create_line(200, 200, sec_x, sec_y, fill="#BDC3C7", width=2) # 中心点 clock_canvas.create_oval(195, 195, 205, 205, fill="#3498DB") # 每秒更新 root.after(1000, draw_clock_face) def update_clock(): current_time = time.localtime() year = current_time.tm_year month = current_time.tm_mon day = current_time.tm_mday weekday = current_time.tm_wday hours = current_time.tm_hour minutes = current_time.tm_min seconds = current_time.tm_sec date_str = f"{year}年{month:02d}月{day:02d}日" weekday_str = ["星期一", "星期二", "星期三", "星期四", "星期五", "星期六", "星期日"][weekday] time_str = f"{hours:02d}:{minutes:02d}:{seconds:02d}" date_label.config(text=date_str) weekday_label.config(text=weekday_str) time_label.config(text=time_str) root.after(1000, update_clock) # 创建主窗口 root = tk.Tk() root.title("蓝动力电脑-桌面时钟") # 设置全屏 root.attributes('-fullscreen', True) # 全屏显示 root.attributes('-topmost', True) # 窗口置顶 root.config(cursor="none") # 隐藏鼠标光标 # 绑定退出事件 root.bind('<Key>', exit_screensaver) # 任意键退出 root.bind('<Motion>', exit_screensaver) # 鼠标移动退出 root.bind('<Button>', exit_screensaver) # 鼠标点击退出 root.bind('<Escape>', exit_screensaver) # ESC键退出 # 获取屏幕尺寸 screen_width = root.winfo_screenwidth() screen_height = root.winfo_screenheight() # 设置背景渐变色 main_frame = tk.Frame(root) main_frame.pack(expand=True, fill='both') main_frame.configure(bg='#2C3E50') # 创建内容框架 content_frame = tk.Frame(main_frame, bg='#2C3E50', padx=20, pady=20) content_frame.pack(expand=True) # 创建左侧模拟时钟框架 analog_frame = tk.Frame(content_frame, bg='#34495E', padx=30, pady=30) analog_frame.pack(side='left', padx=20) # 创建模拟时钟画布 clock_canvas = tk.Canvas( analog_frame, width=400, height=400, bg='#34495E', highlightthickness=0 ) clock_canvas.pack() # 创建右侧数字时钟容器 clock_frame = tk.Frame(content_frame, bg='#34495E', padx=30, pady=30) clock_frame.pack(side='right', padx=20) # 日期标签 date_label = tk.Label( clock_frame, font=("Microsoft YaHei UI", 48, "bold"), fg="#ECF0F1", bg="#34495E" ) date_label.pack(pady=20) # 星期标签 weekday_label = tk.Label( clock_frame, font=("Microsoft YaHei UI", 36), fg="#BDC3C7", bg="#34495E" ) weekday_label.pack(pady=20) # 时间标签 time_label = tk.Label( clock_frame, font=("Microsoft YaHei UI", 120, "bold"), fg="#3498DB", bg="#34495E" ) time_label.pack(pady=30) # 添加版权信息 footer_label = tk.Label( main_frame, text="蓝动力电脑 © 2024", font=("Microsoft YaHei UI", 14), fg="#95A5A6", bg="#2C3E50" ) footer_label.pack(side='bottom', pady=15) # 启动时钟更新 update_clock() draw_clock_face() # 启动主循环 root.mainloop()
代码简说:

1. 添加了 exit_screensaver 函数处理退出事件  

2. 设置窗口属性:  

• root.attributes('-fullscreen', True) 实现全屏显示  

• root.attributes('-topmost', True) 使窗口始终置顶  

• root.config(cursor="none") 隐藏鼠标光标  

3. 绑定各种退出事件:  

• 键盘按键  

• 鼠标移动  

• 鼠标点击 

打包成exe 再改 成 .scr

setup.py

import PyInstaller.__main__ PyInstaller.__main__.run([ '9_日历式时钟.py', '--name=蓝动力时钟屏保', '--noconsole', '--onefile', # '--icon=clock.ico', # 如果您有图标文件的话 '--windowed', ])
py setup.py
1. 打包完成后,在 dist 目录下找到生成的 exe 文件  

2. 将 exe 文件复制一份,改名为 .scr 后缀  • 例如:蓝动力时钟屏保.exe → 蓝动力时钟屏保.scr  

3. 将 .scr 文件复制到 Windows 系统目录:

 • 通常是 C:\Windows\System32

 • 或者 C:\Windows\SysWOW64(64位系统)

 4. 在 Windows 设置中设置屏保:

 • 右键桌面 → 个性化

 • 锁屏界面 → 屏幕保护程序设置

 • 在屏幕保护程序下拉菜单中选择"蓝动力时钟屏保"

增加 查看待办事项 

 待办事项 保存在 同一目录下todo.txt

新代码如下:

# 日历式时钟 # 导入所需的库 # 作者:Hoye # 日期:2025年6月8日 # 功能:显示当前日期、星期、时间,并显示模拟时钟 import tkinter as tk from tkinter import ttk import time import math import sys def exit_screensaver(event=None): root.quit() def draw_clock_face(): # 清除画布 clock_canvas.delete("all") # 获取当前时间 current_time = time.localtime() hours = current_time.tm_hour % 12 minutes = current_time.tm_min seconds = current_time.tm_sec # 时钟外圈 clock_canvas.create_oval(10, 10, 390, 390, width=2, outline="#ECF0F1") # 绘制刻度和数字 for i in range(12): angle = i * math.pi/6 - math.pi/2 # 刻度线 start_x = 200 + 190 * math.cos(angle) start_y = 200 + 190 * math.sin(angle) end_x = 200 + 180 * math.cos(angle) end_y = 200 + 180 * math.sin(angle) width = 3 if i % 3 == 0 else 1 clock_canvas.create_line(start_x, start_y, end_x, end_y, fill="#ECF0F1", width=width) # 添加数字 num = 12 if i == 0 else i text_x = 200 + 155 * math.cos(angle) text_y = 200 + 155 * math.sin(angle) clock_canvas.create_text(text_x, text_y, text=str(num), font=("Microsoft YaHei UI", 20, "bold"), fill="#ECF0F1") # 时针 hour_angle = (hours + minutes/60) * math.pi/6 - math.pi/2 hour_x = 200 + 100 * math.cos(hour_angle) hour_y = 200 + 100 * math.sin(hour_angle) clock_canvas.create_line(200, 200, hour_x, hour_y, fill="#3498DB", width=8) # 分针 min_angle = minutes * math.pi/30 - math.pi/2 min_x = 200 + 140 * math.cos(min_angle) min_y = 200 + 140 * math.sin(min_angle) clock_canvas.create_line(200, 200, min_x, min_y, fill="#ECF0F1", width=6) # 秒针 sec_angle = seconds * math.pi/30 - math.pi/2 sec_x = 200 + 160 * math.cos(sec_angle) sec_y = 200 + 160 * math.sin(sec_angle) clock_canvas.create_line(200, 200, sec_x, sec_y, fill="#FFA500", width=2) # 中心点 clock_canvas.create_oval(195, 195, 205, 205, fill="#3498DB") # 每秒更新 root.after(1000, draw_clock_face) def update_clock(): current_time = time.localtime() year = current_time.tm_year month = current_time.tm_mon day = current_time.tm_mday weekday = current_time.tm_wday hours = current_time.tm_hour minutes = current_time.tm_min seconds = current_time.tm_sec date_str = f"{year}年{month:02d}月{day:02d}日" weekday_str = ["星期一", "星期二", "星期三", "星期四", "星期五", "星期六", "星期日"][weekday] time_str = f"{hours:02d}:{minutes:02d}:" seconds_str = f"{seconds:02d}" date_label.config(text=date_str) weekday_label.config(text=weekday_str) time_label.config(text=time_str) seconds_label.config(text=seconds_str) root.after(1000, update_clock) todo_win = None # 全局变量,记录待办事项窗口 todo_file = "todo.txt" # 待办事项保存文件 def show_todo(event=None): global todo_win if todo_win is not None and tk.Toplevel.winfo_exists(todo_win): todo_win.destroy() todo_win = None return todo_win = tk.Toplevel(root) todo_win.title("待办事项") todo_win.geometry("400x300") todo_win.attributes('-topmost', True) todo_win.grab_set() todo_win.focus_set() todo_win.configure(bg='#34495E') label = tk.Label(todo_win, text="待办事项", font=("Microsoft YaHei UI", 20, "bold"), fg="#3498DB", bg='#34495E') label.pack(pady=10) text = tk.Text(todo_win, font=("Microsoft YaHei UI", 14), bg="#ECF0F1", height=10) text.pack(padx=20, pady=10, fill='both', expand=True) # 加载内容 try: with open(todo_file, 'r', encoding='utf-8') as f: content = f.read() text.insert('1.0', content) except Exception: pass def save_content(event=None): try: with open(todo_file, 'w', encoding='utf-8') as f: f.write(text.get('1.0', 'end-1c')) except Exception: pass def close_todo(event=None): global todo_win save_content() if todo_win is not None: todo_win.destroy() todo_win = None btn = tk.Button(todo_win, text="关闭", font=("Microsoft YaHei UI", 12), command=close_todo) btn.pack(pady=10) todo_win.protocol("WM_DELETE_WINDOW", close_todo) todo_win.bind('<Escape>', close_todo) text.bind('<Control-s>', save_content) # Ctrl+S手动保存 text.bind('<KeyRelease>', lambda e: save_content()) # 自动保存 # 创建主窗口 root = tk.Tk() root.title("蓝动力电脑-桌面时钟") # 设置全屏 root.attributes('-fullscreen', True) # 全屏显示 root.attributes('-topmost', True) # 窗口置顶 root.config(cursor="none") # 隐藏鼠标光标 # 绑定退出事件 root.bind('<Key>', exit_screensaver) # 任意键退出 root.bind('<Motion>', exit_screensaver) # 鼠标移动退出 root.bind('<Button>', exit_screensaver) # 鼠标点击退出 root.bind('<Escape>', exit_screensaver) # ESC键退出 root.bind('<space>', show_todo) # 空格弹出待办事项 # 获取屏幕尺寸 screen_width = root.winfo_screenwidth() screen_height = root.winfo_screenheight() # 设置背景渐变色 main_frame = tk.Frame(root) main_frame.pack(expand=True, fill='both') main_frame.configure(bg='#2C3E50') # 创建内容框架 content_frame = tk.Frame(main_frame, bg='#2C3E50', padx=20, pady=20) content_frame.pack(expand=True) # 创建左侧模拟时钟框架 analog_frame = tk.Frame(content_frame, bg='#34495E', padx=30, pady=30) analog_frame.pack(side='left', padx=20, fill='both', expand=True) # 创建模拟时钟画布 clock_canvas = tk.Canvas( analog_frame, width=400, height=400, bg='#34495E', highlightthickness=0 ) clock_canvas.pack(expand=True) # 创建右侧数字时钟容器 clock_frame = tk.Frame(content_frame, bg='#34495E', padx=30, pady=30) clock_frame.pack(side='right', padx=20, fill='both', expand=True) # 日期标签 date_label = tk.Label( clock_frame, font=("Microsoft YaHei UI", 36, "bold"), fg="#ECF0F1", bg="#34495E" ) date_label.pack(pady=10) # 星期标签 weekday_label = tk.Label( clock_frame, font=("Microsoft YaHei UI", 28), fg="#BDC3C7", bg="#34495E" ) weekday_label.pack(pady=10) # 时间标签(时分秒合并一行,使用Text或Label+标签嵌套) time_frame = tk.Frame(clock_frame, bg='#34495E') time_frame.pack(pady=10) time_label = tk.Label( time_frame, font=("Microsoft YaHei UI", 80, "bold"), fg="#3498DB", bg="#34495E" ) time_label.pack(side='left') seconds_label = tk.Label( time_frame, font=("Microsoft YaHei UI", 80, "bold"), fg="#FFA500", bg="#34495E" ) seconds_label.pack(side='left') # 添加版权信息 footer_label = tk.Label( main_frame, text="蓝动力电脑 © 2025 | 按空格键查看待办事项 ESC 键退出并保存", font=("Microsoft YaHei UI", 14), fg="#95A5A6", bg="#2C3E50" ) footer_label.pack(side='bottom', pady=15) # 启动时钟更新 update_clock() draw_clock_face() # 启动主循环 root.mainloop()
注:按空格键查看待办事项 ESC 键退出并保存

Read more

Flutter 组件 humanize 的适配 鸿蒙Harmony 深度进阶 - 驾驭多语言复数逻辑算法、实现鸿蒙端中式大额单位感知与极致人性化文本渲染方案

Flutter 组件 humanize 的适配 鸿蒙Harmony 深度进阶 - 驾驭多语言复数逻辑算法、实现鸿蒙端中式大额单位感知与极致人性化文本渲染方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 humanize 的适配 鸿蒙Harmony 深度进阶 - 驾驭多语言复数逻辑算法、实现鸿蒙端中式大额单位感知与极致人性化文本渲染方案 前言 在前文我们掌握了 humanize 进行基础数据转换的方法。但在鸿蒙(OpenHarmony)面向全球市场的布局中,真正的技术挑战往往隐藏在极其琐碎的“语言表达”中。例如:在英文中我们说 1 items 是错误的,必须是 1 item 与 2 items;而在中文环境下,我们虽然没有复数形变,但却有“万、亿”这类独特的四位一级计数逻辑。 一个真正具备“高级感”的鸿蒙应用,不应在数据展示上显得僵硬且带有明显的机器翻译痕迹。 本文将作为 humanize 适配的进阶篇,带你攻克多语言复数(Pluralization)

By Ne0inhk
Flutter for OpenHarmony: Flutter 三方库 directed_graph 在鸿蒙应用中优雅处理复杂的拓扑排序与依赖关系(算法级工具)

Flutter for OpenHarmony: Flutter 三方库 directed_graph 在鸿蒙应用中优雅处理复杂的拓扑排序与依赖关系(算法级工具)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在进行 OpenHarmony 的复杂业务逻辑设计时,我们经常会遇到“依赖关联”问题。例如: 1. 任务调度:任务 A 依赖于任务 B 和 C,任务 B 依赖于 D。你应该按什么顺序运行它们? 2. 数据流建模:在鸿蒙分布式节点中,数据是如何从一个端点流向另一个端点的?是否存在循环引用(Cycle)? 3. 资源加载器:一个大型鸿蒙 HAP 包内的资源加载优先级排序。 directed_graph 是一款纯粹的、算法级别的 Dart 库。它提供了标准的数据结构模型,能帮你极其高效地处理这些复杂的拓扑(Topology)关系。 一、有向图逻辑模型 该库支持对图节点进行深度遍历、

By Ne0inhk

Docker一站式部署:RustFS、GoFastDFS、Gitea与PostgreSQL实战指南

1. 前言 在现代软件开发和部署中,Docker已成为不可或缺的工具。它提供了轻量级、可移植的容器化解决方案,使应用部署变得简单高效。本文将详细介绍如何使用Docker一键部署四个常用服务:RustFS(高性能文件存储)、GoFastDFS(分布式文件系统)、Gitea(自托管Git服务)和PostgreSQL(关系型数据库)。无论你是个人开发者还是团队负责人,这些服务都能为你的项目提供强大支持。 2. 前提条件 * 已安装Docker(版本20.10+) * 已安装Docker Compose(版本1.29+) * 64位操作系统(Windows/Linux/Mac) * 至少4GB可用内存 3. RustFS部署 RustFS是一款使用Rust语言编写的高性能文件存储系统,支持S3协议,适用于私有云存储场景。 3.1 Docker命令部署 Linux: docker run -d \ --name rustfs_container \ --user root \ -p

By Ne0inhk
解密链表环的起点:LeetCode 142 题

解密链表环的起点:LeetCode 142 题

解密链表环的起点:LeetCode 142 题 * 视频地址 * 🌟 引言 * 🔍 问题描述 * 🧠 解题思路回顾 * 快慢指针算法 * 数学原理 * 💻 C++代码实现 * 🛠 代码解析 * 数据结构定义 * 算法实现细节 * 🚀 性能分析 * 🐞 常见问题与调试 * 常见错误 * 调试技巧 * 📊 复杂度对比表 * 🌈 总结 视频地址 因为想更好的为大佬服务,制作了同步视频,这是Bilibili的视频地址 🌟 引言 链表环检测问题在C++中同样是一个经典面试题。本文将用C++实现LeetCode 142题"环形链表II"的解决方案,深入讲解快慢指针算法的原理和实现细节。 🔍 问题描述 给定一个链表的头节点 head,返回链表开始入环的第一个节点。如果链表无环,则返回 nullptr。 🧠 解题思路回顾 快慢指针算法 1. 使用两个指针:slow每次走一步,fast每次走两步 2.

By Ne0inhk