How to implement screen recording function in Python
1. Interface development
#设置主界面 def set_init_window(self): # 去掉tkinter默认的标题 self.tk.title('') # 隐藏默认图标 self.tk.iconbitmap(self.icon_path()) #获取屏幕的宽度 screeWidth = self.tk.winfo_screenwidth() #获取屏幕高度 screeHeight = self.tk.winfo_screenheight() width = int((screeWidth - 500) / 2) height = int((screeHeight - 300) / 2) # 设置主界面的大小和默认位置 self.tk.geometry(f'500x100+{width}+{height}') #添加开始录制按钮,点击之后开启两个线程:一个录屏、一个监听键盘 btn1 = tkinter.Button(self.tk, width=5, height=1, text='开始', command=lambda:[threading.Thread(target=self.video_record).start(),threading.Thread(target=self.start_listen).start()]) btn1.pack() # 设置按钮位置 btn1.place(x=110, y=50, anchor='n') #开启新线程设置录屏范围 btn2 = tkinter.Button(self.tk, width=15, height=1, text='设置录制区域', command=lambda:threading.Thread(target=self.set_range).start()) btn2.pack() btn2.place(x=230, y=50, anchor='n') #生成透明的icon图标 def icon_path(self): ICON = (b'\x00\x00\x01\x00\x01\x00\x10\x10\x00\x00\x01\x00\x08\x00h\x05\x00\x00' b'\x16\x00\x00\x00(\x00\x00\x00\x10\x00\x00\x00 \x00\x00\x00\x01\x00' b'\x08\x00\x00\x00\x00\x00@\x05\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00' b'\x00\x01\x00\x00\x00\x01') + b'\x00' * 1282 + b'\xff' * 64 _, ICON_PATH = tempfile.mkstemp() with open(ICON_PATH, 'wb') as icon_file: icon_file.write(ICON) return ICON_PATH
2. Screen recording parameter settings
1. Set the screen recording range
#设置录屏范围 def set_range(self): #self.init_window.withdraw() #隐藏窗口 self.tk.state('icon')#窗口最小化 screeWidth = self.tk.winfo_screenwidth() screeHeight = self.tk.winfo_screenheight() self.newFrame = tkinter.Toplevel(self.tk,width=screeWidth,height=screeHeight,bg='white')#开启新窗口 self.newFrame.attributes('-transparentcolor', 'white') # 使白色为透明色 self.newFrame.overrideredirect(True) # 隐藏导航栏 self.canvas = tkinter.Canvas(self.newFrame,bg='white',bd=0,width=screeWidth,height=screeHeight) self.canvas.bind('<Button-1>', self.onLeftButtonDown)#按下左键 self.canvas.bind('<B1-Motion>', self.onLeftButtonMove)#移动鼠标 self.canvas.bind('<ButtonRelease-1>', self.onLeftButtonUp)#抬起左键 self.canvas.pack(fill=tkinter.BOTH, expand=tkinter.YES) time.sleep(0.3) im = ImageGrab.grab() # 暂存全屏截图 im.save('temp.png') im.close() self.image = tkinter.PhotoImage(file='temp.png') os.remove('temp.png') self.canvas.create_image(screeWidth//2, screeHeight//2, image=self.image)
2. Mouse event monitoring
#按下鼠标 def onLeftButtonDown(self,event): try: self.canvas.delete(self.lastDraw) self.canvas.delete(self.dot1) self.canvas.delete(self.dot2) self.btn3.destroy() except Exception as e: pass self.X = event.x self.Y = event.y self.X2 = 0 self.Y2 = 0 #移动鼠标 def onLeftButtonMove(self,event): try: # 删除刚画完的图形,不然所有画的框都会出现 self.canvas.delete(self.lastDraw) self.canvas.delete(self.dot1) self.canvas.delete(self.dot2) self.btn3.destroy() except Exception as e: pass self.X2 = event.x self.Y2 = event.y self.lastDraw = self.canvas.create_rectangle(self.X, self.Y, event.x, event.y,width=2, outline='pink') #松开鼠标 def onLeftButtonUp(self,event): print("起点", self.X, self.Y) print("终点", self.X2, self.Y2) if self.X2==0 and self.X2==0: return self.width, self.high = self.X2-self.X,self.Y2-self.Y self.region = (self.X, self.Y, self.X2, self.Y2) self.dot1=self.canvas.create_text(self.X, self.Y - 10, text=f'({self.X},{self.Y})', font=("Purisa", 12), fill="pink") self.dot2=self.canvas.create_text(self.X2, self.Y2 + 10, text=f'({self.X2},{self.Y2})', font=("Purisa", 12), fill="pink") # self.newFrame.destroy()#销毁窗口 # self.init_window.deiconify()#显示窗口 # self.tk.state('normal') # 取消窗口最小化 self.btn3 = tkinter.Button(self.canvas, width=15, height=1, text='确定录制区域',bg='pink',fg='#64854c',command=lambda:[self.newFrame.destroy(),self.tk.state('normal')]) self.btn3.pack() self.btn3.place(x=self.X2-20, y=self.Y2+20, anchor='n')
3. Keyboard event monitoring
# 开始监听 def start_listen(self): with keyboard.Listener(on_press=self.on_press) as listener: listener.join() # 监听按键 def on_press(self,key): if key == keyboard.Key.esc: self.flag = True # 改变 return False # 返回False,键盘监听结束!
3. Screen recording operation
def video_record(self): fourcc = cv2.VideoWriter_fourcc('X', 'V', 'I', 'D') out = cv2.VideoWriter('output.mp4', fourcc, 14, (self.width, self.high)) # 参数分别为 输出文件名,解码方式,帧数,录像范围 self.count = 1 while (True): img = ImageGrab.grab(self.region) #指定截取坐标(左边X,上边Y,右边X,下边Y) img_np = numpy.array(img) frame = cv2.cvtColor(img_np, cv2.COLOR_BGR2RGB) # ImageGrab获取的颜色为BGR排序,需转换为RGB out.write(frame) self.count += 1 label = tkinter.Label(self.tk, text=f"{int(self.count / 14)}秒") label.pack() label.place(x=320, y=55, anchor='n') # 点击ESC退出 if self.flag == True: tkinter.messagebox.showinfo('提示', '录屏结束') self.flag = False # 改变录屏状态 break out.release() cv2.destroyAllWindows()
The above is the detailed content of How to implement screen recording function in Python. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

An application that converts XML directly to PDF cannot be found because they are two fundamentally different formats. XML is used to store data, while PDF is used to display documents. To complete the transformation, you can use programming languages and libraries such as Python and ReportLab to parse XML data and generate PDF documents.

The speed of mobile XML to PDF depends on the following factors: the complexity of XML structure. Mobile hardware configuration conversion method (library, algorithm) code quality optimization methods (select efficient libraries, optimize algorithms, cache data, and utilize multi-threading). Overall, there is no absolute answer and it needs to be optimized according to the specific situation.

It is impossible to complete XML to PDF conversion directly on your phone with a single application. It is necessary to use cloud services, which can be achieved through two steps: 1. Convert XML to PDF in the cloud, 2. Access or download the converted PDF file on the mobile phone.

To generate images through XML, you need to use graph libraries (such as Pillow and JFreeChart) as bridges to generate images based on metadata (size, color) in XML. The key to controlling the size of the image is to adjust the values of the <width> and <height> tags in XML. However, in practical applications, the complexity of XML structure, the fineness of graph drawing, the speed of image generation and memory consumption, and the selection of image formats all have an impact on the generated image size. Therefore, it is necessary to have a deep understanding of XML structure, proficient in the graphics library, and consider factors such as optimization algorithms and image format selection.

Use most text editors to open XML files; if you need a more intuitive tree display, you can use an XML editor, such as Oxygen XML Editor or XMLSpy; if you process XML data in a program, you need to use a programming language (such as Python) and XML libraries (such as xml.etree.ElementTree) to parse.

XML formatting tools can type code according to rules to improve readability and understanding. When selecting a tool, pay attention to customization capabilities, handling of special circumstances, performance and ease of use. Commonly used tool types include online tools, IDE plug-ins, and command-line tools.

To convert XML images, you need to determine the XML data structure first, then select a suitable graphical library (such as Python's matplotlib) and method, select a visualization strategy based on the data structure, consider the data volume and image format, perform batch processing or use efficient libraries, and finally save it as PNG, JPEG, or SVG according to the needs.

There is no APP that can convert all XML files into PDFs because the XML structure is flexible and diverse. The core of XML to PDF is to convert the data structure into a page layout, which requires parsing XML and generating PDF. Common methods include parsing XML using Python libraries such as ElementTree and generating PDFs using ReportLab library. For complex XML, it may be necessary to use XSLT transformation structures. When optimizing performance, consider using multithreaded or multiprocesses and select the appropriate library.
