已知问题

Android 问题

  • 对于捆绑式语言 ID,应用在升级到 AGP 7.0.0 或更高版本时可能会崩溃。 为避免 com.google.mlkit:language-id:16.1.1 或更早版本中出现崩溃,请添加以下规则:
    -keep class com.google.mlkit.nl.languageid.internal.LanguageIdentificationJni { *; }
    为避免 com.google.mlkit:language-id:17.0.0com.google.mlkit:language-id:17.0.1 中出现崩溃,请添加以下规则:
    -keep class com.google.mlkit.nl.languageid.internal.ThickLanguageIdentifier { *; }
  • 如果通过具有非零 rotationDegrees 的 Bitmap 构建 InputImage,则 FaceDetection API 会因 com.google.mlkit:face-detection:16.0.5com.google.android.gms:play-services-mlkit-barcode-scanning:16.1.4 而出现“旋转无效”MlKitException。请使用较早的版本,并等待我们发布包含此问题修复的下一个版本。
  • 早于 com.google.mlkit:barcode-scanning:16.1.0com.google.android.gms:play-services-mlkit-barcode-scanning:16.1.3 的 BarcodeScanning SDK 无法在运行 camera-camera2:1.0.0-beta08 版本或更高版本的某些设备上使用。您可以使用旧版 camera-camera2 来绕过此问题。例如:

    implementation "androidx.camera:camera-core:1.0.0-beta07"
    implementation "androidx.camera:camera-camera2:1.0.0-beta07"
    implementation "androidx.camera:camera-view:1.0.0-alpha14"
    implementation "androidx.camera:camera-extensions:1.0.0-alpha14"
    implementation "androidx.camera:camera-lifecycle:1.0.0-beta07"

  • com.google.mlkit:language-id:16.1.1 及更早版本中,原生方法可能会被自定义规则混淆。 如果您遇到类似 java.lang.UnsatisfiedLinkError 的错误,请添加以下规则以保留这些文件:

    -keepclasseswithmembernames class com.google.mlkit.nl.languageid.internal.LanguageIdentificationJni {
      native <methods>;
    }

  • 对于文字识别、图片标记以及对象检测和跟踪 API,CameraX 和 Camera2 的性能仍无法与 Camera1 相媲美,因为它们需要更多时间来转换 CameraX 和 Camera2 的图片格式。

  • 任务回调可能会在注册它们的 Activity 或 Fragment 被销毁后执行。如果回调尝试访问在此期间已关闭的检测器,则可能会导致异常。如果您在 Activity 中使用 ML Kit,可以注册一个 Activity 作用域的监听器,该监听器会在 Activity 停止时自动移除。如果您在 fragment 或其他环境中使用 ML Kit,可以提供自定义执行器,以便在 fragment 被销毁时关闭执行。如需查看示例,请参阅 Vision 快速入门中的 ScopedExecutor.Java

  • 对于使用除 Bitmap 以外的图片格式的图片标记,捆绑变体的性能优于依赖于 Google Play 服务的“精简”变体。

  • 对于 Digital Ink com.google.mlkit:digital-ink-recognition:17.0.0 或更低版本以及实体提取 com.google.mlkit:entity-extraction:16.0.0-beta2 或更低版本,如果您将 targetSdkVersion 设置为 31 并在 Android S 上运行,则会收到以下运行时异常。

    Targeting S+ (version 31 and above) requires that one of FLAG_IMMUTABLE or FLAG_MUTABLE be specified when creating a PendingIntent.
    AndroidRuntime: Strongly consider using FLAG_IMMUTABLE, only use FLAG_MUTABLE if some functionality depends on the PendingIntent being mutable, e.g. if it needs to be used with inline replies or bubbles.
    
    此问题已在我们的最新版本中得到修复。

    如果您偏好使用旧版本,可以将 targetSdkVersion 设置为小于 31,也可以将以下内容添加到 build.gradle 中作为解决方法。

    // For apps targeting Android S+, add the following
    constraints {
      implementation 'androidx.work:work-runtime:2.7.0-alpha04'
    }

iOS 问题

  • 不支持基于 M1 的 Mac 上的模拟器。
  • X86_64 模拟器不支持翻译功能('GoogleMLKit/Translate', '4.0.0' 或更高版本)和智能回复功能('GoogleMLKit/SmartReply', '4.0.0' 或更高版本)。