繁体   English   中英

如何使用指针通过C#和Emgucv处理图像?

[英]How to use pointer to process image with c# and emgucv?

我想用指针处理图像以使其更快。首先,我这样做

unsafe
    {
        double a = 288 / 55;
        double b = -215 * 288 / 55;
        MIplImage ss = diff.MIplImage;
        for (int i = 0; i < ss.height; i++)
        {
            IntPtr ptr = ss.imageData + i * ss.widthStep;
            for (int j = 0; j < ss.width; j++)
            {
                if (a * j - i + b > 0)
                    ((byte*)(ptr))[j] = 0;
            }
        }
    }

它的性能很好(0.5ms,而没有指针则为4ms)。

然后我发现应该修复托管对象以防止重定位,所以我想这就像

Image<Gray, byte> diff = new Image<Gray, byte>(frame.Width,frame.Height);
fixed (void* p_temp=diff.Ptr.ToPointer()){}

要么

fixed (byte* p_temp=(byte*)temp.Ptr){}

但这是错误的,那么如何修复图像呢? 以及如何在emgucv中使用指针? 我真的很困惑。谢谢!

unsafe
        {
            var data = diff.Data;
            int stride = diff.MIplImage.widthStep;
            byte* p;
            fixed (byte* pData = data)
            {
                for (int i = 0; i < diff.Height; i++)
                {
                    p = pData + i * stride;
                    for (int j = 0; j < diff.Width; j++)
                    {
                        if (a * j - i + b > 0)
                            *(p + j) = (byte)0;
                    }

                }
            }
        }

我只是做了一个快速演示(不是生产质量代码),为您提供了有关不安全emgu使用的入门示例。

        Image<Gray, Byte> img = new Image<Gray, byte>(510, 510);            
        // Fill image with random values
        img.SetRandUniform(new MCvScalar(), new MCvScalar(255));
        // Show Image
        ImageViewer.Show(img);
        var data = img.Data;
        int stride = img.MIplImage.widthStep;
        fixed (byte* pData = data)
        {
            for (int i = 0; i < 255 * stride; i++)
                *(pData + i) = (byte)(i % stride);
        }
        // Show Image Again
        ImageViewer.Show(img);

首先,我用随机噪声填充图像,然后用渐变填充一些行:-) 在此处输入图片说明

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM