-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlinux-recorder-screen-or-camera.py
150 lines (129 loc) · 6.24 KB
/
linux-recorder-screen-or-camera.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Importação das bibliotecas necessárias
import tkinter as tk # Interface gráfica
from tkinter import filedialog, messagebox # Diálogo e mensagens
import pygetwindow as gw # Manipulação de janelas
import pyautogui # Captura de tela
import cv2 # Processamento de vídeo
import numpy as np # Manipulação de arrays
import threading # Execução em segundo plano
class ScreenRecorder:
def __init__(self, root):
# Configuração inicial da janela principal
self.root = root
self.root.title("Screen Recorder")
# Escolha da fonte de gravação
self.label = tk.Label(root, text="Escolha a fonte de gravação:")
self.label.pack(pady=10)
# Opções de fonte de gravação: câmera ou janela
self.source_var = tk.StringVar(value="camera")
self.camera_radiobutton = tk.Radiobutton(root, text="Câmera USB", variable=self.source_var, value="camera")
self.camera_radiobutton.pack(pady=5)
self.window_radiobutton = tk.Radiobutton(root, text="Janela", variable=self.source_var, value="window")
self.window_radiobutton.pack(pady=5)
# Lista de janelas disponíveis para gravar
self.window_listbox = tk.Listbox(root)
self.window_listbox.pack(pady=10)
# Botão para atualizar a lista de janelas
self.refresh_button = tk.Button(root, text="Atualizar Janelas", command=self.refresh_windows)
self.refresh_button.pack(pady=5)
# Botão para escolher o local de salvamento do vídeo
self.select_file_button = tk.Button(root, text="Escolher Local e Nome do Arquivo", command=self.select_file)
self.select_file_button.pack(pady=5)
# Botão para iniciar a gravação
self.record_button = tk.Button(root, text="Gravar", command=self.start_recording)
self.record_button.pack(pady=20)
# Botão para parar a gravação
self.stop_button = tk.Button(root, text="Parar Gravação", command=self.stop_recording, state=tk.DISABLED)
self.stop_button.pack(pady=5)
# Botão para sair do programa
self.exit_button = tk.Button(root, text="Sair", command=root.quit)
self.exit_button.pack(pady=5)
# Variáveis para armazenar o caminho do arquivo e status de gravação
self.file_path = ""
self.recording = False
self.windows = [] # Lista de janelas abertas
self.refresh_windows() # Inicializa a lista de janelas
# Função para atualizar a lista de janelas
def refresh_windows(self):
self.window_listbox.delete(0, tk.END)
self.windows = gw.getWindowsWithTitle('') # Obtém todas as janelas abertas
for window in self.windows:
self.window_listbox.insert(tk.END, window.title)
# Função para selecionar o local de salvamento do arquivo
def select_file(self):
self.file_path = filedialog.asksaveasfilename(defaultextension=".avi", filetypes=[("Video files", "*.avi")])
if self.file_path:
messagebox.showinfo("Info", f"Arquivo selecionado: {self.file_path}")
# Função para iniciar a gravação
def start_recording(self):
# Verificação da fonte de gravação e se o arquivo foi selecionado
if self.source_var.get() == "window":
selected_index = self.window_listbox.curselection()
if not selected_index:
messagebox.showwarning("Aviso", "Por favor, selecione uma janela para gravar.")
return
if not self.file_path:
messagebox.showwarning("Aviso", "Por favor, selecione o local e nome do arquivo.")
return
# Desativa os botões de gravação e saída durante a gravação
self.record_button.config(state=tk.DISABLED)
self.stop_button.config(state=tk.NORMAL)
self.exit_button.config(state=tk.DISABLED)
# Inicia a gravação conforme a fonte selecionada
if self.source_var.get() == "camera":
self.recording = True
threading.Thread(target=self.record_camera, args=(self.file_path,)).start()
else:
selected_window = self.windows[self.window_listbox.curselection()[0]]
window_box = selected_window.box # Obtém coordenadas da janela
self.recording = True
threading.Thread(target=self.record_video, args=(window_box, self.file_path)).start()
# Função para parar a gravação
def stop_recording(self):
self.recording = False
self.record_button.config(state=tk.NORMAL)
self.stop_button.config(state=tk.DISABLED)
self.exit_button.config(state=tk.NORMAL)
# Função para gravar uma janela específica
def record_video(self, window_box, file_path):
x, y, w, h = window_box
fourcc = cv2.VideoWriter_fourcc(*"XVID")
out = cv2.VideoWriter(file_path, fourcc, 20.0, (w, h))
try:
while self.recording:
img = pyautogui.screenshot(region=(x, y, w, h)) # Captura da área da janela
frame = np.array(img)
frame = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)
out.write(frame)
finally:
out.release()
cv2.destroyAllWindows()
messagebox.showinfo("Info", "Gravação finalizada.")
# Função para gravar a partir da câmera USB
def record_camera(self, file_path):
cap = cv2.VideoCapture(0) # Inicia a captura da câmera
if not cap.isOpened():
messagebox.showerror("Erro", "Não foi possível acessar a câmera.")
self.stop_recording()
return
width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
fourcc = cv2.VideoWriter_fourcc(*"XVID")
out = cv2.VideoWriter(file_path, fourcc, 20.0, (width, height))
try:
while self.recording:
ret, frame = cap.read()
if not ret:
break
out.write(frame)
finally:
cap.release()
out.release()
cv2.destroyAllWindows()
messagebox.showinfo("Info", "Gravação finalizada.")
if __name__ == "__main__":
root = tk.Tk()
app = ScreenRecorder(root)
root.mainloop()