Skaner dokumentów z ML Kit na Androidzie

Użyj interfejsu ML Kit Document Scanner API, aby łatwo dodać funkcję skanera do aplikacji.

Funkcja Szczegóły
Nazwa pakietu SDK play-services-mlkit-document-scanner
Implementacja Usługi Google Play dynamicznie pobierają modele, logikę skanowania i przepływ interfejsu użytkownika.
Wpływ rozmiaru aplikacji Zwiększenie rozmiaru pobieranego pliku o około 300 KB.
Czas inicjowania Użytkownicy mogą czekać na pobranie modeli, elementów logicznych i interfejsu użytkownika przed pierwszym użyciem.

Wypróbuj

Wypróbuj przykładową aplikację, aby zobaczyć przykład użycia tego interfejsu API.

Zanim zaczniesz

  1. W pliku build.gradle na poziomie projektu dodaj repozytorium Maven Google zarówno w sekcji buildscript, jak i w sekcji allprojects.

  2. Dodaj zależność z biblioteką skanera dokumentów ML Kit do pliku Gradle na poziomie aplikacji modułu, którym jest zwykle app/build.gradle:

dependencies {
   // …
   implementation 'com.google.android.gms:play-services-mlkit-document-scanner:16.0.0-beta1'
}

Konfiguracja skanera dokumentów

Sposób korzystania ze skanera dokumentów (który obejmuje specjalny ekran wizjera i ekran podglądu) jest udostępniany przez pakiet SDK. Wizjer i ekran podglądu obsługują te elementy sterujące, które można dostosować:

  • importuję z galerii zdjęć
  • ustawianie limitu liczby skanowanych stron;
  • tryb skanera (do sterowania zestawami funkcji podczas procesu)

Zeskanowane dokumenty możesz pobrać zarówno w formacie PDF, jak i JPEG.

Utwórz instancję GmsDocumentScannerOptions, aby skonfigurować opcje skanera:

Kotlin

val options = GmsDocumentScannerOptions.Builder()
    .setGalleryImportAllowed(false)
    .setPageLimit(2)
    .setResultFormats(RESULT_FORMAT_JPEG, RESULT_FORMAT_PDF)
    .setScannerMode(SCANNER_MODE_FULL)
    .build()

Java

GmsDocumentScannerOptions options = new GmsDocumentScannerOptions.Builder()
    .setGalleryImportAllowed(false)
    .setPageLimit(2)
    .setResultFormats(RESULT_FORMAT_JPEG, RESULT_FORMAT_PDF)
    .setScannerMode(SCANNER_MODE_FULL)
    .build();

Skanowanie dokumentów

Po utworzeniu instancji GmsDocumentScannerOptions pobierz instancję GmsDocumentScanner. Następnie możesz rozpocząć aktywność skanera zgodnie z interfejsami Activity Result API wprowadzonymi w AndroidX.

Gdy skanowanie dokumentów zostanie zakończone, obiekt GmsDocumentScanningResult przyzna dostęp do liczby przeskanowanych stron oraz identyfikatorów URI obrazów w formacie JPEG i PDF zgodnie z definicją za pomocą setResultFormats:

Kotlin

val scanner = GmsDocumentScanning.getClient(options)
val scannerLauncher = registerForActivityResult(StartIntentSenderForResult()) {
  result -> {
    if (result.resultCode == RESULT_OK) {
      val result =
        GmsDocumentScanningResult.fromActivityResultIntent(result.data)
      result.getPages()?.let { pages ->
        for (page in pages) {
          val imageUri = pages.get(0).getImageUri()
        }
      }
      result.getPdf()?.let { pdf ->
        val pdfUri = pdf.getUri()
        val pageCount = pdf.getPageCount()
      }
    }
  }
}

scanner.getStartScanIntent(activity)
  .addOnSuccessListener { intentSender ->
     scannerLauncher.launch(IntentSenderRequest.Builder(intentSender).build())
   }
  .addOnFailureListener {
    ...
  }

Java

GmsDocumentScanner scanner = GmsDocumentScanning.getClient(options);
ActivityResultLauncher<IntentSenderRequest> scannerLauncher =
  registerForActivityResult(
    new StartIntentSenderForResult(),
      result -> {
        if (result.getResultCode() == RESULT_OK) {
          GmsDocumentScanningResult result = GmsDocumentScanningResult.fromActivityResultIntent(result.getData());
          for (Page page : result.getPages()) {
            Uri imageUri = pages.get(0).getImageUri();
          }

          Pdf pdf = result.getPdf();
          Uri pdfUri = pdf.getUri();
          int pageCount = pdf.getPageCount();
        }
      });

scanner.getStartScanIntent(activity)
  .addOnSuccessListener(intentSender ->
    scannerLauncher.launch(new IntentSenderRequest.Builder(intentSender).build()))
  .addOnFailureListener(...);

Wskazówki dotyczące poprawy skuteczności

Pamiętaj, że generowanie plików dokumentów jest czasochłonne i wymaga mocy obliczeniowej, więc wysyłaj żądania tylko w formatach wyjściowych (JPEG, PDF bądź w obu tych formatach), których rzeczywiście potrzebujesz.