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

1 篇文章 0 订阅

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值