既知の問題

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.0 または com.google.mlkit:language-id:17.0.1 でのクラッシュを回避するには、次のルールを含めます。
    -keep class com.google.mlkit.nl.languageid.internal.ThickLanguageIdentifier { *; }
  • Bitmap で構築された InputImage の rotationDegrees が 0 以外の場合、com.google.mlkit:face-detection:16.0.5com.google.android.gms:play-services-mlkit-barcode-scanning:16.1.4 が原因で FaceDetection API の MlKitException「無効な回転」が発生します。以前のバージョンを使用し、この問題の修正を含む次回のリリースをお待ちください。
  • com.google.mlkit:barcode-scanning:16.1.0 および com.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 の画像形式の変換に時間がかかるため、CameraX と Camera2 のパフォーマンスは Camera1 と同等ではありません。

  • Task コールバックは、登録された Activity または Fragment が破棄された後に実行される可能性があります。コールバックがその間に閉じられた検出機能にアクセスしようとすると、例外が発生する可能性があります。アクティビティで ML Kit を使用している場合は、アクティビティの範囲のリスナーを登録できます。このリスナーは、アクティビティが停止すると自動的に削除されます。フラグメントなどの環境で ML Kit を使用している場合は、フラグメントが破棄されたときに実行をシャットダウンするカスタム エグゼキュータを指定できます。例については、Vision クイックスタートScopedExecutor.Java をご覧ください。

  • ビットマップ以外の画像形式で画像ラベリングを行う場合、バンドル バリアントは Google Play 開発者サービスに依存する「シン」バリアントよりもパフォーマンスが優れています。

  • Digital Ink com.google.mlkit:digital-ink-recognition:17.0.0 以前と Entity Extraction 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 シミュレータは、Translation 'GoogleMLKit/Translate', '4.0.0' 以降と Smart Reply 'GoogleMLKit/SmartReply', '4.0.0' 以降ではサポートされていません。