-
Notifications
You must be signed in to change notification settings - Fork 90
/
Copy pathrecord2.py
125 lines (93 loc) · 3.62 KB
/
record2.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
"""
record2.py
---------------
Main Function for recording a video sequence into cad (color-aligned-to-depth)
images and depth images
Using librealsense SDK 2.0 with pyrealsense2 for SR300 and D series cameras
"""
# record for 40s after a 5s count down
# or exit the recording earlier by pressing q
RECORD_LENGTH = 40
import png
import pyrealsense2 as rs
import json
import logging
logging.basicConfig(level=logging.INFO)
import numpy as np
import cv2
import time
import os
import sys
# from config.DataAcquisitionParameters import DEPTH_THRESH
def make_directories(folder):
if not os.path.exists(folder+"JPEGImages/"):
os.makedirs(folder+"JPEGImages/")
if not os.path.exists(folder+"depth/"):
os.makedirs(folder+"depth/")
def print_usage():
print("Usage: record2.py <foldername>")
print("foldername: path where the recorded data should be stored at")
print("e.g., record2.py LINEMOD/mug")
if __name__ == "__main__":
try:
folder = sys.argv[1]+"/"
except:
print_usage()
exit()
FileName=0
make_directories(folder)
pipeline = rs.pipeline()
config = rs.config()
config.enable_stream(rs.stream.depth, 640, 480, rs.format.z16, 30)
config.enable_stream(rs.stream.color, 640, 480, rs.format.bgr8, 30)
# Start pipeline
profile = pipeline.start(config)
frames = pipeline.wait_for_frames()
color_frame = frames.get_color_frame()
# Color Intrinsics
intr = color_frame.profile.as_video_stream_profile().intrinsics
camera_parameters = {'fx': intr.fx, 'fy': intr.fy,
'ppx': intr.ppx, 'ppy': intr.ppy,
'height': intr.height, 'width': intr.width,
'depth_scale':profile.get_device().first_depth_sensor().get_depth_scale()
}
with open(folder+'intrinsics.json', 'w') as fp:
json.dump(camera_parameters, fp)
align_to = rs.stream.color
align = rs.align(align_to)
T_start = time.time()
while True:
frames = pipeline.wait_for_frames()
aligned_frames = align.process(frames)
aligned_depth_frame = aligned_frames.get_depth_frame()
color_frame = aligned_frames.get_color_frame()
# Validate that both frames are valid
if not aligned_depth_frame or not color_frame:
continue
d = np.asanyarray(aligned_depth_frame.get_data())
c = np.asanyarray(color_frame.get_data())
# Visualize count down
if time.time() -T_start > 5:
filecad= folder+"JPEGImages/%s.jpg" % FileName
filedepth= folder+"depth/%s.png" % FileName
cv2.imwrite(filecad,c)
with open(filedepth, 'wb') as f:
writer = png.Writer(width=d.shape[1], height=d.shape[0],
bitdepth=16, greyscale=True)
zgray2list = d.tolist()
writer.write(f, zgray2list)
FileName+=1
if time.time() -T_start > RECORD_LENGTH + 5:
pipeline.stop()
break
if time.time() -T_start < 5:
cv2.putText(c,str(5-int(time.time() -T_start)),(240,320), cv2.FONT_HERSHEY_SCRIPT_SIMPLEX, 4,(0,0,255),2,cv2.LINE_AA)
if time.time() -T_start > RECORD_LENGTH:
cv2.putText(c,str(RECORD_LENGTH+5-int(time.time()-T_start)),(240,320), cv2.FONT_HERSHEY_SCRIPT_SIMPLEX, 4,(0,0,255),2,cv2.LINE_AA)
cv2.imshow('COLOR IMAGE',c)
# press q to quit the program
if cv2.waitKey(1) & 0xFF == ord('q'):
pipeline.stop()
break
# Release everything if job is finished
cv2.destroyAllWindows()