gpt4 book ai didi

c++ - CPP OpenCV - 尝试根据边缘裁剪图像

转载 作者:行者123 更新时间:2023-11-28 04:57:33 25 4
gpt4 key购买 nike

我需要根据我找到的边缘裁剪图像(使用给定的 epsilon)

我遵循以下说明: Opencv c++ detect and crop white region on image

有一个变化 - 我试图根据我从 canny 边缘检测器接收到的边缘图像找到矩形:

cv::Mat in = cv::imread("c:/cropping/myImage.png");
cv::Mat _imgGray;
cv::Mat edges;
std::vector<cv::Point> nonBlackList;

cv::cvtColor(in, _imgGray, CV_BGR2GRAY);
cv::Canny(_imgGray, edges, 5, 50, 3);
for(int j=0; j<edges.rows; ++j)
for(int i=0; i<edges.cols; ++i)
{
// if not black: add to the list
if(edges.at<cv::Vec3b>(j,i) != cv::Vec3b(0,0,0))
{
nonBlackList.push_back(cv::Point(i,j));
}
}

我遇到的问题是,当我到达第 139 列时,它因以下异常而崩溃:

Microsoft C++ exception: cv::Exception at memory location 0x000000EB35DEF170.

但是当我使用原始图像(而不是边缘图像)时,它会按预期工作。

有什么想法吗?我想要的是根据图像的边缘而不是实际图像进行裁剪

谢谢

最佳答案

Canny 结果是一个 8 位单 channel 二进制图像。您正在使用 Vec3i 访问像素值;这意味着您假设图像是 8 位 3 channel 图像,这是不正确的。尝试:

if(edges.at<uchar>(j,i) != 0)
{
nonBlackList.push_back(cv::Point(i,j));
}

关于c++ - CPP OpenCV - 尝试根据边缘裁剪图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46834246/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com