我创建了以下函数来使用 opencv 计算图像矩阵中具有最小强度的点。但是,我总是将点 0,0 作为强度最小的点,并且强度值也很荒谬,例如 -2142484923。有人可以帮忙吗?
img 是输入图像矩阵,minloc 返回具有最小强度的 cvPoint。
int min_Loc(Mat img, Point minloc)
{
cvtColor(img, img, CV_RGB2GRAY);
int x1;
int y1;
int x2;
int y2;
x1 = 0;
x2 = img.rows;
y1 = 0;
y2 = img.cols;
int min = std::numeric_limits< int >::max();
int currentval;
for (int j=y1; j<y2; j++)
{
for (int i=x1; i<x2; i++){
currentval = img.at<int>(j,i);
if(currentval < min){
min = std::min<int>( currentval, min );
minloc.x = i;
minloc.y = j;
}
}
}
return min;
}