幽灵资源网 Design By www.bzswh.com
过年GUI博客二连发,本打算出去玩玩,奈何空气,天气实在差,遂使用tkinter开发一款GUI刷屏器,写此博客记录一下我的开发思路。
一.准备工作
本次使用除tkinter库之外还使用了pynput库,可以使用
pip install pynput
安装
二.预览
在长文本框中输入要刷屏的内容,通过设置刷屏频率(单位:秒)即可实现刷屏。
三.设计流程
四.源代码
import re import time import pyperclip from tkinter import * from tkinter import messagebox from tkinter import ttk from pynput.keyboard import Key, Controller import threading from PIL import Image ,ImageTk ''' 难点 按键复用 ''' imgs=["./rely/logo.png",'./rely/favicon.ico'] class App: def __init__(self): self.flag=True self.window = Tk() width = 230 height = 260 screenWidth = self.window.winfo_screenwidth() # 获取显示区域的宽度 screenHeight = self.window.winfo_screenheight() # 获取显示区域的高度 left = (screenWidth - width) / 2 top = (screenHeight - height) / 2 self.window.geometry("%dx%d+%d+%d" % (width, height, left, top)) self.window.title('刷一刷-v1.0') self.window.iconbitmap(imgs[1]) self.window.resizable(0, 0) self.create_widget() self.config_widget() self.place_widget() self.window.mainloop() def create_widget(self): self.paned=PanedWindow(self.window) self.img=imgs photo = Image.open(self.img[0]) # 括号里为需要显示在图形化界面里的图片 photo = photo.resize((150, 50)) # 规定图片大小 self.paned.img = ImageTk.PhotoImage(photo) self.l0 = Label(self.window, image=self.paned.img, justify='center') self.l1 = ttk.Label(self.window, text='内容:') self.l1 = ttk.Label(self.window, text='频率:') self.t1 = Text(self.window) self.c1 = ttk.Combobox(self.window, width=13) self.l2=ttk.Label(self.window,text='秒/次') self.b1 = ttk.Button(self.window, text='开始', ) self.b2 = ttk.Button(self.window, text='退出',) self.m=Menu(self.window) self.window['menu']=self.m self.s1=Menu(self.m,tearoff=False) self.s2=Menu(self.m,tearoff=False) self.s3=Menu(self.m,tearoff=False) def place_widget(self): self.l0.pack() self.l1.place(x=20, y=90) self.t1.place(x=40, y=60, width=150, height=80) self.l1.place(x=20, y=162) self.c1.place(x=65, y=160,width=80) self.l2.place(x=160,y=160) self.b1.place(x=20, y=200) self.b2.place(x=125, y=200) def config_widget(self): self.b1.config(command=lambda: self.thread_it(self.start)) self.b2.config( command=self.window_quit) rate_list=['1','0.1','0.01'] self.c1.config(value=rate_list) self.m.add_cascade(label='文件',menu=self.s1) self.s1.add_command(label='退出',command=self.window_quit) self.m.add_cascade(label='操作',menu=self.s2) self.m.add_cascade(label='关于',menu=self.s3) self.s2.add_command(label='开始 F9',command=lambda: self.thread_it(self.start)) self.s2.add_command(label='停止 F10',command=lambda: self.thread_it(self.start)) self.s3.add_command(label='说明',command=self.show_infos) #设置热键 self.window.bind('<F9>',lambda: self.thread_it(self.pre_start)) self.window.bind('<F10>',lambda: self.thread_it(self.pre_start)) self.window.bind('<Escape>',self.escape) self.window.bind('<FocusIn>',self.clear_content) self.window.protocol('WM_DELETE_WINDOW',self.window_quit) def clear_content(self,event): self.t1.delete(0.0,END) def pre_start(self,event): self.start() def start(self): if self.b1['text']=='开始': self.flag=True t1_content = self.t1.get(1.0, 'end').strip() if len(t1_content) != 0: gap = self.c1.get() try: if re.match('(^0|^1)\.{0,1}\d+$', gap) or int(gap) > 0: # 将t1内容复制到剪切板 pyperclip.copy(t1_content) keyboard = Controller() self.b1.config(text='停止') self.t1.config(state='disable') while True: # 使用control+v组合键进行粘贴 if self.flag: keyboard.press(Key.ctrl.value) keyboard.press('v') keyboard.release('v') keyboard.release(Key.ctrl.value) keyboard.press(Key.enter.value) keyboard.release(Key.enter.value) print(t1_content) time.sleep(float(gap)) else: break else: messagebox.showerror('错误', '请输入正确的数值!') self.c1.delete(0, END) except ValueError: messagebox.showerror('错误', '请输入正确的数值!') self.c1.delete(0, END) else: messagebox.showerror('错误', '还没有输入内容') else: self.flag=False self.b1.config(text='开始') def thread_it(self,func,*args): t=threading.Thread(target=func,args=args) t.setDaemon(True)#设置守护线程,即主线程结束,子线程也结束 t.start() def show_infos(self): messagebox.showinfo('说明','***本软件完全免费***\n\n1.输入刷屏内容\n2.选择(输入)刷屏频率\n3.开始(F9)刷屏\n4.停止(F10)刷屏') def window_quit(self): ret=messagebox.askyesno('退出','是否要退出?') if ret: self.window.destroy() def escape(self,event): self.window_quit() if __name__ == '__main__': a=App()
五.总结
本次使用tkinter写了一款刷屏器,能够实现短时间内相同文本的发送,继而实现刷屏的目的。在代码的撰写上,模拟键盘输入主要参考了:
python模拟鼠标点击和键盘输入的操作
实现了组合键Ctrl+V的操作。本篇技术含量不多,重点在代码逻辑思路上。
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。