Spaces:
Running
on
Zero
Running
on
Zero
from PIL import Image | |
import cv2 | |
import numpy as np | |
import os | |
import tempfile | |
def resize(img, size): | |
assert img.dtype == np.uint8 | |
pil_image = Image.fromarray(img) | |
pil_image = pil_image.resize(size, Image.LANCZOS) | |
resized_img = np.array(pil_image) | |
return resized_img | |
def crop(img, start_h, start_w, crop_h, crop_w): | |
img_src = np.zeros((crop_h, crop_w, *img.shape[2:]), dtype=img.dtype) | |
hsize, wsize = crop_h, crop_w | |
dh, dw, sh, sw = start_h, start_w, 0, 0 | |
if dh < 0: | |
sh = -dh | |
hsize += dh | |
dh = 0 | |
if dh + hsize > img.shape[0]: | |
hsize = img.shape[0] - dh | |
if dw < 0: | |
sw = -dw | |
wsize += dw | |
dw = 0 | |
if dw + wsize > img.shape[1]: | |
wsize = img.shape[1] - dw | |
img_src[sh : sh + hsize, sw : sw + wsize] = img[dh : dh + hsize, dw : dw + wsize] | |
return img_src | |
def imresize_max(img, size, min_side=False): | |
new_img = [] | |
for i, _img in enumerate(img): | |
h, w = _img.shape[:2] | |
ori_size = min(h, w) if min_side else max(h, w) | |
_resize = min(size / ori_size, 1.0) | |
new_size = (int(w * _resize), int(h * _resize)) | |
new_img.append(resize(_img, new_size)) | |
return new_img | |
def imcrop_multi(img, multiple=32): | |
new_img = [] | |
for i, _img in enumerate(img): | |
crop_size = ( | |
_img.shape[0] // multiple * multiple, | |
_img.shape[1] // multiple * multiple, | |
) | |
start_h = int(0.5 * max(0, _img.shape[0] - crop_size[0])) | |
start_w = int(0.5 * max(0, _img.shape[1] - crop_size[1])) | |
_img_src = crop(_img, start_h, start_w, crop_size[0], crop_size[1]) | |
new_img.append(_img_src) | |
return new_img | |
def read_video(video_path, max_frames=None): | |
cap = cv2.VideoCapture(video_path) | |
fps = cap.get(cv2.CAP_PROP_FPS) | |
frames = [] | |
count = 0 | |
while True: | |
ret, frame = cap.read() | |
if not ret: | |
break | |
frame = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB) | |
frames.append(frame) | |
count += 1 | |
if max_frames is not None and count >= max_frames: | |
break | |
cap.release() | |
# (N, H, W, 3) | |
return frames, fps | |
def read_image(image_path): | |
frame = cv2.imread(image_path) | |
frame = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB) | |
# (1, H, W, 3) | |
return [frame] | |
def write_video(video_path, frames, fps): | |
tmp_dir = os.path.join(os.path.dirname(video_path), "tmp") | |
os.makedirs(tmp_dir, exist_ok=True) | |
for i, frame in enumerate(frames): | |
write_image(os.path.join(tmp_dir, f"{i:06d}.png"), frame) | |
# it will cause visual compression artifacts | |
ffmpeg_command = [ | |
"ffmpeg", | |
"-f", | |
"image2", | |
"-framerate", | |
f"{fps}", | |
"-i", | |
os.path.join(tmp_dir, "%06d.png"), | |
"-b:v", | |
"5626k", | |
"-y", | |
video_path, | |
] | |
os.system(" ".join(ffmpeg_command)) | |
os.system(f"rm -rf {tmp_dir}") | |
def write_image(image_path, frame): | |
frame = cv2.cvtColor(frame, cv2.COLOR_RGB2BGR) | |
cv2.imwrite(image_path, frame) | |