首页 > 解决方案 > 如何使用 OpenCV 拉直曲线?

问题描述

我有这样的曲线图像:

在此处输入图像描述

我找不到使用 OpenCV 拉直曲线的技术。它类似于这篇文章Straightening a curve contour,但我的问题是针对使用 opencv 进行编码的(在 C++ 中更好)。

到目前为止,我只能找到曲线的轮廓。

在此处输入图像描述

int main()
{
    Mat src; Mat src_gray;
    src = imread("D:/2.jpg");
    cvtColor(src, src_gray, COLOR_BGR2GRAY);
    cv::blur(src_gray, src_gray, Size(1, 15));

    Canny(src_gray, src_gray, 100, 200, 3);
    /// Find contours   
    vector<vector<Point> > contours;
    vector<Vec4i> hierarchy;
    RNG rng(12345);
    findContours(src_gray, contours, hierarchy, CV_RETR_TREE, CV_CHAIN_APPROX_SIMPLE, Point(0, 0));
    /// Draw contours
    Mat drawing = Mat::zeros(src_gray.size(), CV_8UC3);
    for (int i = 0; i < contours.size(); i++)
    {
        drawContours(drawing, contours, i, (255), 1, 8, hierarchy, 0, Point());
    }

    imshow("Result window", drawing);
    imwrite("D:/C_Backup_Folder/Ivan_codes/VideoStitcher/result/2_res.jpg", drawing);

    cv::waitKey();
    return 0;
}

但我不知道如何确定哪条线是弯曲的而不是弯曲的,以及如何拉直它。可能吗?任何帮助,将不胜感激。

标签: c++opencvimage-processing

解决方案


这是我的建议:

在一切之前,将您的图像调整为更大的图像(例如大 5 倍)。然后做你之前做的,得到轮廓。找到每个轮廓的最右侧像素,然后测量该轮廓的所有像素并计算每个像素到最右侧像素的水平距离,并对该行(整行)进行移位。此方法对某些行进行右移,对其他行进行左移。

如果您有多个轮廓,请为每一行中的每个轮廓计算此移位值并计算它们的“平均值”,然后根据每一行的平均值进行移位。

最后调整你的图像大小。这是我能想到的最简单和最快的事情。


推荐阅读