FPS Counter

pull/746/head
KRSHH 2024-10-14 19:46:48 +05:30
parent b58ffffd37
commit 37f224cb47
2 changed files with 64 additions and 27 deletions

View File

@ -2,11 +2,11 @@ import os
from typing import List, Dict, Any from typing import List, Dict, Any
ROOT_DIR = os.path.dirname(os.path.abspath(__file__)) ROOT_DIR = os.path.dirname(os.path.abspath(__file__))
WORKFLOW_DIR = os.path.join(ROOT_DIR, 'workflow') WORKFLOW_DIR = os.path.join(ROOT_DIR, "workflow")
file_types = [ file_types = [
('Image', ('*.png','*.jpg','*.jpeg','*.gif','*.bmp')), ("Image", ("*.png", "*.jpg", "*.jpeg", "*.gif", "*.bmp")),
('Video', ('*.mp4','*.mkv')) ("Video", ("*.mp4", "*.mkv")),
] ]
souce_target_map = [] souce_target_map = []
@ -31,8 +31,9 @@ max_memory = None
execution_providers: List[str] = [] execution_providers: List[str] = []
execution_threads = None execution_threads = None
headless = None headless = None
log_level = 'error' log_level = "error"
fp_ui: Dict[str, bool] = {} fp_ui: Dict[str, bool] = {}
camera_input_combobox = None camera_input_combobox = None
webcam_preview_running = False webcam_preview_running = False
opacity = 100 opacity = 100
show_fps = False

View File

@ -26,7 +26,6 @@ from modules.utilities import (
has_image_extension, has_image_extension,
) )
modules.globals.face_opacity = 100
os.environ["QT_AUTO_SCREEN_SCALE_FACTOR"] = "1" os.environ["QT_AUTO_SCREEN_SCALE_FACTOR"] = "1"
os.environ["QT_SCREEN_SCALE_FACTORS"] = "1" os.environ["QT_SCREEN_SCALE_FACTORS"] = "1"
os.environ["QT_SCALE_FACTOR"] = "1" os.environ["QT_SCALE_FACTOR"] = "1"
@ -213,7 +212,7 @@ def init(start: Callable[[], None], destroy: Callable[[], None]) -> tkdnd.Tkinte
def create_root( def create_root(
start: Callable[[], None], destroy: Callable[[], None] start: Callable[[], None], destroy: Callable[[], None]
) -> tkdnd.TkinterDnD.Tk: ) -> tkdnd.TkinterDnD.Tk:
global source_label, target_label, status_label, donate_frame global source_label, target_label, status_label, donate_frame, show_fps_switch
ctk.set_appearance_mode("dark") ctk.set_appearance_mode("dark")
ctk.set_default_color_theme("blue") ctk.set_default_color_theme("blue")
@ -383,6 +382,19 @@ def create_root(
) )
map_faces_switch.pack(pady=5, anchor="w") map_faces_switch.pack(pady=5, anchor="w")
# Add the Show FPS switch
show_fps_value = ctk.BooleanVar(value=modules.globals.show_fps)
show_fps_switch = ctk.CTkSwitch(
options_column,
text="Show FPS",
variable=show_fps_value,
cursor="hand2",
command=lambda: setattr(modules.globals, "show_fps", show_fps_value.get()),
progress_color="#3a7ebf",
font=("Roboto", 14, "bold"),
)
show_fps_switch.pack(pady=5, anchor="w")
button_frame = ctk.CTkFrame(main_frame, fg_color="#1a1a1a") button_frame = ctk.CTkFrame(main_frame, fg_color="#1a1a1a")
button_frame.grid(row=2, column=0, columnspan=3, padx=10, pady=10, sticky="nsew") button_frame.grid(row=2, column=0, columnspan=3, padx=10, pady=10, sticky="nsew")
@ -1010,25 +1022,25 @@ def update_opacity(value):
modules.globals.face_opacity = int(value) modules.globals.face_opacity = int(value)
# Modify the create_webcam_preview function to include the slider def create_webcam_preview(camera_index: int):
def create_webcam_preview(camera_index):
global preview_label, PREVIEW global preview_label, PREVIEW
camera = cv2.VideoCapture(camera_index) camera = cv2.VideoCapture(camera_index)
if not camera.isOpened(): if not camera.isOpened():
update_status(f"Error: Could not open camera with index {camera_index}") update_status(f"Error: Could not open camera with index {camera_index}")
return return
camera.set(cv2.CAP_PROP_FRAME_WIDTH, PREVIEW_DEFAULT_WIDTH) camera.set(cv2.CAP_PROP_FRAME_WIDTH, PREVIEW_DEFAULT_WIDTH)
camera.set(cv2.CAP_PROP_FRAME_HEIGHT, PREVIEW_DEFAULT_HEIGHT) camera.set(cv2.CAP_PROP_FRAME_HEIGHT, PREVIEW_DEFAULT_HEIGHT)
camera.set(cv2.CAP_PROP_FPS, 60) camera.set(cv2.CAP_PROP_FPS, 60)
PREVIEW.deiconify() PREVIEW.deiconify()
# Remove any existing widgets in PREVIEW window # Clear any existing widgets in the PREVIEW window
for widget in PREVIEW.winfo_children(): for widget in PREVIEW.winfo_children():
widget.destroy() widget.destroy()
# Create a main frame to hold all widgets # Create a main frame to contain all widgets
main_frame = ctk.CTkFrame(PREVIEW) main_frame = ctk.CTkFrame(PREVIEW)
main_frame.pack(fill="both", expand=True) main_frame.pack(fill="both", expand=True)
@ -1039,10 +1051,17 @@ def create_webcam_preview(camera_index):
preview_label = ctk.CTkLabel(preview_frame, text="") preview_label = ctk.CTkLabel(preview_frame, text="")
preview_label.pack(fill="both", expand=True) preview_label.pack(fill="both", expand=True)
# Initialize frame processors
frame_processors = get_frame_processors_modules(modules.globals.frame_processors) frame_processors = get_frame_processors_modules(modules.globals.frame_processors)
# Variables for source image and FPS calculation
source_image = None source_image = None
prev_time = time.time()
fps_update_interval = 0.5
frame_count = 0
fps = 0
# Function to update frame size when the window is resized
def update_frame_size(event): def update_frame_size(event):
nonlocal temp_frame nonlocal temp_frame
if modules.globals.live_resizable: if modules.globals.live_resizable:
@ -1050,44 +1069,63 @@ def create_webcam_preview(camera_index):
preview_frame.bind("<Configure>", update_frame_size) preview_frame.bind("<Configure>", update_frame_size)
while camera: # Main loop for capturing and processing frames
while camera.isOpened() and PREVIEW.state() != "withdrawn":
ret, frame = camera.read() ret, frame = camera.read()
if not ret: if not ret:
break break
temp_frame = frame.copy() # Create a copy of the frame temp_frame = frame.copy()
# Apply mirroring if enabled
if modules.globals.live_mirror: if modules.globals.live_mirror:
temp_frame = cv2.flip(temp_frame, 1) # horizontal flipping temp_frame = cv2.flip(temp_frame, 1)
# Resize frame if enabled
if modules.globals.live_resizable: if modules.globals.live_resizable:
temp_frame = fit_image_to_size( temp_frame = fit_image_to_size(
temp_frame, PREVIEW.winfo_width(), PREVIEW.winfo_height() temp_frame, PREVIEW.winfo_width(), PREVIEW.winfo_height()
) )
# Process frame based on face mapping mode
if not modules.globals.map_faces: if not modules.globals.map_faces:
# Check if source_path has changed and update source_image if necessary # Update source image if path has changed
if modules.globals.source_path and ( if modules.globals.source_path and (
source_image is None source_image is None
or modules.globals.source_path != source_image["location"] or modules.globals.source_path != source_image["location"]
): ):
source_image = get_one_face(cv2.imread(modules.globals.source_path)) source_image = get_one_face(cv2.imread(modules.globals.source_path))
source_image["location"] = ( source_image["location"] = modules.globals.source_path
modules.globals.source_path
) # Store location for comparison
# Apply frame processors (e.g., face swapping, enhancement)
for frame_processor in frame_processors: for frame_processor in frame_processors:
temp_frame = frame_processor.process_frame(source_image, temp_frame) temp_frame = frame_processor.process_frame(source_image, temp_frame)
else: else:
modules.globals.target_path = None modules.globals.target_path = None
for frame_processor in frame_processors: for frame_processor in frame_processors:
temp_frame = frame_processor.process_frame_v2(temp_frame) temp_frame = frame_processor.process_frame_v2(temp_frame)
image = cv2.cvtColor( # Calculate and display FPS
temp_frame, cv2.COLOR_BGR2RGB current_time = time.time()
) # Convert the image to RGB format to display it with Tkinter frame_count += 1
if current_time - prev_time >= fps_update_interval:
fps = frame_count / (current_time - prev_time)
frame_count = 0
prev_time = current_time
if modules.globals.show_fps:
cv2.putText(
temp_frame,
f"FPS: {fps:.1f}",
(10, 30),
cv2.FONT_HERSHEY_SIMPLEX,
1,
(0, 255, 0),
2,
)
# Convert frame to RGB and display in preview label
image = cv2.cvtColor(temp_frame, cv2.COLOR_BGR2RGB)
image = Image.fromarray(image) image = Image.fromarray(image)
image = ImageOps.contain( image = ImageOps.contain(
image, (temp_frame.shape[1], temp_frame.shape[0]), Image.LANCZOS image, (temp_frame.shape[1], temp_frame.shape[0]), Image.LANCZOS
@ -1096,11 +1134,9 @@ def create_webcam_preview(camera_index):
preview_label.configure(image=image) preview_label.configure(image=image)
ROOT.update() ROOT.update()
if PREVIEW.state() == "withdrawn": # Release camera and close preview window
break
camera.release() camera.release()
PREVIEW.withdraw() # Close preview window when loop is finished PREVIEW.withdraw()
def create_source_target_popup_for_webcam(root: ctk.CTk, map: list) -> None: def create_source_target_popup_for_webcam(root: ctk.CTk, map: list) -> None: