video2slide / utils.py
dragonSwing's picture
Update app
54696a3
raw
history blame contribute delete
No virus
1.96 kB
import os
import re
import cv2
import shutil
import img2pdf
from imutils import paths
# PIL can also be used to convert the image set into PDFs.
# However, using PIL requires opening each of the images in the set.
# Hence img2pdf package was used, which is able to convert the entire image set into a PDF
# without opening at once.
def sanitize_file_name(string):
sanitized_string = re.sub(r'[^\w ]+', '', string)
sanitized_string = re.sub(r'\s+', ' ', sanitized_string)
sanitized_string = sanitized_string.strip()
return sanitized_string
def resize_image_frame(frame, resize_width):
ht, wd, _ = frame.shape
new_height = resize_width * ht / wd
frame = cv2.resize(
frame, (resize_width, int(new_height)), interpolation=cv2.INTER_AREA
)
return frame
def create_output_directory(video_path, output_path, type_bgsub):
vid_file_name = video_path.rsplit(os.sep)[-1].split(".")[0]
output_dir_path = os.path.join(output_path, vid_file_name, type_bgsub)
# Remove the output directory if there is already one.
if os.path.exists(output_dir_path):
shutil.rmtree(output_dir_path)
# Create output directory.
os.makedirs(output_dir_path, exist_ok=True)
print("Output directory created...")
print("Path:", output_dir_path)
print("***" * 10, "\n")
return output_dir_path
def convert_slides_to_pdf(img_dir, output_path=None):
if not os.path.isdir(img_dir):
print("The image directory doesn't exist!")
return
if output_path == None:
pdf_file_name = os.path.basename(img_dir) + ".pdf"
output_path = os.path.join(img_dir, pdf_file_name)
print("Output PDF Path:", output_path)
print("Converting captured slide images to PDF...")
with open(output_path, "wb") as f:
f.write(img2pdf.convert(sorted(paths.list_images(img_dir))))
print("PDF Created!")
print("***" * 10, "\n")
return output_path