C# 什么是好的真正的黑白色矩阵?

C# 什么是好的真正的黑白色矩阵?,c#,vb.net,image,image-processing,colormatrix,C#,Vb.net,Image,Image Processing,Colormatrix,我想将图像从彩色转换为黑白(即没有灰度,只有黑白)。有人有好的颜色矩阵来实现这一点吗?如果你想让它看起来有点像样,你可能需要应用某种形式的抖动 这里有一个完整的讨论,如果有点过时: 我终于找到了解决问题的方法: 使用已知的颜色矩阵将图像转换为灰度 使用ImageAttributes类的SetThreshold方法设置区分黑白的阈值 以下是C#代码: 我已经对这段代码进行了基准测试,它比逐像素操作快大约40倍。VB.NET版本: Using gr As Graphics = Graphics.Fr

我想将图像从彩色转换为黑白(即没有灰度,只有黑白)。有人有好的颜色矩阵来实现这一点吗?

如果你想让它看起来有点像样,你可能需要应用某种形式的抖动

这里有一个完整的讨论,如果有点过时:


我终于找到了解决问题的方法:

  • 使用已知的颜色矩阵将图像转换为灰度
  • 使用ImageAttributes类的SetThreshold方法设置区分黑白的阈值
  • 以下是C#代码:

    我已经对这段代码进行了基准测试,它比逐像素操作快大约40倍。

    VB.NET版本:

    Using gr As Graphics = Graphics.FromImage(SourceImage) 'SourceImage is a Bitmap object'
      Dim gray_matrix As Single()() = {
        New Single() {0.299F, 0.299F, 0.299F, 0, 0},
        New Single() {0.587F, 0.587F, 0.587F, 0, 0},
        New Single() {0.114F, 0.114F, 0.114F, 0, 0},
        New Single() {0, 0, 0, 1, 0},
        New Single() {0, 0, 0, 0, 1}
      }
      Dim ia As New System.Drawing.Imaging.ImageAttributes
      ia.SetColorMatrix(New System.Drawing.Imaging.ColorMatrix(gray_matrix))
      ia.SetThreshold(0.8)
      Dim rc As New Rectangle(0, 0, SourceImage.Width, SourceImage.Height)
      gr.DrawImage(SourceImage, rc, 0, 0, SourceImage.Width, SourceImage.Height, GraphicsUnit.Pixel, ia)
    End Using
    

    您不需要一个颜色矩阵来实现这一点,只需将编码更改为CCITT即可!那只是黑白的。结果保持正确,结果文件大小非常小。也比
    System.DrawImage
    更高效、更快

    这是一个完美的解决方案:

    public void toCCITT(string tifURL)
    {
        byte[] imgBits = File.ReadAllBytes(tifURL);
    
        using (MemoryStream ms = new MemoryStream(imgBits))
        {
            using (Image i = Image.FromStream(ms))
            {
                EncoderParameters parms = new EncoderParameters(1);
                ImageCodecInfo codec = ImageCodecInfo.GetImageDecoders()
                                                     .FirstOrDefault(decoder => decoder.FormatID == ImageFormat.Tiff.Guid);
    
                parms.Param[0] = new EncoderParameter(Encoder.Compression, (long)EncoderValue.CompressionCCITT4);
    
                i.Save(@"c:\test\result.tif", codec, parms);
            }
        }
    }
    

    我想要黑色和白色,因为这是图像识别过程的一部分,也就是说,无论颜色如何,都能识别出一些形状。在这种情况下,你可能可以通过“像素[x,y]=((R(x,y)+G(x,y)+B(x,y))/3>=127?1:0”这是我已经尝试过的,但是改变图像像素的速度非常慢。这会做黑白(不是灰度):
    newcolormatrix(newsingle(){newsingle(){1.5,1.5,1.5,0,0},{newsingle(){1.5,1.5,1.5,0,0},{1.5,1.5,0,0},{newsingle 0,0},{0,0,0,0,0,0,0},},{newsingle Single 1,1,-1,0,{1,}代码不会工作。它将提供更锐利的边缘,但仍然是灰色值。@Pedery:您一定没有正确地实现它,这正是黑白(没有任何灰色阴影)的操作方法。MSDN Doc on draw image:知道如何在Android Xamarin解决方案中实现吗?无法访问EncoderParameters,也无法访问ImageCodeInfo…我认为您也可以在Xamarin中使用BitmapEncoder类。你打算用手机扫描送货单吗?不,我试图绕过epson SDK,因为我们遇到了一些问题,直接打印到打印机插座上。
    
    public void toCCITT(string tifURL)
    {
        byte[] imgBits = File.ReadAllBytes(tifURL);
    
        using (MemoryStream ms = new MemoryStream(imgBits))
        {
            using (Image i = Image.FromStream(ms))
            {
                EncoderParameters parms = new EncoderParameters(1);
                ImageCodecInfo codec = ImageCodecInfo.GetImageDecoders()
                                                     .FirstOrDefault(decoder => decoder.FormatID == ImageFormat.Tiff.Guid);
    
                parms.Param[0] = new EncoderParameter(Encoder.Compression, (long)EncoderValue.CompressionCCITT4);
    
                i.Save(@"c:\test\result.tif", codec, parms);
            }
        }
    }