In this guide, you will learn how to get started with the Genius Scan SDK for Android.
The Genius Scan SDK for Android is composed of multiple Android libraries, which enables you to integrate just what you need.
We provide two demo projects in the SDK Demo apps repository:
gssdk-scanflow
. The different screens are customizable via a ScanConfiguration
.gssdk-core
module. It also shows how to run OCR before generating a PDF file.In order to run the provided demos, open the root folder in Android Studio.
The Android SDK includes support for the following CPU architectures: x86, x86_64, armeabi-v7a, arm64-v8a. When integrated into your app, the SDK will increase the size of your APK by the sizes in the following table:
Module | x86 | x86_64 | armeabi-v7a | arm64-v8a | universal |
---|---|---|---|---|---|
gssdk-core | 11.7MB | 12.4MB | 10.2MB | 10.5MB | 25.4MB |
gssdk-ocr | 1.4MB | 1.4MB | 1.2MB | 1.3MB | 5.3MB |
gssdk-scanflow | - | - | - | - | <1MB |
If you’d like to optimize the size of your app, you can either:
Native debug symbols are included as part of the SDK. These symbols are generally stripped in the release builds of your app. This isn’t the case for debug builds, for which you may see a larger size increase than the one mentioned above.
Add the following code to your app’s build.gradle
:
repositories {
// ...
maven { url 'https://s3.amazonaws.com/tgl.maven' }
}
dependencies {
// ...
implementation 'com.geniusscansdk:gssdk-core:4.14.0'
// Optionally:
implementation 'com.geniusscansdk:gssdk-ocr:4.14.0'
implementation 'com.geniusscansdk:gssdk-scanflow:4.14.0'
}
The Genius Scan SDK is subject to a commercial license: a license key is needed to initialize the SDK. The key must match your application identifier (aka. bundle ID) and the license’s expiration date. Please contact us if you don’t have a license key yet.
The SDK can run without a license key but will stop working after 60 seconds.
You initialize the SDK with your license key as follows. The best place to initialize the SDK is in the main Activity of your application:
GeniusScanSDK.setLicenseKey(context, "Your license key")
By default, the SDK will use the license key set in code to refresh your license, ensuring your users always benefit from the SDK features. For additional reliability, we still recommend to update the license key in the code when your license is renewed.
You can turn off auto-refreshing by using the autoRefresh
parameter.
GeniusScanSDK.setLicenseKey(context, "Your license key", autoRefresh = false)
When your license key renews, you will need to update the key in code and your users will need to install the update to keep accessing the SDK features.
Once you have done this, you’re ready to start your actual implementation. The next steps will depend whether you chose the simple integration, using the ScanFlow module, or if you are going for a custom integration.
© 2025 The Grizzly Labs. All rights reserved.