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;
            }
        }
    }

}

EmguCV C++ to convert C# EmguCV

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]