Android에서 ML Kit를 사용한 문서 스캐너

ML Kit Document Scanner API를 사용하여 앱에 문서 스캐너 기능을 쉽게 추가하세요.

기능 세부정보
SDK 이름 play-services-mlkit-document-scanner
구현 모델, 스캔 로직, UI 흐름은 Google Play 서비스에서 동적으로 다운로드합니다.
앱 크기 영향 다운로드 크기가 최대 300KB 증가합니다.
초기화 시간 사용자는 처음 사용하기 전에 모델, 로직, UI 흐름이 다운로드될 때까지 기다려야 할 수 있습니다.

사용해 보기

샘플 앱을 사용해 이 API의 사용 예를 살펴보세요.

시작하기 전에

  1. 프로젝트 수준 build.gradle 파일의 buildscript 및 allprojects 섹션에 Google의 Maven 저장소가 포함되어야 합니다.

  2. 모듈의 앱 수준 Gradle 파일(일반적으로 app/build.gradle)에 ML Kit 문서 스캐너 라이브러리의 종속 항목을 추가합니다.

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

문서 스캐너 구성

전용 뷰파인더 화면과 미리보기 화면을 포함하는 문서 스캐너 사용자 흐름은 SDK에서 제공합니다. 뷰파인더 및 미리보기 화면은 다음과 같은 맞춤설정 가능한 컨트롤을 지원합니다.

  • 사진 갤러리에서 가져오기
  • 스캔할 페이지 수 제한 설정
  • 스캐너 모드 (흐름에서 기능 집합을 제어하기 위한 모드)

스캔한 문서의 PDF 파일과 JPEG 파일을 모두 검색할 수 있습니다.

GmsDocumentScannerOptions를 인스턴스화하여 스캐너 옵션을 구성합니다.

Kotlin

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

자바

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

문서 스캔

GmsDocumentScannerOptions를 만든 후 GmsDocumentScanner의 인스턴스를 가져옵니다. 그런 다음 AndroidX에서 도입된 Activity Result API에 따라 스캐너 활동을 시작할 수 있습니다.

문서 스캔이 완료되면 GmsDocumentScanningResult 객체는 setResultFormats를 통해 정의된 대로 스캔된 페이지 수, JPEG 형식의 이미지 URI, PDF에 액세스할 수 있습니다.

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 {
    ...
  }

자바

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(...);

성능 개선을 위한 팁

문서 파일을 생성하는 데 시간이 걸리고 처리 능력이 필요하므로 실제로 필요한 출력 형식 (JPEG, PDF 또는 둘 다)만 요청하세요.