Integrating our OCR SDK into iOS
This guide explains the process of integrating the OCR framework of Nutrient iOS SDK into your project.
Requirements
-
Nutrient iOS SDK with Nutrient OCR
PSPDFKit and PSPDFKitOCR are two separate dynamic frameworks available in the same download. Download the latest release from my.nutrient.io, or for evaluation purposes, check out our free trial and download the latest release, or use Swift Package Manager (see the integration section below).
-
The latest stable version of Xcode
Nutrient and Nutrient OCR require the latest stable version of Xcode available at the time the release was made.
Quick start with the Catalog example
You can find runnable sample code in OCRExample.swift
. It showcases how Nutrient OCR works in our Nutrient Catalog sample project:
-
Open
Catalog.xcodeproj
. -
Build and run the
Catalog
scheme. -
Search for OCR in the examples list and open the example.
Integrating the Nutrient OCR framework
There are three ways to integrate the Nutrient OCR framework: with Swift Package Manager, with CocoaPods, and manually. They’re outlined below.
Swift Package Manager
If you’re already using Swift Package Manager, you can add PSPDFKitOCR to your project like so:
-
Integrate the PSPDFKitOCR Swift package using the public repository URL.
https://github.com/PSPDFKit/PSPDFKitOCR-SP
-
Manually add the language files you need to your target.
CocoaPods
If you’re already using CocoaPods, you can add PSPDFKit and PSPDFKitOCR to your project by adding the following to your Podfile
:
use_frameworks! target :YourTargetName do pod 'PSPDFKit', podspec: 'https://my.pspdfkit.com/pspdfkit-ios/latest.podspec' pod 'PSPDFKitOCR', podspec: 'https://my.pspdfkit.com/ocr/latest.podspec' end
Then run pod install
.
PSPDFKitOCR ships with individual language bundles that can all be separately integrated in your app. This is so you only use the ones you actually need, which avoids unnecessarily bloating your app’s size.
ℹ️ Note: The example above will download and include in your app all the trained data models for every language we support. If you’re looking to only implement OCR for a subset of the supported languages, you’ll need to modify your
Podfile
like shown below:
use_frameworks! target :YourTargetName do pod 'PSPDFKit', podspec: 'https://my.nutrient.io/pspdfkit-ios/latest.podspec' pod 'PSPDFKitOCR/PSPDFKitOCR', podspec: 'https://my.nutrient.io/ocr/latest.podspec' pod 'PSPDFKitOCR/English', podspec: 'https://my.nutrient.io/ocr/latest.podspec' pod 'PSPDFKitOCR/German', podspec: 'https://my.nutrient.io/ocr/latest.podspec' end
Manually
To integrate manually:
-
Drag
PSPDFKitOCR.xcframework
into the Frameworks, Libraries, and Embedded Content section of your target. -
Manually add the language files located in
PSPDFKitOCR/Languages
to your target.