嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 20 元微信扫码支付:20 元
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
C# tesseract图形识别,可识别中文(中文的需要培育),
附件中还包含了 tesseract-ocr-setup-3.02.02.exe 和 tesseract-ocr-3.02.chi_sim.tar.gz (这些工具仅用于理解tesseract,直接通过命令行测试的工具(和源码无关,供测试用))
安装 tesseract-ocr-setup-3.02.02.exe 之后 将tesseract-ocr-3.02.chi_sim.tar.gz中的 chi_sim.traineddata 拷贝到 tessdata的目录,然后cmd 执行如下脚本即可 识别中文(识别结果保存到安装目录的 result文件中)
private Bitmap PreprocesImage(Bitmap image)
{
//You can change your new color here. Red,Green,LawnGreen any..
Color actualColor;
//make an empty bitmap the same size as scrBitmap
image = ResizeImage(image, image.Width * 5, image.Height * 5);
//image.Save(@"D:\UpWork\OCR_WinForm\Preprocess_Resize.jpg");
Bitmap newBitmap = new Bitmap(image.Width, image.Height);
for (int i = 0; i < image.Width; i )
{
for (int j = 0; j < image.Height; j )
{
//get the pixel from the scrBitmap image
actualColor = image.GetPixel(i, j);
// > 150 because.. Images edges can be of low pixel colr. if we set all pixel color to new then there will be no smoothness left.
if (actualColor.R > 135 && actualColor.G > 135 && actualColor.B > 135)
newBitmap.SetPixel(i, j, Color.White);
else
newBitmap.SetPixel(i, j, Color.Black);
}
}
return newBitmap;
}
private Bitmap ResizeImage(Image image, int width, int height)
{
var destRect = new Rectangle(0, 0, width, height);
var destImage = new Bitmap(width, height);
destImage.SetResolution(image.HorizontalResolution , image.VerticalResolution * 2);//2,3
//image.Save(@"D:\UpWork\OCR_WinForm\Preprocess_HighRes.jpg");
using (var graphics = Graphics.FromImage(destImage))
{
graphics.CompositingMode = CompositingMode.SourceOver;
graphics.CompositingQuality = CompositingQuality.HighQuality;
graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;
graphics.SmoothingMode = SmoothingMode.HighQuality;
graphics.PixelOffsetMode = PixelOffsetMode.HighQuality;
using (var wrapMode = new ImageAttributes())
{
wrapMode.SetWrapMode(WrapMode.Clamp);
graphics.DrawImage(image, destRect, 0, 0, image.Width, image.Height, GraphicsUnit.Pixel, wrapMode);
}
}
return destImage;
}
// May need this at some point
public static Bitmap ImageSharpen(Bitmap image)
{
Bitmap sharpenImage = new Bitmap(image.Width, image.Height);
int filterWidth = 3;
int filterHeight = 3;
int w = image.Width;
int h = image.Height;
double[,] filter = new double[filterWidth, filterHeight];
filter[0, 0] = filter[0, 1] = filter[0, 2] = filter[1, 0] = filter[1, 2] = filter[2, 0] = filter[2, 1] = filter[2, 2] = -1;
filter[1, 1] = 9;
double factor = 1.0;
double bias = 0.0;
Color[,] result = new Color[image.Width, image.Height];
for (int x = 0; x < w; x)
{
for (int y = 0; y < h; y)
{
double red = 0.0, green = 0.0, blue = 0.0;
//=====[REMOVE LINES]========================================================
// Color must be read per filter entry, not per image pixel.
//Color imageColor = image.GetPixel(x, y);
//===========================================================================
for (int filterX = 0; filterX < filterWidth; filterX )
{
for (int filterY = 0; filterY < filterHeight; filterY )
{
int imageX = (x - filterWidth / 2 filterX w) % w;
int imageY = (y - filterHeight / 2 filterY h) % h;
//=====[INSERT LINES]========================================================
// Get the color here - once per fiter entry and image pixel.
Color imageColor = image.GetPixel(imageX, imageY);
//===========================================================================
red = imageColor.R * filter[filterX, filterY];
green = imageColor.G * filter[filterX, filterY];
blue = imageColor.B * filter[filterX, filterY];
}
int r = Math.Min(Math.Max((int)(factor * red bias), 0), 255);
int g = Math.Min(Math.Max((int)(factor * green bias), 0), 255);
int b = Math.Min(Math.Max((int)(factor * blue bias), 0), 255);
result[x, y] = Color.FromArgb(r, g, b);
}
}
}
for (int i = 0; i < w; i)
{
for (int j = 0; j < h; j)
{
sharpenImage.SetPixel(i, j, result[i, j]);
}
}
return sharpenImage;
}
}
}