我正在使用emgu CV从图像中检测静脉,我几乎没有问题。有没有简单的方法来检测颜色或颜色范围?是否有一种简单的方法可以将这种颜色替换为另一种颜色(例如图像的平均颜色)?如何在不降低性能的情况下实现这一目标?
提前致谢!
答案 0 :(得分:3)
我无法想象这个问题已经发表了大约3年......
public static Image<Bgr, byte> BackgroundToGreen(Image<Bgr, byte> rgbimage)
{
Image<Bgr, byte> ret = rgbimage;
var image = rgbimage.InRange(new Bgr(190, 190, 190), new Bgr(255, 255, 255));
var mat = rgbimage.Mat;
mat.SetTo(new MCvScalar(200, 237, 204), image);
mat.CopyTo(ret);
return ret;
}
为何选择Matrix?
http://www.emgu.com/wiki/index.php/Working_with_Images#Accessing_the_pixels_from_Mat
与Image&lt;,&gt;不同类,其中内存是预先分配和修复的,Mat的内存可以通过Open CV函数调用自动重新分配。我们无法预先分配托管内存,并假设在Mat对象的生命周期内使用相同的内存。因此,Mat类不包含像Image&lt;,&gt;这样的Data属性。 class,可以通过托管数组访问像素。
什么是InRange?
http://www.emgu.com/wiki/files/2.0.0.0/html/07eff70b-f81f-6313-98a9-02d508f7c7e0.htm
检查图像元素位于两个标量之间
返回值
res [i,j] = 255(如果是inrange),否则为0
什么是SetTo?
http://www.emgu.com/wiki/files/2.4.0/document/html/0309f41d-aa02-2c0d-767f-3d7d8ccc9212.htm
将标量值复制到目标GpuMat的每个选定元素:GpuMat(I)=值,如果掩码(I)!= 0
就是这样。
引自:http://blog.zsxsoft.com/post/24(仅限中文)(CC BY-NC-ND)
答案 1 :(得分:1)
Image<Bgr, Byte> img;
Image<Gray, Byte> grayImg = img.Convert<Gray, Byte>();
grayImg = img.InRange(new Bgr(minB, minG, minR), new Bgr(new Bgr(maxB, maxG, maxR);
它只会以二进制显示您的颜色(范围)并且是最快的 方式
但是如果你想检测一定范围的颜色并替换它们:
Image<Bgr, Byte> img;
for (int i = 0; i < img.ManagedArray.GetLength(0); i++)
{
for (int j = 0; j < img.ManagedArray.GetLength(1); j++)
{
Bgr currentColor = img[i, j];
if (currentColor.Blue >= minB && currentColor.Blue <= maxB && currentColor.Green >= minG && maxG <= trackBar13.Value && currentColor.Red >= minR && currentColor.Red <= maxR)
{
img[i, j] = new Bgr(B,G,R);
}
}
}