python3 gui 计时器
# -*- coding: utf-8 -*-
# @Time : 2023/4/4 21:53
# @File : 定时器gui.py
# @Software: PyCharm Community Edition '''
用tkinter制作一个图形化定时器
'''
from tkinter import *
from tkinter import messagebox
import io
import threading
# import win32gui, winsound
import argparse class Timer:
def __init__(self, Minutes, Seconds):
self.state = {'isStop': False, 'minutes': Minutes, 'seconds': Seconds}
self.createContainer() # 创建容器
def createContainer(self):
# 创建窗口实例
self.window = Tk()
self.window.title('Timer')
# 禁止全屏
self.window.resizable(False, False) self.addWidgets()
# 开启定时
self.startTimer()
# 修改主窗口退出协议
self.window.protocol('WM_DELETE_WINDOW', self.closeWindow) # 返回屏幕的宽高
# win_w = self.tk.winfo_screenwidth()
# win_h = self.tk.winfo_screenheight()
# 返回需要的宽高
x = self.window.winfo_reqwidth()
y = self.window.winfo_reqheight()
# 设置初始位置
self.window.geometry("%dx%d+%d+%d" % (208, 56, 10, 10))
# 修改图标(对启动速度有点影响)
# self.window.iconbitmap('title.ico')
# 主事件循环
self.window.mainloop() # 添加组件
def addWidgets(self):
self.Minutes = IntVar()
self.Minutes.set(self.state['minutes'])
self.Seconds = IntVar()
self.Seconds.set(self.state['seconds'])
# relief :设置3D效果
self.e_minutes = Entry(self.window, relief=RAISED, justify=RIGHT, font='Helvetica 34 bold', state='readonly',
width=2, textvariable=self.Minutes)
self.e_seconds = Entry(self.window, relief=RAISED, justify=RIGHT, font='Helvetica 34 bold', state='readonly',
width=2, textvariable=self.Seconds)
self.btn_stop_start = Button(self.window, text='Start', font='Helvetica 10', width=10, command=self.changeTimer)
self.btn_reset = Button(self.window, text='Reset', font='Helvetica 10', width=10, command=self.resetTime) # 组件布局
self.e_minutes.grid(row=0, column=0, rowspan=2)
Label(self.window, font='Helvetica 25 bold', text=':').grid(row=0, column=1, rowspan=2) # 装饰作用
self.e_seconds.grid(row=0, column=2, rowspan=2)
self.btn_stop_start.grid(row=0, column=3, sticky='e')
self.btn_reset.grid(row=1, column=3, sticky='e') # 更新时间
def updateTime(self):
# 避免按下暂停,线程还在执行
if self.state['isStop'] == True:
return
if self.Seconds.get() < 59:
self.Seconds.set(self.Seconds.get() + 1)
self.window.update()
elif self.Seconds.get() == 60 and self.Minutes.get() < 60:
self.Seconds.set(0)
self.Minutes.set(self.Minutes.get() + 1)
self.window.update() elif self.Seconds.get() == 60 and self.Minutes.get() == 60: # 没时间了,发声提示
self.Seconds.set(0)
self.window.update()
self.state['isStop'] = True # 用于停止刷新时间
self.alert()
self.startCicle() def updateTime1(self):
# 避免按下暂停,线程还在执行
if self.state['isStop'] == True:
return
if self.Seconds.get() > 0:
self.Seconds.set(self.Seconds.get() - 1)
self.window.update()
elif self.Seconds.get() == 0 and self.Minutes.get() > 0:
self.Seconds.set(59)
self.Minutes.set(self.Minutes.get() - 1)
self.window.update() elif self.Seconds.get() == 0 and self.Minutes.get() == 0: # 没时间了,发声提示
self.Seconds.set(0)
self.window.update()
self.state['isStop'] = True # 用于停止刷新时间
self.alert()
self.startCicle() # 关闭窗口 def closeWindow(self):
if self.state['isStop'] == False:
if messagebox.askyesno('It`s not time.', 'Are you sure stop?'):
self.state['isStop'] = True
self.window.quit()
else:
self.window.quit() # 重置时间
def resetTime(self):
self.Minutes.set(self.state['minutes'])
self.Seconds.set(self.state['seconds']) # 更改定时状态
def changeTimer(self):
if self.state['isStop'] == True:
self.state['isStop'] = False
self.startTimer()
else:
self.state['isStop'] = True
self.stopTimer() # 开启循环
def startCicle(self):
if self.state['isStop'] == True:
return
threading.Timer(1, self.updateTime).start() # 开始定时
def startTimer(self):
# 在时间停止时,可以修改定时时间
self.state['minutes'] = self.Minutes.get()
self.state['seconds'] = self.Seconds.get()
self.e_minutes['state'] = 'readonly'
self.e_seconds['state'] = 'readonly'
self.btn_stop_start['text'] = 'Stop'
self.window.update()
self.startCicle() # 暂停定时
def stopTimer(self):
self.btn_stop_start['text'] = 'Start'
self.e_minutes['state'] = 'normal'
self.e_seconds['state'] = 'normal'
self.window.update() # 发声提示
# def alert(self):
# winsound.Beep(600, 3000) # 发出声音提示 默认闹3s if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('-m', type=int, default=0, help='set minutes for timer')
parser.add_argument('-s', type=int, default=0, help='*set seconds for timer')
args = parser.parse_args()
Timer(args.m, args.s)
python3 gui 计时器的更多相关文章
- Python3 GUI开发(PyQt)安装和配置
Python3 GUI开发(PyQt5)安装和配置: 下载安装好Miniconda3, 并且安装好jupyter 注意:最好关闭360杀毒软件或者把cmd加入信任,否则运行activate会有问题. ...
- Python3 GUI:PyQt5环境搭建
配置镜像源 最近用Python内置的Thinter写了个小工具,发现界面略朴素,于是决定转向PyQt5.先配置镜像源,否则只能龟速下载. C:\Users\你的用户名下新建目录pip 在pip目录下新 ...
- python3 井字棋 GUI - 人机对战、机器对战 (threading、tkinter库)
python3 井字棋 GUI - 人机对战.机器对战 功能 GUI界面 人机对战(可选择机器先走) 机器对战(50局) 流程图 内核 棋盘 [0][1][2] [3][4][5] [6][7][8] ...
- 微信小游戏跳一跳简单手动外挂(基于adb 和 python)
只有两个python文件,代码很简单. shell.py: #coding:utf-8 import subprocess import math import os def execute_comm ...
- Django项目常见面试问题
1.python中的lambda是什么意思,可以举例 匿名函数 a = lambda x:x+1 print(a(1)) 2.请写出以下代码执行的结果 class Parent(object): x ...
- Java之线程———GUI线程(包含打字游戏和计时器俩个GUI实列)
当java程序包含图形用户界面(GUI)时,Java虚拟机在运行应用程序时会自动启动更多的线程,其中有两个重要的线程:AWT-EventQuecue 和 AWT-Windows. AWT-EventQ ...
- 程序员之路:python3+PyQt5+pycharm桌面GUI开发(转)
程序员之路:python3+PyQt5+pycharm桌面GUI开发 http://blog.sina.com.cn/s/blog_989218ad0102wz1k.html 先看效果: 图 1 没错 ...
- Python3+PyQt5+PyCharm 桌面GUI开发环境搭建
Python3+PyQt5+PyCharm 桌面GUI开发环境搭建 一.安装python PyQt5所支持的python版本是不低于3.5版本 python3.5以上的版本安装:https://www ...
- python3.4学习笔记(九) Python GUI桌面应用开发工具选择
python3.4学习笔记(九) Python GUI桌面应用开发工具选择 Python GUI开发工具选择 - WEB开发者http://www.admin10000.com/document/96 ...
- 使用Python3.6的标准GUI库tkinter快速创建GUI应用程序
Python 提供了多个图形开发界面的库,几个常用 Python GUI 库如下: Tkinter: Tkinter 模块(Tk 接口)是 Python 的标准 Tk GUI 工具包的接口 .Tk 和 ...
随机推荐
- 基于uni-app+vue3渲染markdown格式|uniapp软键盘顶起问题解决方案
前些时候有给大家分享一篇uni-app+vite4+uview-plus搭建跨端项目.今天主要分享下在uniapp中渲染markdown语法及uniapp中软键盘弹起,页面tabbar或顶部自定义na ...
- GO 语言中 slice 的理解
GO 语言中 slice 理解 为什么说 Go 语言的 slice 是引用类型,其底层实现明明是一个结构体? slice 的底层实现是一个包含三个字段的结构体:指向底层数组的指针.slice 的长度和 ...
- Python读取本地文件时出现错误UnicodeDecodeError
Python读取本地文件时出现错误UnicodeDecodeError: 'gbk' codec can't decode byte 0x94 in position 5702: illegal mu ...
- 平时容易忽视的地方之一:java在抽取方法时,什么时候该用void
当一个类中多个方法有相同编码,或该部分编码可以作为一个整体,适合抽取出一个方法时,要注意这个抽取的方法的返回值,什么时候可以用void,什么时候不能用void? 先看代码: import lombok ...
- 2021-10-08 Core的LaunchSettings文件说明
{ "iisSettings": { //是否以IIS Express启动 "windowsAuthentication": false, //是否启用wind ...
- 四 APPIUM GUI讲解(Windows版)(转)
Windows版本的APPIUM GUI有以下图标或者按钮: ·Android Settings - Android设置按钮,所有和安卓设置的参数都在这个里面 ·General Settings – ...
- vscode+gdb 配置
到这个网址下载 mingw c语言环境 https://sourceforge.net/projects/mingw-w64/files/mingw-w64/ 我是windows64 位,直接下载这个 ...
- markdown之mermaid
官方文档 01 简单的流程图 TD或TB:top to bottom,从上到下的流程图 LR:从左到右 其它:RL,BT flowchart LR; A([节点A的圆矩框]) --> |AB之间 ...
- HTML5CSS3基础
目录 HTML5CSS3基础 1 2D 转换 1.1 二维坐标系 1.2 2D 转换之移动 translate 1.3 2D 转换之旋转 rotate 1.4 2D 转换中心点 transform-o ...
- GGTalk 开源即时通讯系统源码剖析之:客户端全局缓存及本地存储
继上篇<GGTalk 开源即时通讯系统源码剖析之:虚拟数据库>详细介绍了 GGTalk 内置的虚拟的数据库,无需部署真实数据库便能体验GGTalk的全部功能,虚拟数据库将极大地简化服务端的 ...