Я работаю над видеовходом, где видео делится на кадры. Теперь я должен нарисовать прямоугольник над текстом, который меня интересует. Итак, мне нужно сохранить все координаты всех прямоугольников, которые я нарисовал на кадре в файле CSV. И мне нужно обрезать весь прямоугольник из каждого кадра. Я отправляю программу, написанную на python. В дополнение к этому, я хочу, чтобы все прямоугольники были выделены для каждого кадра.
self.capture = cv2.VideoCapture('ch3_train/Video_2_1_2.mp4')
# Bounding box reference points and boolean if we are extracting coordinates
self.image_coordinates = []
self.extract = False
self.selected_ROI = False
self.update()
def update(self):
while True:
if self.capture.isOpened():
# Read frame
(self.status, self.frame) = self.capture.read()
for i in range(len(self.frame)):
cv2.imshow('image', self.frame)
key = cv2.waitKey(2)
# Crop image
if key == ord('c'):
self.clone = self.frame.copy()
cv2.namedWindow('image')
cv2.setMouseCallback('image', self.extract_coordinates)
while True:
key = cv2.waitKey(2)
cv2.imshow('image', self.clone)
# Crop and display cropped image
if key == ord('c'):
self.crop_ROI()
self.show_cropped_ROI()
# Resume video
if key == ord('r'):
break
# Close program with keyboard 'q'
if key == ord('q'):
cv2.destroyAllWindows()
self.capture.release()
exit(1)
else:
sys.exit()
#pass
def extract_coordinates(self, event, x, y, flags, parameters):
# Record starting (x,y) coordinates on left mouse button click
if event == cv2.EVENT_LBUTTONDOWN:
self.image_coordinates = [(x,y)]
self.extract = True
# Record ending (x,y) coordintes on left mouse bottom release
elif event == cv2.EVENT_LBUTTONUP:
self.image_coordinates.append((x,y))
self.extract = False
self.selected_ROI = True
# (x1,y1,x2,y2)=[int(v) for v in f ]
# Draw rectangle around ROI
cv2.rectangle(self.clone, self.image_coordinates[0], self.image_coordinates[1], (0,255,0), 2)
'''
while self.selected_ROI:
x1 = self.image_coordinates[0][0]
y1 = self.image_coordinates[0][1]
x2 = self.image_coordinates[1][0]
y2 = self.image_coordinates[1][1]
with open ('train_annotations_bbox.csv',mode='w') as bboxfile:
bboxwriter=csv.writer(bboxfile,delimiter=',', quotechar='"', quoting=csv.QUOTE_MINIMAL)
bboxwriter.writerow(['Xmin','Xmax','Ymin','Ymax'])#[self.image_coordinators[1],self.image_coordinators[0]])
bboxwriter.writerow([x1*0.001,y1*0.001,x2*0.001,y2*0.001])
'''
#for i in event:
# cv2.imwrite("frame%d"+i+".jpg",self.clone)
# Clear drawing boxes on right mouse button click
elif event == cv2.EVENT_RBUTTONDOWN:
self.clone = self.frame.copy()
self.selected_ROI = False
def crop_ROI(self):
if self.selected_ROI:
self.cropped_image = self.frame.copy()
x1 = self.image_coordinates[0][0]
y1 = self.image_coordinates[0][1]
x2 = self.image_coordinates[1][0]
y2 = self.image_coordinates[1][1]
self.cropped_image = self.cropped_image[y1:y2, x1:x2]
print('Cropped image: {} {}'.format(self.image_coordinates[0], self.image_coordinates[1]))
#fromCenter=False
#ROIs=cv2.selectROIs('Select ROIs',self.selected_ROI,fromCenter)
#for i, ctr in enumerate(self.selected_ROI):
# cv2.imshow('roi'+str(i),self.cropped_image)
else:
print('Select ROI to crop before cropping')
def show_cropped_ROI(self):
cv2.imshow('cropped image', self.cropped_image)
Я ожидал, что выход будет зацикливаться на прямоугольниках для сохранения его координатных точек в файле CSV. Но фактический вывод сохраняет только последний выбранный прямоугольникв CSV-файле.