// This file is part of OpenCV project. // It is subject to the license terms in the LICENSE file found in the top-level directory // of this distribution and at http://opencv.org/license.html. #include "test_precomp.hpp" namespace opencv_test { namespace { TEST(Features2d_BlobDetector, bug_6667) { cv::Mat image = cv::Mat(cv::Size(100, 100), CV_8UC1, cv::Scalar(255, 255, 255)); cv::circle(image, Point(50, 50), 20, cv::Scalar(0), -1); SimpleBlobDetector::Params params; params.minThreshold = 250; params.maxThreshold = 260; params.minRepeatability = 1; // https://github.com/opencv/opencv/issues/6667 std::vector keypoints; Ptr detector = SimpleBlobDetector::create(params); detector->detect(image, keypoints); ASSERT_NE((int) keypoints.size(), 0); } TEST(Features2d_BlobDetector, withContours) { cv::Mat image = cv::Mat(cv::Size(100, 100), CV_8UC1, cv::Scalar(255, 255, 255)); cv::circle(image, Point(50, 50), 20, cv::Scalar(0), -1); SimpleBlobDetector::Params params; params.minThreshold = 250; params.maxThreshold = 260; params.minRepeatability = 1; // https://github.com/opencv/opencv/issues/6667 params.collectContours = true; std::vector keypoints; Ptr detector = SimpleBlobDetector::create(params); detector->detect(image, keypoints); ASSERT_NE((int)keypoints.size(), 0); ASSERT_GT((int)detector->getBlobContours().size(), 0); std::vector contour = detector->getBlobContours()[0]; ASSERT_TRUE(std::any_of(contour.begin(), contour.end(), [](Point p) { return abs(p.x - 30) < 2 && abs(p.y - 50) < 2; })); } }} // namespace