2

我正在尝试使用Recognizer带有RegerParserSettings片段内部的 a 来扫描从资源中获取的图像。问题是BaseRecognitionResult通过回调获得的onScanningDone总是null。我尝试设置 RecognitionSettingsMRTDRecognizer并且工作正常,所以我认为该库已正确集成。这是我正在使用的源代码:

@Override
public void onAttach(Context context) {
    ...

    try {
        mRecognizer = Recognizer.getSingletonInstance();
        mRecognizer.setLicenseKey(context, LICENSE_KEY);
    } catch (FeatureNotSupportedException | InvalidLicenceKeyException e) {
        Log.d(TAG, e.getMessage());
    }
    buildRecognitionSettings();
    mRecognizer.initialize(context, mRecognitionSettings, new DirectApiErrorListener() {
        @Override
        public void onRecognizerError(Throwable t) {
            //Handle exception

        }
    });
}

private void buildRecognitionSettings() {
        mRecognitionSettings = new RecognitionSettings();
        mRecognitionSettings.setRecognizerSettingsArray(setupSettingsArray());
}

private RecognizerSettings[] setupSettingsArray() {
        RegexParserSettings regexParserSettings = new RegexParserSettings("[A-Z0-9]{17}");
        BlinkOCRRecognizerSettings sett = new BlinkOCRRecognizerSettings();
        sett.addParser("myRegexParser", regexParserSettings);
        return new RecognizerSettings[] { sett };
}

我像这样扫描图像:

mRecognizer.recognizeBitmap(bitmap, Orientation.ORIENTATION_PORTRAIT, FragMicoblink.this);

这是片段中处理的回调

@Override
public void onScanningDone(RecognitionResults results) {
    BaseRecognitionResult[] dataArray = results.getRecognitionResults();

    //dataArray is null

    for(BaseRecognitionResult baseResult : dataArray) {
        if (baseResult instanceof BlinkOCRRecognitionResult) {
            BlinkOCRRecognitionResult result = (BlinkOCRRecognitionResult) baseResult;
            if (result.isValid() && !result.isEmpty()) {
                String parsedAmount = result.getParsedResult("myRegexParser");
                if (parsedAmount != null && !parsedAmount.isEmpty()) {
                    Log.d(TAG, "Result: " + parsedAmount);
                }
            }
        }
    }
}`

提前致谢!

4

1 回答 1

2

你好螺旋桨。

SegmentScanActivity您的代码与您的代码使用的区别在于DirectAPI,它只能处理您发送进行处理的单个位图图像,而SegmentScanActivity在它们从相机到达时处理相机帧。这样做的同时,它可以利用时间冗余信息来提高 OCR 质量,即结合多个视频帧的连续 OCR 结果来获得质量更好的 OCR 结果。

此功能无法通过DirectAPI- 您需要使用任何一种,或通过我们的相机管理SegmentScanActivity自定义扫描活动。

您还可以在此处了解更多信息: https ://github.com/BlinkID/blinkid-android/issues/54

问候

于 2017-08-30T08:42:34.343 回答