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):
|
2020-12-19 23:11:11 +00:00
|
|
|
"""progress monitor
|
2020-05-07 19:58:22 +00:00
|
|
|
|
|
|
|
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-12-19 23:11:11 +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-12-19 23:11:11 +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()
|