我想跟踪图像中的颜色。我使用以下代码(javaCV):
//Load initial image.
iplRGB = cvLoadImage(imageFile, CV_LOAD_IMAGE_UNCHANGED);
//Prepare for HSV
iplHSV = cvCreateImage(iplRGB.cvSize(), iplRGB.depth(), iplRGB.nChannels());
//Transform RGB to HSV
cvCvtColor(iplRGB, iplHSV, CV_BGR2HSV);
//Define a region of interest.
//minRow = 0; maxRow = iplHSV.height();
//minCol = 0; maxCol = iplHSV.width();
minRow = 197; minCol = 0; maxRow = 210; maxCol = 70;
//Print each HSV for each pixel of the region.
for (int y = minRow; y < maxRow; y++){
for (int x = minCol; x < maxCol; x++) {
CvScalar pixelHsv = cvGet2D(iplHSV, y, x);
double h = pixelHsv.val(0);
double s = pixelHsv.val(1);
double v = pixelHsv.val(2);
String line = y + "," + x + "," + h + "," + s + "," + v;
System.out.println(line);
}
}
我可以很容易地从输出中找出 HUE 和 SAT 的最小值和最大值。让我们调用 minHue、minSat、maxHue 和 maxSat(不是花哨的嘿!)。然后我执行这段代码:
iplMask = cvCreateImage(iplHSV.cvSize(), iplHSV.depth(), 1);
CvScalar min = cvScalar(minHue, minSat, 0, 0);
CvScalar max = cvScalar(maxHue, maxSat, 255 ,0);
cvInRangeS(iplHSV, min, max, iplMask);
当我展示 iplMask 时,我不应该看到感兴趣的区域完全是白色的吗?我没有,我看到轮廓是白色的,但矩形的内部是黑色的。我必须弄乱一些东西,但我不明白是什么。
我知道 Hue 在 [0..179] 中与 OpenCV 和 Sat 和 Val 在 [0..255] 但由于我使用 openCV 显示的值,我认为我不必重新调整...
无论如何,我迷路了。有人可以解释一下吗?谢谢。