一直想用python实现一个类似QQ截图的功能,但不直接截图,而是返回截图的区域,以下是代码
# -*- coding:utf-8 -*- import tkinterimport tkinter.filedialogimport osfrom PIL import ImageGrabfrom time import sleepfrom tkinter import StringVar, IntVar#创建tkinter主窗口root = tkinter.Tk()#指定主窗口位置与大小root.geometry('200x80+400+300')#不允许改变窗口大小root.resizable(False, False)class MyCapture: def __init__(self, png): #变量X和Y用来记录鼠标左键按下的位置 self.X = tkinter.IntVar(value=0) self.Y = tkinter.IntVar(value=0) self.selectPosition=None #屏幕尺寸 screenWidth = root.winfo_screenwidth() #print(screenWidth) screenHeight = root.winfo_screenheight() #print(screenHeight) #创建顶级组件容器 self.top = tkinter.Toplevel(root, width=screenWidth, height=screenHeight) #不显示最大化、最小化按钮 self.top.overrideredirect(True) self.canvas = tkinter.Canvas(self.top,bg='white', width=screenWidth, height=screenHeight) #显示全屏截图,在全屏截图上进行区域截图 self.p_w_picpath = tkinter.PhotoImage(file=png) self.canvas.create_p_w_picpath(screenWidth//2, screenHeight//2, p_w_picpath=self.p_w_picpath) #鼠标左键按下的位置 def onLeftButtonDown(event): self.X.set(event.x) self.Y.set(event.y) #开始截图 self.sel = True self.canvas.bind('', onLeftButtonDown) #鼠标左键移动,显示选取的区域 def onLeftButtonMove(event): if not self.sel: return global lastDraw try: #删除刚画完的图形,要不然鼠标移动的时候是黑乎乎的一片矩形 self.canvas.delete(lastDraw) except Exception as e: pass lastDraw = self.canvas.create_rectangle(self.X.get(), self.Y.get(), event.x, event.y, outline='black') self.canvas.bind(' ', onLeftButtonMove) #获取鼠标左键抬起的位置,保存区域截图 def onLeftButtonUp(event): self.sel = False try: self.canvas.delete(lastDraw) except Exception as e: pass sleep(0.1) #考虑鼠标左键从右下方按下而从左上方抬起的截图 myleft, myright = sorted([self.X.get(), event.x]) mytop, mybottom = sorted([self.Y.get(), event.y]) self.selectPosition=(myleft,myright,mytop,mybottom)# pic = ImageGrab.grab((left+1, top+1, right, bottom))# # #弹出保存截图对话框# # fileName = tkinter.filedialog.asksaveasfilename(title='保存截图', filetypes=[('JPG files', '*.jpg')])# # if fileName:# # pic.save(fileName+'.jpg') #关闭当前窗口 #print(left, ' ', top,' ',right,' ',bottom) self.top.destroy() self.canvas.bind(' ', onLeftButtonUp) self.canvas.pack(fill=tkinter.BOTH, expand=tkinter.YES) #开始截图text = StringVar()text.set('old')def buttonCaptureClick(): #最小化主窗口 #root.state('icon') #sleep(0.2) filename = 'temp.png' im = ImageGrab.grab() im.save(filename) im.close() #显示全屏幕截图 w = MyCapture(filename) buttonCapture.wait_window(w.top) text.set(str(w.selectPosition)) #print(w.myleft,w.mybottom) #截图结束,恢复主窗口,并删除临时的全屏幕截图文件 #label.config(text='Hello') root.state('normal') os.remove(filename)label=tkinter.Label(root,textvariable=text)label.place(x=10, y=30, width=160, height=20)label.config(text='New test')buttonCapture = tkinter.Button(root, text='截图', command=buttonCaptureClick)buttonCapture.place(x=10, y=10, width=160, height=20)#启动消息主循环#root.update()root.mainloop()