我试图在android上使用tess-two从图像中获取文本。
但它给了我一个非常糟糕的结果
01-16 12:00:25.339: I/Tesseract(native)(29038): Initialized Tesseract API with language=spa
并在30秒后将其显示为结果字符串:
{ga
.,
r¿
y“: A
r M í
:3
' ‘Ev’.-:.. -: A 7
» w- ?" _
Á.» ¿"A ¿rw-V r
mjÏfn 'n’n . Y
' "\'ZA".‘.¡ A‘ :‘ïvAv- « ‘
:"Éf‘Ï'" -Ï«l :‘,.v:...»- .
' RFI' .. ’ g)" 3;:- 1-;4',
= * ¿,arifgggk mw; .1. ,
' "53» "J
't‘ ‘ ¿Las ;.‘».L',-‘»
' ' 'N‘“ "“=: - '. V . ‘9!
5.? ' “F a .“
Y , <_ 7- . 7.-, .
;« z "1:;2wr . A - . ' -»‘ 5“:
“4-”, ¿rn 73:33: w v'.‘ ¿a ‘ A ,z, v VA
...,,« ' 'Q ' ‘ 4 214€. 5 . AV ¿JL y .13:
1 » . 21mm; » ¿ati-“fl ¿ab-1377*“ w”
. x ‘ ‘ ú F v'v:
1 . ' . ; (“ya í .
当然这不正确,我使用这张照片:
我已经尝试了很多次,总是有类似的结果。
可能有什么问题,这是我的代码使用tess-two
TessBaseAPI baseApi = new TessBaseAPI();
baseApi.init("/mnt/sdcard/external_sd/tess/", "spa",TessBaseAPI.OEM_TESSERACT_ONLY);
baseApi.setImage(bitmap);
String recognizedText = baseApi.getUTF8Text();
Log.d("Texto leido", "texto: "+recognizedText);
baseApi.end();
这就是我从文件中获取位图的方法
BitmapFactory.Options options = new BitmapFactory.Options();
options.inPreferredConfig = Bitmap.Config.ARGB_8888;
Bitmap bitmap = BitmapFactory.decodeFile(photopath.getAbsolutePath(), options);
即时通讯在imageview上使用该位图,看起来是正确的,所以我无法找到它的工作原理那么糟糕。
有什么想法吗?
答案 0 :(得分:1)
此处更改图像文字语言的语言代码。
例如:如果您想要英语文本识别,请使用'eng'或西班牙语作为'spa'
1)
TessBaseAPI baseApi = new TessBaseAPI();
baseApi.init("/mnt/sdcard/external_sd/tess/", "eng");
baseApi.setImage(bitmap);
String recognizedText = baseApi.getUTF8Text();
Log.d("Texto leido", "texto: "+recognizedText);
baseApi.end();
2)从 Download here下载语言包文件 你必须下载osd.traineddata.zip文件和tesseract-ocr-3.01.eng.tar.zip(这里是eng for English,spa for Spanish ... etc)文件粘贴到assets文件夹。
3)在设置位图之前转换为灰度图像位图