2015-12-31 09:25:36 -08:00
|
|
|
from tqdm import tqdm as show_progress
|
2018-12-24 12:37:51 -08:00
|
|
|
import cv2
|
2015-08-21 19:58:36 -07:00
|
|
|
|
2018-12-24 12:37:51 -08:00
|
|
|
from manimlib.scene.scene import Scene
|
2015-08-21 19:58:36 -07:00
|
|
|
|
|
|
|
|
|
|
|
class SceneFromVideo(Scene):
|
2017-10-05 21:03:30 -05:00
|
|
|
def construct(self, file_name,
|
2018-04-06 13:58:59 -07:00
|
|
|
freeze_last_frame=True,
|
|
|
|
time_range=None):
|
2015-08-21 19:58:36 -07:00
|
|
|
cap = cv2.VideoCapture(file_name)
|
|
|
|
self.shape = (
|
|
|
|
int(cap.get(cv2.cv.CV_CAP_PROP_FRAME_HEIGHT)),
|
|
|
|
int(cap.get(cv2.cv.CV_CAP_PROP_FRAME_WIDTH))
|
|
|
|
)
|
|
|
|
fps = cap.get(cv2.cv.CV_CAP_PROP_FPS)
|
2018-04-06 13:58:59 -07:00
|
|
|
self.frame_duration = 1.0 / fps
|
2015-08-21 19:58:36 -07:00
|
|
|
frame_count = int(cap.get(cv2.cv.CV_CAP_PROP_FRAME_COUNT))
|
|
|
|
if time_range is None:
|
|
|
|
start_frame = 0
|
|
|
|
end_frame = frame_count
|
|
|
|
else:
|
2018-08-09 17:56:05 -07:00
|
|
|
start_frame, end_frame = [fps * t for t in time_range]
|
2015-08-21 19:58:36 -07:00
|
|
|
|
|
|
|
frame_count = end_frame - start_frame
|
2017-10-05 21:03:30 -05:00
|
|
|
print("Reading in " + file_name + "...")
|
2018-08-09 17:56:05 -07:00
|
|
|
for count in show_progress(list(range(start_frame, end_frame + 1))):
|
2015-08-21 19:58:36 -07:00
|
|
|
returned, frame = cap.read()
|
2017-08-12 16:41:08 +02:00
|
|
|
if not returned:
|
2015-08-21 19:58:36 -07:00
|
|
|
break
|
|
|
|
# b, g, r = cv2.split(frame)
|
|
|
|
# self.frames.append(cv2.merge([r, g, b]))
|
|
|
|
self.frames.append(frame)
|
|
|
|
cap.release()
|
|
|
|
|
|
|
|
if freeze_last_frame and len(self.frames) > 0:
|
|
|
|
self.original_background = self.background = self.frames[-1]
|
|
|
|
|
2018-04-06 13:58:59 -07:00
|
|
|
def apply_gaussian_blur(self, ksize=(5, 5), sigmaX=5):
|
2015-08-21 19:58:36 -07:00
|
|
|
self.frames = [
|
|
|
|
cv2.GaussianBlur(frame, ksize, sigmaX)
|
|
|
|
for frame in self.frames
|
|
|
|
]
|
|
|
|
|
2018-04-06 13:58:59 -07:00
|
|
|
def apply_edge_detection(self, threshold1=50, threshold2=100):
|
2015-08-21 19:58:36 -07:00
|
|
|
edged_frames = [
|
|
|
|
cv2.Canny(frame, threshold1, threshold2)
|
|
|
|
for frame in self.frames
|
|
|
|
]
|
|
|
|
for index in range(len(self.frames)):
|
|
|
|
for i in range(3):
|
2018-04-06 13:58:59 -07:00
|
|
|
self.frames[index][:, :, i] = edged_frames[index]
|