Нахождение контуров в OpenCV? - PullRequest
       224

Нахождение контуров в OpenCV?

14 голосов
/ 09 декабря 2011

Когда вы извлекаете контуры из изображения, вы должны получить 2 контура на блоб - один внутренний и один внешний. Рассмотрите круг ниже - поскольку круг - это линия с шириной пикселя больше единицы, вы должны быть в состоянии найти два контура на изображении - один из внутренней части круга и один из внешней части.

Используя OpenCV, я хочу получить ВНУТРЕННИЕ контуры. Однако, когда я использую findContours (), мне кажется, что я получаю только внешние контуры. Как мне получить внутренние контуры BLOB-объекта с помощью OpenCV?

Я использую API C ++, а не C, поэтому предлагаю только функции, использующие API C ++. (то есть findContours (), а не cvFindContours ())

Спасибо.

enter image description here

Ответы [ 3 ]

26 голосов
/ 12 декабря 2011

Я запустил этот код на вашем изображении, и он вернул внутренний и внешний контур.

#include <iostream>
#include "opencv2/core/core.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"

int main(int argc, const char * argv[]) {

    cv::Mat image= cv::imread("../../so8449378.jpg");
    if (!image.data) {
        std::cout << "Image file not found\n";
        return 1;
    }

    //Prepare the image for findContours
    cv::cvtColor(image, image, CV_BGR2GRAY);
    cv::threshold(image, image, 128, 255, CV_THRESH_BINARY);

    //Find the contours. Use the contourOutput Mat so the original image doesn't get overwritten
    std::vector<std::vector<cv::Point> > contours;
    cv::Mat contourOutput = image.clone();
    cv::findContours( contourOutput, contours, CV_RETR_LIST, CV_CHAIN_APPROX_NONE );

    //Draw the contours
    cv::Mat contourImage(image.size(), CV_8UC3, cv::Scalar(0,0,0));
    cv::Scalar colors[3];
    colors[0] = cv::Scalar(255, 0, 0);
    colors[1] = cv::Scalar(0, 255, 0);
    colors[2] = cv::Scalar(0, 0, 255);
    for (size_t idx = 0; idx < contours.size(); idx++) {
        cv::drawContours(contourImage, contours, idx, colors[idx % 3]);
    }

    cv::imshow("Input Image", image);
    cvMoveWindow("Input Image", 0, 0);
    cv::imshow("Contours", contourImage);
    cvMoveWindow("Contours", 200, 0);
    cv::waitKey(0);

    return 0;
}

Вот найденные контуры:

findContour result image

3 голосов
/ 04 ноября 2012

Я думаю, что Фархад просит обрезать контур от исходного изображения.

Для этого вам нужно будет найти контур, как описано выше, а затем использовать маску, чтобы получить внутреннюю часть от оригинала., а затем обрежьте результат в изображение того же размера, что и контур.

0 голосов
/ 04 января 2016

Функция findcontours хранит все контуры в разных векторах, в коде даны все контуры, вы просто рисуете контур, соответствующий внутреннему, idx - переменная, которая указывает, какой контур нарисован.

...