Mat转PIX

在使用Tesseract4-OCR时,它的最终识别图像类型为PIX。

有的图片质量不好,需要先做预处理。然而,PIX我们大多数人都不熟悉。

是否可以先用opencv来读入图片并做预处理,在识别之前再把图像转换为PIX呢?

经过大量百度,只找到一位外国朋友写的,Mat转PIX,亲测可用。

晒代码:

PIX* cvtMat2PIX(Mat imgGray)
{
	int cols = imgGray.cols;
	int rows = imgGray.rows;

	PIX *pixS = pixCreate(cols, rows, 8);

	for (int i = 0; i < rows; i++)
		for (int j = 0; j < cols; j++)
			pixSetPixel(pixS, j, i, (l_uint32)imgGray.at<uchar>(i, j));
	return pixS;
}

另外,看Tesseract的源码,在读入PIX的时候默认将图片转换为灰度图,因此上面代码输入参数为灰度图。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值