-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathvideo_processor.py
40 lines (28 loc) · 1.14 KB
/
video_processor.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
import cv2
import skvideo.io
from crowd_detector import get_processed_img
from detection import default_dedector
import numpy as np
from PerspectiveTransform import Transformer
def get_process_video(input_file_path, processor):
detector = default_dedector()
videogen = skvideo.io.vreader(input_file_path)
data = []
for frame in videogen:
print('.',end='')
processed_frame = processor(detector, frame)
data.append(processed_frame)
return data
def write_processed_video(input_file_path, output_file_path, processor):
data = get_process_video(input_file_path, processor)
skvideo.io.vwrite(output_file_path, data)
if __name__ == '__main__':
# write_processed_video('videos/cctv.mp4', 'output.mp4', get_processed_img)
videogen = skvideo.io.vreader('videos/cctv.mp4')
frame = next(videogen)
transformer = Transformer()
transformer.calibrate(frame)
transformed_img = transformer.get_processed_image(default_dedector(), frame)
cv2.imshow("transformed", transformed_img)
cv2.waitKey()
write_processed_video('videos/cctv.mp4', 'output.mp4', transformer.get_processed_image)