HGScannerLib c# demo增加二值图和灰度图的处理
This commit is contained in:
parent
43c43a2616
commit
4debf9c4c9
|
@ -43,26 +43,57 @@ namespace WindowsFormsApp1
|
||||||
imageInfo.origin = 0;
|
imageInfo.origin = 0;
|
||||||
HGScannerLib.HGLib_GetImageInfo(image, ref imageInfo);
|
HGScannerLib.HGLib_GetImageInfo(image, ref imageInfo);
|
||||||
|
|
||||||
Bitmap curBitmap = new Bitmap((int)imageInfo.width, (int)imageInfo.height, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
|
Bitmap curBitmap = null;
|
||||||
|
if (imageInfo.type == 1) // BINARY
|
||||||
Rectangle rect = new Rectangle(0, 0, (int)imageInfo.width, (int)imageInfo.height);
|
|
||||||
|
|
||||||
System.Drawing.Imaging.BitmapData bmpData = curBitmap.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadWrite, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
|
|
||||||
unsafe
|
|
||||||
{
|
{
|
||||||
byte* dest = (byte*)(bmpData.Scan0);
|
curBitmap = new Bitmap((int)imageInfo.width, (int)imageInfo.height, (int)imageInfo.widthStep,
|
||||||
byte* src = (byte*)imageData;
|
System.Drawing.Imaging.PixelFormat.Format1bppIndexed, imageData);
|
||||||
for (int i = 0; i < (int)imageInfo.height; i++)
|
|
||||||
|
System.Drawing.Imaging.ColorPalette palette = curBitmap.Palette;
|
||||||
|
palette.Entries[0] = Color.FromArgb(0, 0, 0);
|
||||||
|
palette.Entries[1] = Color.FromArgb(255, 255, 255);
|
||||||
|
curBitmap.Palette = palette;
|
||||||
|
}
|
||||||
|
else if (imageInfo.type == 2) // GRAY
|
||||||
|
{
|
||||||
|
curBitmap = new Bitmap((int)imageInfo.width, (int)imageInfo.height, (int)imageInfo.widthStep,
|
||||||
|
System.Drawing.Imaging.PixelFormat.Format8bppIndexed, imageData);
|
||||||
|
|
||||||
|
System.Drawing.Imaging.ColorPalette palette = curBitmap.Palette;
|
||||||
|
for (int i = 0; i < palette.Entries.Length; i++)
|
||||||
{
|
{
|
||||||
for (int j = 0; j < (int)imageInfo.width; j++)
|
palette.Entries[i] = Color.FromArgb(i, i, i);
|
||||||
|
}
|
||||||
|
curBitmap.Palette = palette;
|
||||||
|
}
|
||||||
|
else if (imageInfo.type == 3) // BGR
|
||||||
|
{
|
||||||
|
curBitmap = new Bitmap((int)imageInfo.width, (int)imageInfo.height, (int)imageInfo.widthStep,
|
||||||
|
System.Drawing.Imaging.PixelFormat.Format24bppRgb, imageData);
|
||||||
|
}
|
||||||
|
else if (imageInfo.type == 4) // RGB
|
||||||
|
{
|
||||||
|
curBitmap = new Bitmap((int)imageInfo.width, (int)imageInfo.height, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
|
||||||
|
|
||||||
|
Rectangle rect = new Rectangle(0, 0, (int)imageInfo.width, (int)imageInfo.height);
|
||||||
|
|
||||||
|
System.Drawing.Imaging.BitmapData bmpData = curBitmap.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadWrite, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
|
||||||
|
unsafe
|
||||||
|
{
|
||||||
|
byte* dest = (byte*)(bmpData.Scan0);
|
||||||
|
byte* src = (byte*)imageData;
|
||||||
|
for (int i = 0; i < (int)imageInfo.height; i++)
|
||||||
{
|
{
|
||||||
dest[i * bmpData.Stride + j * 3 + 0] = src[i * imageInfo.widthStep + j * 3 + 2];
|
for (int j = 0; j < (int)imageInfo.width; j++)
|
||||||
dest[i * bmpData.Stride + j * 3 + 1] = src[i * imageInfo.widthStep + j * 3 + 1];
|
{
|
||||||
dest[i * bmpData.Stride + j * 3 + 2] = src[i * imageInfo.widthStep + j * 3 + 0];
|
dest[i * bmpData.Stride + j * 3 + 0] = src[i * imageInfo.widthStep + j * 3 + 2];
|
||||||
|
dest[i * bmpData.Stride + j * 3 + 1] = src[i * imageInfo.widthStep + j * 3 + 1];
|
||||||
|
dest[i * bmpData.Stride + j * 3 + 2] = src[i * imageInfo.widthStep + j * 3 + 0];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
curBitmap.UnlockBits(bmpData);
|
||||||
}
|
}
|
||||||
curBitmap.UnlockBits(bmpData);
|
|
||||||
|
|
||||||
curBitmap.Save("3.jpg");
|
curBitmap.Save("3.jpg");
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue