gpt4 book ai didi

android - Google Mobile Vision API 无法检测纵向模式下的文本

转载 作者:行者123 更新时间:2023-11-29 15:38:13 25 4
gpt4 key购买 nike

我有一个使用 Fotoapparat Library 的 Activity 获取图片并将其保存到文件中。接下来,我使用 Google Mobile Vision API 创建该文件的位图并检测文本。我使用了为此提供的标准代码。

    TextRecognizer ocrFrame = new TextRecognizer.Builder(context).build();
Frame frame = new Frame.Builder().setBitmap(BitmapFactory.decodeFile(pathToPhoto)).build();

SparseArray<TextBlock> sparseTextBlocks = ocrFrame.detect(frame);
if (sparseTextBlocks.size() <= 0)
return null;

ArrayList<TextBlock> textBlocks = new ArrayList<>();
for (int i = 0; i < sparseTextBlocks.size(); i++) {
textBlocks.add(sparseTextBlocks.get(sparseTextBlocks.keyAt(i)));
}

OCR 在横向模式下完美运行,但在纵向模式下它几乎检测不到任何文本。我已经通过显示图像验证图像在纵向模式下没有反转。它给出了一个垂直图像。我真的不明白为什么会这样。有什么线索吗?

最佳答案

这是实现 Mobile Vision API 的另一种选择

// imageBitmap is the Bitmap image you're trying to process for text
if(imageBitmap != null) {

TextRecognizer textRecognizer = new TextRecognizer.Builder(this).build();

if(!textRecognizer.isOperational()) {
// Note: The first time that an app using a Vision API is installed on a
// device, GMS will download a native libraries to the device in order to do detection.
// Usually this completes before the app is run for the first time. But if that
// download has not yet completed, then the above call will not detect any text,
// barcodes, or faces.
// isOperational() can be used to check if the required native libraries are currently
// available. The detectors will automatically become operational once the library
// downloads complete on device.
Log.w(LOG_TAG, "Detector dependencies are not yet available.");

// Check for low storage. If there is low storage, the native library will not be
// downloaded, so detection will not become operational.
IntentFilter lowstorageFilter = new IntentFilter(Intent.ACTION_DEVICE_STORAGE_LOW);
boolean hasLowStorage = registerReceiver(null, lowstorageFilter) != null;

if (hasLowStorage) {
Toast.makeText(this,"Low Storage", Toast.LENGTH_LONG).show();
Log.w(LOG_TAG, "Low Storage");
}
}


Frame imageFrame = new Frame.Builder()
.setBitmap(imageBitmap)
.build();

SparseArray<TextBlock> textBlocks = textRecognizer.detect(imageFrame);

for (int i = 0; i < textBlocks.size(); i++) {
TextBlock textBlock = textBlocks.get(textBlocks.keyAt(i));

Log.i(LOG_TAG, textBlock.getValue());
// Do something with value
}
}

您需要确保在模块的 build.gradle 中包含移动视觉依赖项

dependencies {
compile 'com.google.android.gms:play-services-vision:9.4.0'
}

并将其包含在应用的 Android list 中

<meta-data
android:name="com.google.android.gms.vision.DEPENDENCIES"
android:value="ocr" />

总体而言,您的代码看起来不错,我认为这可能是您的库保存图片方向的方式可能与 Mobile Vision API 冲突,请尝试在副项目或其他库中使用 native android 捕获,如果您的应用程序仍然没有正在努力尝试保存横向静止图像,即使它们是纵向拍摄的,这也可能有帮助

希望对你有帮助

关于android - Google Mobile Vision API 无法检测纵向模式下的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45928536/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com