我是一名从事学校项目的学生,负责创建名片扫描仪,从图像中提取文本,并通过姓名,电话号码等相应的文本框显示。
过去几周我一直在谷歌搜索,并在网上发现了许多很好的例子。目前我正在尝试实现我在网上找到的名为“AndrOCR”的应用程序的源代码。但是,我在代码中遇到了一些错误,我不知道如何在Ecilpse(juno)中解决。
我已经从rmtheis实现了tess-two并且能够运行其他一些OCR源代码。但是,对于“AndrOCR”,我无法解决。
带错误的代码如下所示:
public void onDialogSingleChoice(int dialog_id, int item){
switch(dialog_id){
case SEGMODE_DIALOG:
mSegModeID = item;
// Change the OCR page segmentation mode
switch (mSegModeID){
case 0:
mSegMode = TessBaseAPI.**PSM_AUTO**;
break;
case 1:
mSegMode = TessBaseAPI.**PSM_SINGLE_BLOCK**;
break;
case 2:
mSegMode = TessBaseAPI.**PSM_SINGLE_LINE**;
break;
case 3:
mSegMode = TessBaseAPI.**PSM_SINGLE_WORD**;
break;
case 4:
mSegMode = TessBaseAPI.**PSM_SINGLE_CHAR**;
break;
case 5:
mSegMode = TessBaseAPI.**PSM_SINGLE_BLOCK_VERT_TEXT**;
break;
}
// It's not needed to restart the whole library here
removeDialogFragment("segmode_dialog");
Toast.makeText(mThis, getString(R.string.selected_text_layout) + " " + mSegModeArray[mSegModeID], Toast.LENGTH_SHORT).show();
break;
case LANGUAGE_DIALOG:
mLangID = item;
// Change the OCR language recognition
mLang = mTessLangArray[mLangID];
removeDialogFragment("language_dialog");
setTessData();
break;
}
}
错误发生在粗体文本中,如上所示。第一个错误的错误消息是“PSM_AUTO无法解析或不是字段”,这也适用于其余错误。
源代码可在此链接中找到:https://github.com/TheWall89/AndrOCR
请检查一下,让我知道错误是什么以及如何解决它们,因为我仍然是android开发的初学者,需要很多帮助,非常感谢〜
答案 0 :(得分:1)
将constants移至名为PageSegMode
的内部类。
所以将代码更改为
mSegMode = TessBaseAPI.PageSegMode.PSM_AUTO;
和
mSegMode = TessBaseAPI.PageSegMode.PSM_SINGLE_BLOCK;
等