2020-05-07 19:58:22 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
Name: Video2X Upscale Progress Monitor
|
2020-06-08 03:35:17 +00:00
|
|
|
Author: K4YT3X
|
2020-05-07 19:58:22 +00:00
|
|
|
Date Created: May 7, 2020
|
2020-09-09 17:07:42 +00:00
|
|
|
Last Modified: September 9, 2020
|
2020-05-07 19:58:22 +00:00
|
|
|
"""
|
|
|
|
|
|
|
|
# built-in imports
|
|
|
|
import contextlib
|
|
|
|
import threading
|
|
|
|
import time
|
|
|
|
|
|
|
|
# third-party imports
|
|
|
|
from tqdm import tqdm
|
|
|
|
|
|
|
|
|
|
|
|
class ProgressMonitor(threading.Thread):
|
|
|
|
""" progress monitor
|
|
|
|
|
|
|
|
This class provides progress monitoring functionalities
|
|
|
|
by keeping track of the amount of frames in the input
|
|
|
|
directory and the output directory. This is originally
|
|
|
|
suggested by @ArmandBernard.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def __init__(self, upscaler, extracted_frames_directories):
|
|
|
|
threading.Thread.__init__(self)
|
|
|
|
self.upscaler = upscaler
|
|
|
|
self.extracted_frames_directories = extracted_frames_directories
|
|
|
|
self.running = False
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
self.running = True
|
2020-05-08 21:32:36 +00:00
|
|
|
|
2020-09-09 17:07:42 +00:00
|
|
|
with tqdm(total=self.upscaler.total_frames, ascii=True, desc=_('Processing: {} (pass {}/{})').format(self.upscaler.current_input_file.name, self.upscaler.current_pass, len(self.upscaler.scaling_jobs))) as progress_bar:
|
2020-05-07 19:58:22 +00:00
|
|
|
# tqdm update method adds the value to the progress
|
|
|
|
# bar instead of setting the value. Therefore, a delta
|
|
|
|
# needs to be calculated.
|
|
|
|
previous_cycle_frames = 0
|
|
|
|
while self.running:
|
|
|
|
|
|
|
|
with contextlib.suppress(FileNotFoundError):
|
2020-06-08 03:35:17 +00:00
|
|
|
upscaled_frames = [f for f in self.upscaler.upscaled_frames.iterdir() if str(f).lower().endswith(self.upscaler.extracted_frame_format.lower())]
|
2020-05-11 08:17:21 +00:00
|
|
|
if len(upscaled_frames) >= 1:
|
|
|
|
self.upscaler.last_frame_upscaled = sorted(upscaled_frames)[-1]
|
|
|
|
self.upscaler.total_frames_upscaled = len(upscaled_frames)
|
2020-05-07 19:58:22 +00:00
|
|
|
|
|
|
|
# update progress bar
|
|
|
|
delta = self.upscaler.total_frames_upscaled - previous_cycle_frames
|
|
|
|
previous_cycle_frames = self.upscaler.total_frames_upscaled
|
|
|
|
progress_bar.update(delta)
|
|
|
|
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
def stop(self):
|
|
|
|
self.running = False
|
|
|
|
self.join()
|