mirror of
https://github.com/zxing/zxing.git
synced 2025-01-14 20:57:40 -08:00
164 lines
4.7 KiB
C#
164 lines
4.7 KiB
C#
|
using com.google.zxing;
|
|||
|
using com.google.zxing.common;
|
|||
|
using System.Drawing.Imaging;
|
|||
|
using System.Drawing;
|
|||
|
using System;
|
|||
|
|
|||
|
public class RGBLuminanceSource : LuminanceSource
|
|||
|
{
|
|||
|
|
|||
|
private sbyte[] luminances;
|
|||
|
private bool isRotated = false;
|
|||
|
private bool __isRegionSelect = false;
|
|||
|
private Rectangle __Region;
|
|||
|
|
|||
|
override public int Height
|
|||
|
{
|
|||
|
get
|
|||
|
{
|
|||
|
if (!isRotated)
|
|||
|
return __height;
|
|||
|
else
|
|||
|
return __width;
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
override public int Width
|
|||
|
{
|
|||
|
get
|
|||
|
{
|
|||
|
if (!isRotated)
|
|||
|
return __width;
|
|||
|
else
|
|||
|
return __height;
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
private int __height;
|
|||
|
private int __width;
|
|||
|
|
|||
|
public RGBLuminanceSource(byte[] d, int W, int H)
|
|||
|
: base(W, H)
|
|||
|
{
|
|||
|
__width = W;
|
|||
|
__height = H;
|
|||
|
int width = W;
|
|||
|
int height = H;
|
|||
|
// In order to measure pure decoding speed, we convert the entire image to a greyscale array
|
|||
|
// up front, which is the same as the Y channel of the YUVLuminanceSource in the real app.
|
|||
|
luminances = new sbyte[width * height];
|
|||
|
for (int y = 0; y < height; y++)
|
|||
|
{
|
|||
|
int offset = y * width;
|
|||
|
for (int x = 0; x < width; x++)
|
|||
|
{
|
|||
|
int r = d[offset * 3 + x * 3];
|
|||
|
int g = d[offset * 3 + x * 3 + 1];
|
|||
|
int b = d[offset * 3 + x * 3 + 2];
|
|||
|
if (r == g && g == b)
|
|||
|
{
|
|||
|
// Image is already greyscale, so pick any channel.
|
|||
|
luminances[offset + x] = (sbyte)r;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Calculate luminance cheaply, favoring green.
|
|||
|
luminances[offset + x] = (sbyte)((r + g + g + b) >> 2);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
public RGBLuminanceSource(byte[] d, int W, int H,bool Is8Bit)
|
|||
|
: base(W, H)
|
|||
|
{
|
|||
|
__width = W;
|
|||
|
__height = H;
|
|||
|
luminances = new sbyte[W * H];
|
|||
|
Buffer.BlockCopy(d,0, luminances,0, W * H);
|
|||
|
}
|
|||
|
|
|||
|
public RGBLuminanceSource(byte[] d, int W, int H, bool Is8Bit,Rectangle Region)
|
|||
|
: base(W, H)
|
|||
|
{
|
|||
|
__width = Region.Width;
|
|||
|
__height = Region.Height;
|
|||
|
__Region = Region;
|
|||
|
__isRegionSelect = true;
|
|||
|
//luminances = Red.Imaging.Filters.CropArea(d, W, H, Region);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
public RGBLuminanceSource(Bitmap d, int W, int H)
|
|||
|
: base(W, H)
|
|||
|
{
|
|||
|
int width = __width = W;
|
|||
|
int height = __height = H;
|
|||
|
// In order to measure pure decoding speed, we convert the entire image to a greyscale array
|
|||
|
// up front, which is the same as the Y channel of the YUVLuminanceSource in the real app.
|
|||
|
luminances = new sbyte[width * height];
|
|||
|
//if (format == PixelFormat.Format8bppIndexed)
|
|||
|
{
|
|||
|
Color c;
|
|||
|
for (int y = 0; y < height; y++)
|
|||
|
{
|
|||
|
int offset = y * width;
|
|||
|
for (int x = 0; x < width; x++)
|
|||
|
{
|
|||
|
c = d.GetPixel(x, y);
|
|||
|
luminances[offset + x] = (sbyte)(((int)c.R) << 16 | ((int)c.G) << 8 | ((int)c.B));
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
override public sbyte[] getRow(int y, sbyte[] row)
|
|||
|
{
|
|||
|
if (isRotated == false)
|
|||
|
{
|
|||
|
int width = Width;
|
|||
|
if (row == null || row.Length < width)
|
|||
|
{
|
|||
|
row = new sbyte[width];
|
|||
|
}
|
|||
|
for (int i = 0; i < width; i++)
|
|||
|
row[i] = luminances[y * width + i];
|
|||
|
//System.arraycopy(luminances, y * width, row, 0, width);
|
|||
|
return row;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
int width = __width;
|
|||
|
int height = __height;
|
|||
|
if (row == null || row.Length < height)
|
|||
|
{
|
|||
|
row = new sbyte[height];
|
|||
|
}
|
|||
|
for (int i = 0; i < height; i++)
|
|||
|
row[i] = luminances[i * width + y];
|
|||
|
//System.arraycopy(luminances, y * width, row, 0, width);
|
|||
|
return row;
|
|||
|
}
|
|||
|
}
|
|||
|
public override sbyte[] Matrix
|
|||
|
{
|
|||
|
get { return luminances; }
|
|||
|
}
|
|||
|
|
|||
|
public override LuminanceSource crop(int left, int top, int width, int height)
|
|||
|
{
|
|||
|
return base.crop(left, top, width, height);
|
|||
|
}
|
|||
|
public override LuminanceSource rotateCounterClockwise()
|
|||
|
{
|
|||
|
isRotated = true;
|
|||
|
return this;
|
|||
|
}
|
|||
|
public override bool RotateSupported
|
|||
|
{
|
|||
|
get
|
|||
|
{
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
}
|