OpenCV 4.11.0
开源计算机视觉库
加载中…
搜索中…
未找到匹配项
平面目标检测

上一教程: 使用 Features2D + 单应性查找已知物体
下一教程: AKAZE 局部特征匹配

原作者Victor Eruhimov
兼容性OpenCV >= 3.0

本教程的目标是学习如何使用features2dcalib3d模块在场景中检测已知的平面物体。

测试数据:使用您数据文件夹中的图像,例如 box.png 和 box_in_scene.png。

  • 创建一个新的控制台项目。读取两张输入图像。
    Mat img1 = imread(argv[1], IMREAD_GRAYSCALE);
    Mat img2 = imread(argv[2], IMREAD_GRAYSCALE);
    
  • 检测两张图像中的关键点,并为每个关键点计算描述符。
    // detecting keypoints
    Ptr<Feature2D> surf = SURF::create();
    vector<KeyPoint> keypoints1;
    Mat descriptors1;
    surf->detectAndCompute(img1, Mat(), keypoints1, descriptors1);
    
    ... // do the same for the second image
    
  • 现在,找到第一张图像的描述符与第二张图像描述符之间最接近的匹配项:
    // matching descriptors
    BruteForceMatcher<L2<float> > matcher;
    vector<DMatch> matches;
    matcher.match(descriptors1, descriptors2, matches);
    
  • 可视化结果:
    // drawing the results
    namedWindow("matches", 1);
    Mat img_matches;
    drawMatches(img1, keypoints1, img2, keypoints2, matches, img_matches);
    imshow("matches", img_matches);
    waitKey(0);
    
  • 找到两组点之间的单应性变换:
    vector<Point2f> points1, points2;
    // fill the arrays with the points
    ....
    Mat H = findHomography(Mat(points1), Mat(points2), RANSAC, ransacReprojThreshold);
    
  • 创建一组内点匹配并绘制它们。使用perspectiveTransform函数根据单应性映射点

    Mat points1Projected; perspectiveTransform(Mat(points1), points1Projected, H);

  • 使用drawMatches绘制内点。