Обнаружение объектов OpenCV - Центральная точка
-
07-07-2019 - |
Вопрос
Учитывая объект на простом белом фоне, кто-нибудь знает, предоставляет ли OpenCV функциональность для легкого обнаружения объекта из захваченного кадра? Р>
Я пытаюсь найти угловые / центральные точки объекта (прямоугольник). То, как я сейчас это делаю, - грубой силой (сканируя изображение на предмет) и не точным. Мне интересно, есть ли под капотом функциональность, о которой я не знаю.
Изменить данные . Размер примерно такой же, как у маленькой банки с газировкой. Камера расположена над объектом, чтобы дать ему ощущение 2D / прямоугольника. Ориентация / угол от камеры - случайная, которая рассчитывается из угловых точек.
Это просто белый фон с объектом на нем (черный). Качество снимка примерно соответствует тому, что вы ожидаете увидеть от веб-камеры Logitech.
Как только я получу угловые точки, я вычисляю центр. Центральная точка затем преобразуется в сантиметры.
Я пытаюсь сосредоточиться на том, как я получаю эти 4 угла. Вы можете увидеть мой метод грубой силы с этим изображением: Изображение
Решение
Уже есть пример того, как сделать обнаружение прямоугольника в OpenCV (см. samples / squares.c), и на самом деле это довольно просто.
Вот грубый алгоритм, который они используют:
0. rectangles <- {}
1. image <- load image
2. for every channel:
2.1 image_canny <- apply canny edge detector to this channel
2.2 for threshold in bunch_of_increasing_thresholds:
2.2.1 image_thresholds[threshold] <- apply threshold to this channel
2.3 for each contour found in {image_canny} U image_thresholds:
2.3.1 Approximate contour with polygons
2.3.2 if the approximation has four corners and the angles are close to 90 degrees.
2.3.2.1 rectangles <- rectangles U {contour}
Не точная транслитерация того, что они делают, но это должно вам помочь.
Другие советы
Надеюсь, это поможет, использует метод момента, чтобы получить центр тяжести черно-белого изображения.
cv::Point getCentroid(cv::Mat img)
{
cv::Point Coord;
cv::Moments mm = cv::moments(img,false);
double moment10 = mm.m10;
double moment01 = mm.m01;
double moment00 = mm.m00;
Coord.x = int(moment10 / moment00);
Coord.y = int(moment01 / moment00);
return Coord;
}
OpenCV имеет множество функций, которые могут помочь вам достичь этого. Загрузите Emgu.CV для C # .NET в библиотеку, если вы программируете на этом языке.
Некоторые способы получить то, что вы хотите:
<Ол>Найдите углы, как раньше - например, Quot & & CornerHarris Quot; Функция OpenCV
Пороговое изображение и вычисление центра тяжести - см. http : //www.roborealm.com/help/Center%20of%20Gravity.php ... это метод, который я бы использовал. Вы даже можете выполнить пороговое значение в рутине COG. т.е. cog_x + = * imagePtr < 128? 255: 0;
Найдите моменты изображения, чтобы задать вращение, центр тяжести и т. д. - например, & Quot; Moments Quot &; Функция OpenCV. (Я этим не пользовался)
(правка) Библиотека AForge.NET имеет функции обнаружения углов, а также пример проекта (MotionDetector) и библиотеки для подключения к веб-камерам. Я думаю, что это будет самый простой способ, если вы используете Windows и .NET.
Обычно это называется анализом BLOB-объектов в других библиотеках машинного зрения. Я еще не использовал opencv.