基于wxpython的时钟小工具
前言
基于python3.10 + wxpython 的时钟小工具
代码由chatgpt3.5生成,作者自己调试。留作后续参考。
正文
timer_ok.py
import wx
import time
import threading
import os
class ClockCountdownPanel(wx.Panel):
def __init__(self, parent):
super(ClockCountdownPanel, self).__init__(parent)
self.background = None
self.is_cancle = True
self.clock_label = wx.StaticText(self, label="0000-00-00 00:00:00")
self.clock_label.SetBackgroundColour(wx.Colour(135, 206, 250, 128)) # 设置背景颜色和透明度
clock_font = wx.Font(24, wx.FONTFAMILY_DEFAULT, wx.FONTSTYLE_NORMAL, wx.FONTWEIGHT_BOLD)
self.clock_label.SetFont(clock_font)
self.countdown_label = wx.StaticText(self, label="00:00:00")
self.countdown_label.SetBackgroundColour(wx.Colour(255, 182, 193, 30))
countdown_font = wx.Font(18, wx.FONTFAMILY_DEFAULT, wx.FONTSTYLE_NORMAL, wx.FONTWEIGHT_BOLD)
self.countdown_label.SetFont(countdown_font)
self.countdown_text = wx.TextCtrl(self, value="00:00:00")
self.start_button = wx.Button(self, label="Start")
# self.start_button.SetBackgroundColour(wx.Colour(144, 238, 144, 128))
self.cancel_button = wx.Button(self, label="Cancel")
# self.cancel_button.SetBackgroundColour(wx.Colour(255,255,193,128))
self.start_button.Bind(wx.EVT_BUTTON, self.start_countdown)
self.cancel_button.Bind(wx.EVT_BUTTON, self.cancel_countdown)
sizer = wx.BoxSizer(wx.VERTICAL)
clock_sizer = wx.BoxSizer(wx.HORIZONTAL)
clock_sizer.AddStretchSpacer()
clock_sizer.Add(self.clock_label, flag=wx.ALIGN_CENTER_VERTICAL, proportion=1)
clock_sizer.AddStretchSpacer()
sizer.Add(clock_sizer, flag=wx.EXPAND|wx.ALL, border=10, proportion=1)
sizer.Add(wx.StaticLine(self), flag=wx.EXPAND|wx.ALL, border=10)
countdown_sizer = wx.BoxSizer(wx.VERTICAL)
countdown_sizer.Add(self.countdown_label, flag=wx.ALIGN_CENTER, proportion=1)
countdown_sizer.Add(self.countdown_text, flag=wx.ALIGN_CENTER|wx.ALL, border=10, proportion=1)
buttons_sizer = wx.BoxSizer(wx.HORIZONTAL)
buttons_sizer.Add(self.start_button, flag=wx.ALIGN_CENTER|wx.ALL, border=10)
buttons_sizer.Add(self.cancel_button, flag=wx.ALIGN_CENTER|wx.ALL, border=10)
countdown_sizer.Add(buttons_sizer, flag=wx.ALIGN_CENTER, proportion=2)
sizer.Add(countdown_sizer, flag=wx.EXPAND|wx.ALL, border=10, proportion=2)
self.SetSizer(sizer)
self.timer = wx.Timer(self)
self.Bind(wx.EVT_TIMER, self.update_clock, self.timer)
self.timer.Start(1000) # 每隔一秒钟更新一次时钟
def update_clock(self, event):
current_time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
self.clock_label.SetLabel(current_time)
def start_countdown(self, event):
self.is_cancle = False
countdown_time = self.countdown_text.GetValue()
countdown_thread = threading.Thread(target=self.run_countdown, args=(countdown_time,))
countdown_thread.start()
def cancel_countdown(self, event):
# self.timer.Stop()
self.is_cancle = True
self.countdown_label.SetLabel("00:00:00")
def run_countdown(self, countdown_time):
hours, minutes, seconds = countdown_time.split(":")
total_seconds = int(hours) * 3600 + int(minutes) * 60 + int(seconds)
while self.is_cancle is False and total_seconds >= 0:
hours = total_seconds // 3600
minutes = (total_seconds % 3600) // 60
seconds = total_seconds % 60
countdown_str = f"{hours:02d}:{minutes:02d}:{seconds:02d}"
self.countdown_label.SetLabel(countdown_str)
total_seconds -= 1
wx.MilliSleep(1000) # 等待一秒钟
wx.MessageBox("倒计时结束了, 休息一下吧")
def set_background(self, image_path):
if os.path.exists(image_path):
image = wx.Image(image_path, wx.BITMAP_TYPE_ANY)
image = image.Scale(self.GetSize().GetWidth(), self.GetSize().GetHeight())
self.background = wx.Bitmap(image)
self.Refresh()
else:
wx.MessageBox("未找到背景图片: 背景图片.png")
def paint_background(self, event):
if self.background:
dc = wx.BufferedPaintDC(self)
dc.DrawBitmap(self.background, 0, 0)
class MainFrame(wx.Frame):
def __init__(self, *args, **kw):
super(MainFrame, self).__init__(*args, **kw)
# 禁止最大化和最小化图标
self.SetWindowStyle(wx.DEFAULT_FRAME_STYLE & ~(wx.MAXIMIZE_BOX | wx.MINIMIZE_BOX))
self.panel = ClockCountdownPanel(self)
self.panel.Bind(wx.EVT_PAINT, self.panel.paint_background)
self.Bind(wx.EVT_SIZING, self.on_size)
self.SetSize((640, 360))
self.SetTitle("小工具")
self.Centre()
self.panel.set_background("背景图片.png")
def on_size(self, event):
self.panel.set_background("背景图片.png")
if __name__ == '__main__':
app = wx.App()
frame = MainFrame(None)
frame.Show(True)
app.MainLoop()
运行效果:

背景图片.png

打包指令:
# D:\python3.10\Lib\site-packages\ 换成实际的 site-packages 所在目录
pyinstaller3 -F .\timer_ok.py --icon=背景图片.png --noconsole -p D:\python3.10\Lib\site-packages\
基于wxpython的时钟小工具的更多相关文章
- 一个基于vue的时钟
前两天写了一个基于vue的小钟表,给大家分享一下. 其中时针和分针使用的是图片,结合transform制作:表盘刻度是通过transform和transformOrigin配合画的:外面的弧形框框,啊 ...
- 基于百度通用翻译API的一个翻译小工具
前几天写了一个简单的翻译小工具,是基于有道翻译的,不过那个翻译接口有访问限制,超过一定次数后会提示访问过于频繁,偶然发现百度翻译API如果月翻译字符少于200万是不收取费用的,所以就注册了一个百度开发 ...
- 设计一款可扩展和基于windows系统的一键处理表格小工具思路
原创总结/朱季谦 设计一款可扩展和基于windows系统的一键处理表格小工具思路 日常开发当中,业务人员经常会遇到一些重复性整理表格的事情,这时候,就可以通过一些方式进行自动化程序处理,提高工作(摸鱼 ...
- 【原创】基于UDP广播的局域网Web Window Service日志跟踪小工具
一直感觉Web开发或者windows服务的日志跟踪调试不是很方便 特别是在生产环境服务器上面 目前一般的解决方案是通过各种日志工具把错误信息和调试信息 ...
- 手把手教你写一个windows服务 【基于.net】 附实用小工具{注册服务/开启服务/停止服务/删除服务}
1,本文适用范围 语言:.net 服务类型:windows服务,隔一段时间执行 2,服务搭建: 1,在vs中创建 console程序 2,在console项目所在类库右键 添加-新建项-选择Windo ...
- 基于Xposed Hook实现的Android App的协议算法分析小工具-CryptoFucker
本文博客地址:https://blog.csdn.net/QQ1084283172/article/details/80962121 在进行Android应用的网络协议分析的时候,不可避免涉及到网络传 ...
- 2000条你应知的WPF小姿势 基础篇<45-50 Visual Tree&Logic Tree 附带两个小工具>
在正文开始之前需要介绍一个人:Sean Sexton. 来自明尼苏达双城的软件工程师.最为出色的是他维护了两个博客:2,000Things You Should Know About C# 和 2,0 ...
- python开发目录合并小工具 PathMerge
前言 这个程序陆陆续续开发了几天,正好我在学Python,就一边做一边学,倒是学到不少东西. 不得不说python是快速开发的好工具. 程序做了一些改进,这两天又忙着毕设,现在才想起来发到博客上.想想 ...
- JSON生成c#类代码小工具
JSON生成c#类代码小工具 为什么写这么个玩意 最近的项目中需要和一个服务端程序通讯,而通讯的协议是基于流行的json,由于是.net,所以很简单的从公司代码库里找到了Newtonsoft.dll( ...
- Animo.js :一款管理 CSS 动画的强大的小工具
Animo.js 是一个功能强大的小工具,用于管理 CSS 动画.它的特色功能包括像堆栈动画,创建跨浏览器的模糊,设置动画完成的回调等等.Animo 还包括惊人的 animate.css,为您提供了近 ...
随机推荐
- WEB服务与NGINX(2)-NGINX的I/O模型
WEB服务与NGINX(2)-NGINX的I/O模型 目录 WEB服务与NGINX(2)-NGINX的I/O模型 1. linux I/0模型及在NGINX中的应用 1.1 I/O模型概述 1.2 系 ...
- 机器学习策略:详解什么时候该改变开发/测试集和指标?(When to change dev/test sets and metrics)
什么时候该改变开发/测试集和指标? 有时候在项目进行途中,可能意识到,目标的位置放错了.这种情况下,应该移动的目标. 来看一个例子,假设在构建一个猫分类器,试图找到很多猫的照片,向的爱猫人士用户展示, ...
- 小程序中 canvas 的图片不支持 base64 格式
首先使用 wx.base64ToArrayBuffer 将 base64 数据转换为 ArrayBuffer 数据,使用FileSystemManager.writeFile 将 ArrayBuffe ...
- RediSearch的简单使用与总结
前言 之前就有考虑过想要研究下RediSearch,号称高性能全文索引的功能,这几天闲来无事调研了一番. RediSearch 介绍 RediSearch 是 Redis Labs 提供的一款强大且高 ...
- vue绑定对象,绑定的值不改变的问题
在使用vue结合elmentui的table组件,对数组绑定,需要编辑数组里一些属性的值.我的情况是,需要在打开这个表时,根据条件插入一些对象到table里,经测试,到这里是没问题的,可以显示新插入的 ...
- 【c#】JavaScriptSerializer 不序列化null值
首先引用dll :System.Web.Extensions. 再自定义转换器代码如下: public class JavaScriptSerilizeConvert : JavaScriptConv ...
- Tkinter禁止用户调整窗口尺寸大小
禁止用户调整窗口尺寸大小的方式: root.resizable(False,False) 例子: from tkinter import * from tkinter import ttk impor ...
- 高精度离线免费 的C#文字识别PaddleOCR库
随便打开一个Microsoft Visual Studio,新建一个WinForms项目,从下面列表中随便选择一个NET框架.目标平台要设置成X64,该OCR仅支持64位. net35;net40;n ...
- Opencv笔记(12)傅里叶变换
在之前了解的OpenCV为我们实现的图像变换,这些本质上是从图像到输出图像的映射,即输入仍是一幅图像.本章的傅里叶变换,输出数组的值在含义上和原图像的强度值大不相同,是输入图像的频域表示. cv::d ...
- vue 实现商品列表的添加、删除,搜索
大江东去,浪淘尽,千古风流人物.故垒西边,人道是,三国周郎赤壁.乱石穿空,惊涛拍岸,卷起千堆雪.江山如画,一时多少豪杰.遥想公瑾当年,小乔初嫁了,雄姿英发.羽扇纶巾,谈笑间,樯橹灰飞烟灭.故国神游,多 ...