gpt4 book ai didi

c++ - 在差异区域周围绘制矩形

转载 作者:搜寻专家 更新时间:2023-10-31 00:10:54 26 4
gpt4 key购买 nike

我有一个我无法解决的问题。我正在使用 OpenCV 对两幅图像进行区分。我在单独的 Mat 中获取输出。使用的差异方法是 AbsDiff 方法。这是代码。

char imgName[15];

Mat img1 = imread(image_path1, COLOR_BGR2GRAY);
Mat img2 = imread(image_path2, COLOR_BGR2GRAY);

/*cvtColor(img1, img1, CV_BGR2GRAY);
cvtColor(img2, img2, CV_BGR2GRAY);*/
cv::Mat diffImage;
cv::absdiff(img2, img1, diffImage);

cv::Mat foregroundMask = cv::Mat::zeros(diffImage.rows, diffImage.cols, CV_8UC3);

float threshold = 30.0f;
float dist;

for(int j=0; j<diffImage.rows; ++j)
{
for(int i=0; i<diffImage.cols; ++i)
{
cv::Vec3b pix = diffImage.at<cv::Vec3b>(j,i);

dist = (pix[0]*pix[0] + pix[1]*pix[1] + pix[2]*pix[2]);
dist = sqrt(dist);

if(dist>threshold)
{
foregroundMask.at<unsigned char>(j,i) = 255;
}
}
}

sprintf(imgName,"D:/outputer/d.jpg");
imwrite(imgName, diffImage);

我想将差异部分绑定(bind)在一个矩形中。 findContours 绘制了过多的轮廓。但我只需要一个特定的部分。我的差异图像是 here

我想在所有五个刻度盘周围绘制一个矩形。

请指出正确的方向。

问候,

最佳答案

我将搜索给出非黑色像素的 i 索引的最高值;那是正确的边界。

最低的非黑色 i 是左边框。与 j 类似。

关于c++ - 在差异区域周围绘制矩形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35938620/

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