久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

將位圖轉換為單色

Converting a bitmap to monochrome(將位圖轉換為單色)
本文介紹了將位圖轉換為單色的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我正在嘗試將圖像保存為單色(黑白,1 位深度),但我不知道該怎么做.

I am trying to save an image as monochrome (black&white, 1 bit-depth) but I'm coming up lost how to do it.

我從 png 開始并轉換為位圖進行打印(它是熱敏打印機,無論如何只支持黑色 - 如果我嘗試將它們作為彩色/灰度發送,它對于大圖像的速度會很慢).

I am starting with a png and converting to a bitmap for printing (it's a thermal printer and only supports black anyway - plus its slow as hell for large images if I try to send them as color/grayscale).

到目前為止,我的代碼將其轉換為位圖非常簡單,但它保留了原始顏色深度.

My code so far is dead simple to convert it to a bitmap, but it is retaining the original colour depth.

Image image = Image.FromFile("C:\test.png");

byte[] bitmapFileData = null;
int bitsPerPixel = 1;
int bitmapDataLength;

using (MemoryStream str = new MemoryStream())
{
    image.Save(str, ImageFormat.Bmp);
    bitmapFileData = str.ToArray();
}

推薦答案

這是我放在一起的一些代碼,它采用全彩色(24 位/像素)圖像,并將其轉換為 1 位/像素輸出位圖,應用標準 RGB 到灰度轉換,然后使用 Floyd-Steinberg 將灰度轉換為 1 位/像素輸出.

Here's some code I put together that takes a full colour (24 bits/pixel) image, and converts it to a 1 bit/pixel output bitmap, applying a standard RGB to greyscale conversion, and then using Floyd-Steinberg to convert greyscale to the 1 bit/pixel output.

請注意,這絕不應該被視為理想"的實現,但它確實有效.如果您愿意,可以應用許多改進.例如,它將整個輸入圖像復制到 data 數組中,而我們實際上只需要在內存中保留兩行(當前"和下一個"行)來累積錯誤數據.盡管如此,性能似乎還可以接受.

Note that this should by no means be considered an "ideal" implementation, but it does work. There are a number of improvements that could be applied if you wanted. For example, it copies the entire input image into the data array, whereas we really only need to keep two lines in memory (the "current" and "next" lines) for accumulating the error data. Despite this, performance seems acceptable.

public static Bitmap ConvertTo1Bit(Bitmap input)
{
    var masks = new byte[] { 0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01 };
    var output = new Bitmap(input.Width, input.Height, PixelFormat.Format1bppIndexed);
    var data = new sbyte[input.Width, input.Height];
    var inputData = input.LockBits(new Rectangle(0, 0, input.Width, input.Height), ImageLockMode.ReadOnly, PixelFormat.Format24bppRgb);
    try
    {
        var scanLine = inputData.Scan0;
        var line = new byte[inputData.Stride];
        for (var y = 0; y < inputData.Height; y++, scanLine += inputData.Stride)
        {
            Marshal.Copy(scanLine, line, 0, line.Length);
            for (var x = 0; x < input.Width; x++)
            {
                data[x, y] = (sbyte)(64 * (GetGreyLevel(line[x * 3 + 2], line[x * 3 + 1], line[x * 3 + 0]) - 0.5));
            }
        }
    }
    finally
    {
        input.UnlockBits(inputData);
    }
    var outputData = output.LockBits(new Rectangle(0, 0, output.Width, output.Height), ImageLockMode.WriteOnly, PixelFormat.Format1bppIndexed);
    try
    {
        var scanLine = outputData.Scan0;
        for (var y = 0; y < outputData.Height; y++, scanLine += outputData.Stride)
        {
            var line = new byte[outputData.Stride];
            for (var x = 0; x < input.Width; x++)
            {
                var j = data[x, y] > 0;
                if (j) line[x / 8] |= masks[x % 8];
                var error = (sbyte)(data[x, y] - (j ? 32 : -32));
                if (x < input.Width - 1) data[x + 1, y] += (sbyte)(7 * error / 16);
                if (y < input.Height - 1)
                {
                    if (x > 0) data[x - 1, y + 1] += (sbyte)(3 * error / 16);
                    data[x, y + 1] += (sbyte)(5 * error / 16);
                    if (x < input.Width - 1) data[x + 1, y + 1] += (sbyte)(1 * error / 16);
                }
            }
            Marshal.Copy(line, 0, scanLine, outputData.Stride);
        }
    }
    finally
    {
        output.UnlockBits(outputData);
    }
    return output;
}

public static double GetGreyLevel(byte r, byte g, byte b)
{
    return (r * 0.299 + g * 0.587 + b * 0.114) / 255;
}

這篇關于將位圖轉換為單色的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Right-click on a Listbox in a Silverlight 4 app(右鍵單擊 Silverlight 4 應用程序中的列表框)
WPF c# webbrowser scrolls over top menu(WPF c# webbrowser 在頂部菜單上滾動)
C# Console app - How do I make an interactive menu?(C# 控制臺應用程序 - 如何制作交互式菜單?)
How to avoid duplicate form creation in .NET Windows Forms?(如何避免在 .NET Windows Forms 中創建重復的表單?)
UI Automation Control Desktop Application and Click on Menu Strip(UI自動化控制桌面應用程序并單擊菜單條)
Removing thin border around the menuitems(刪除菜單項周圍的細邊框)
主站蜘蛛池模板: 中文字幕亚洲精品 | 激情综合五月天 | 性色视频在线观看 | 久久精品网 | 国产午夜精品一区二区三区嫩草 | 国产成人短视频在线观看 | 亚洲精品视频在线看 | 久色一区 | 精品国产一区二区国模嫣然 | 久久久国产精品 | av网站在线播放 | 久久久精品影院 | 蜜桃久久 | 一级黄色淫片 | 男人久久天堂 | 中文字幕国产日韩 | 天天亚洲 | 亚洲 中文 欧美 日韩 在线观看 | 在线免费av电影 | 国产乱码精品1区2区3区 | 天天干天天爱天天爽 | aaa国产大片 | 日本精品一区二区三区四区 | a级免费观看视频 | 综合激情久久 | 国产日韩精品一区二区三区 | 久久成人国产精品 | 日韩1区 | 宅女噜噜66国产精品观看免费 | 一区二区三区四区在线 | 免费在线一区二区 | 色888www视频在线观看 | 日韩中文视频 | 本道综合精品 | 亚洲欧美精品久久 | 免费看黄色小视频 | 国产精品一区三区 | 99在线免费视频 | 少妇午夜一级艳片欧美精品 | 欧美午夜剧场 | 91av视频在线观看 |