VS2012成功编译后的tesseract链接:http://download.csdn.net/download/qq_15947787/10042499
———————————————————————————————————————————————
问题1:
再编译tesseract-vs2012-master时遇到了这样的warning,并带来一系列莫名其妙的error。
warning C4819 该文件包含不能在当前代码页(936)中表示的字符。请将该文件保存为 Unicode 格式以防止数据丢失
解决方法:
首先打开有该warning的文件,点击【文件】选【高级保存选项】,显示如下,或是其他别的编码格式,
现在开始改变编码格式为【简体中文(GB2312)- 代码页936】或【Unicode】,总之是适合自己的编码格式
点击【确定】后保存,重新编译,warning消失。
———————————————————————————————————————————————
问题2:Please make sure the TESSDATA_PREFIX environment variable is set to the parent directory of your "tessdata" directory.Failed loading language 'eng' .Tesseract couldn't load any languages!
测试代码
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <tesseract/baseapi.h>
#include <iostream>
int main(int argc, char** argv)
{
// Load image
cv::Mat im = cv::imread("t.bmp");
if (im.empty())
{
std::cout << "Cannot open source image!" << std::endl;
return -1;
}
cv::Mat gray;
cv::cvtColor(im, gray, CV_BGR2GRAY);
// ...other image pre-processing here...
// Pass it to Tesseract API
tesseract::TessBaseAPI tess;
tess.Init(NULL, "eng", tesseract::OEM_DEFAULT);
tess.SetPageSegMode(tesseract::PSM_SINGLE_BLOCK);
tess.SetImage((uchar*)gray.data, gray.cols, gray.rows, 1, gray.cols);
// Get the text
char* out = tess.GetUTF8Text();
std::cout << out << std::endl;
return 0;
}
解决方法:
从下面源码中可以分析:如果定义了TESSDATA_PREFIX这个环境变量,datadir则使用环境变量的路径,如果未定义这个环境变量,则通过argv0传入的参数,也就是tess.Init的第一个参数。
删除系统环境变量TESSDATA_PREFIX,程序默认从工程目录/可执行文件目录寻找tessdata,只要将tessdata下的文件拷贝过来即可。