Я использую алгоритм OpenCV GrabCut, как описано здесь (https://opencv -python-tutroals.readthedocs.io / en / latest / py_tutorials / py_imgproc / py_grabcut / py_grabcut.html # grabcut ), чтобы извлечьпередний план в изображении.
import numpy as np
import cv2
from matplotlib import pyplot as plt
img = cv2.imread('messi5.jpg')
mask = np.zeros(img.shape[:2],np.uint8)
bgdModel = np.zeros((1,65),np.float64)
fgdModel = np.zeros((1,65),np.float64)
rect = (50,50,450,290)
cv2.grabCut(img,mask,rect,bgdModel,fgdModel,5,cv2.GC_INIT_WITH_RECT)
mask2 = np.where((mask==2)|(mask==0),0,1).astype('uint8')
img = img*mask2[:,:,np.newaxis]
Теперь я могу сохранить это изображение, полученное с помощью cv.imwrite('filename', img)
, и выходное изображение содержит только передний план с затемненным фоном.
Я хотелчтобы получить координаты ограничительной рамки для переднего плана как (LowerXcoordinate, LowerYcoordinate) и (UpperXcoordinate, UpperYcoordinate).
Один из способов, которые я могу себе представить, - рассмотреть изображение как 2D-матрицу пикселей, чтобы получить верхний Y-координата начинается со строки 1, и строка за строкой проверяет, является ли значение цвета всех пикселей черным.Первая строка с не черным пикселем будет там, где начинается передний план.Точно так же, начиная с последнего ряда и работая вверх, я мог получить нижнюю Y-координату.И просто повторите процедуру со столбцами, чтобы получить координаты X.
Прямо сейчас единственный наивный способ, который я знаю, - это вручную писать циклы для проверки этого.
Есть ли какой-нибудь более простой метод, использующий библиотечные функции для достижения этой цели?