【tesseract】VS2012编译及调用tesseract遇到的一系列问题

来源:互联网 发布:管理人员必看书籍 知乎 编辑:程序博客网 时间:2024/05/21 10:01

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下的文件拷贝过来即可。


阅读全文
0 0