EmguCV C++ to convert C# EmguCV
本文关键字:EmguCV convert to C++ | 更新日期: 2023-09-27 18:21:13
我正试图用EmguCV在通道H中进行像素计数,大多数人在C++中都有这段代码,并希望将EmguCV C++的部分转换为C#,尤其是在(I,j)处的uchar tone=comp[0]部分;这让我很头疼,非常感谢你能帮我吗?
这是代码:
ProcessadorImagem::calculaHistograma(cv::Mat-imagem,DadosImagem*DadosImagem){
cv::Mat hls;
cv::cvtColor(imagem, hls, CV_RGB2HLS_FULL);
cv::Mat* comp = new cv::Mat[3];
cv::split(hls, comp);
for (int i = 0; i < imagem.rows; i++)
for (int j = 0; j < imagem.cols; j++) {
uchar tom = comp[0].at<uchar>(i, j);
for (int k = 0; k < dadosImagem->getHistograma().size(); k++) {
uchar min = dadosImagem->getHistograma()[k]->getLimiteInicial();
uchar max = dadosImagem->getHistograma()[k]->getLimiteFinal();
if (tom >= min && tom <= max) {
int contagem = dadosImagem->getHistograma()[k]->getContagemPixels();
dadosImagem->getHistograma()[k]->setContagemPixels(contagem + 1);
break;
}
}
}
}
public class ColorDetails
{
public Hsv hueLowerLimit { get; set; }
public Hsv hueUpperLimit { get; set; }
}
hueLowerLimit = new Hsv(hueLow, satLow, valLow);
hueUpperLimit = new Hsv(hueHigh, satHigh, valHigh);
===================
ColorDetails element = // add hue upperlimit and lower limit here
Image<Gray, byte> filteredImage = null;
//function to filter out a specified hue range
if (element.hueLowerLimit.Hue > element.hueUpperLimit.Hue)
{
filteredImage = hsvImage.InRange(element.hueLowerLimit, new Hsv(180, element.hueUpperLimit.Satuation, element.hueUpperLimit.Value))
.Add(hsvImage.InRange(new Hsv(0, element.hueLowerLimit.Satuation, element.hueLowerLimit.Value), element.hueUpperLimit));
}
else
{
filteredImage = hsvImage.InRange(element.hueLowerLimit, element.hueUpperLimit);
}
/*
//for debugging
Image<Bgr, Byte> masked = new Image<Bgr, byte>(image.Size);
image.Copy(masked, filteredImage);
Console.WriteLine("Color Count : " + filteredImage.CountNonzero()[0]);
CvInvoke.Imshow("out", masked);
CvInvoke.WaitKey(0);
*/
//this is the pixel count of a particular hue range
filteredImage.CountNonzero()[0]