Skip to content
This repository has been archived by the owner on Aug 2, 2024. It is now read-only.

Contains projects to help you use the Android and iOS Gini Vision Libraries with Xamarin.

Notifications You must be signed in to change notification settings

gini/gini-vision-lib-xamarin

Repository files navigation

Gini Vision Library Xamarin Examples and Bindings

This repository contains projects to help you use the Android and iOS Gini Vision Libraries with Xamarin.

Example Projects

The GVLXamarinFormsExample project shows how to use our bindings libraries in a Xamarin.Forms project.

Android

To use the Android Gini Vision Library you need to add the DLLs created by the GVLXamarinAndroid and GVLNetworkingXamarinAndroid bindings libraries to your Xamarin project.

For using the Gini Vision Library please refer ot our documentation and the screenapiexample or componentapiexample projects in our repository. We also have a standalone example app here.

Bindings Libraries

The Gini Vision Library for Android consists of the main library and a default networking layer implementation. The main library is bound with the GVLXamarinAndroid bindings library and the networking layer implementation with the GVLNetworkingXamarinAndroid bindings library.

The networking bindings library requires additional bindings which are provided by GiniAPISDKXamarinAndroid and TrustKitXamarin.

Customization

Customization of the Views is provided via overriding of app resources: dimensions, strings, colors, texts, etc. Take a look at the Customization Guide to see which resources can be overridden.

The example overrides the gv_qrcode_detected_popup_message_1 and gv_qrcode_detected_popup_message_2 string resources for both the default localization (German) and the English one. You can override other resources like this.

Onboarding Pages

You can change the onboarding pages in two ways:

  1. By creating your own instances of OnboardingPage and pass them in a list to GiniVision.NewInstance().SetCustomOnboardingPages(onboardingPages).
  2. By using the DefaultPagesPhone.AsArrayList() to get the list of default onboarding pages and then altering the order of the pages or remove/add pages. If you also support tablets, then you can use DefaultPagesTablet.AsArrayList(). Pass the modified list to GiniVision.NewInstance().SetCustomOnboardingPages(onboardingPages).

Building

Because modules depend on each other they need to be build in the right order:

  1. TrustKitXamarin
  2. GiniApiSDKXamarinAndroid
  3. GVLXamarinAndroid
  4. GVLNetworkingXamarinAndroid

Only after that the example app can be run.

Troubleshooting

  • "No resource found that matches the given name" errors: set the AndroidUseAapt2 flag to false in your csproj configuration.
  • When building GVLXamarinAndroid you encounter an error related to OnProceedToAnalysisScreenHandler: just delete the line the error points to in order to fix the duplicate definition.
  • If you enable QR Code scanning and get Failed resolution of: Lcom/google/android/gms/vision/barcode/BarcodeDetector$Builder; or similar, then add the following NuGet packages to your Android platform project: Xamarin.GooglePlayServices.Base, Xamarin.GooglePlayServices.Basement and Xamarin.GooglePlayServices.Vision.

iOS

GVL for iOS is provided as a DLL file called GiniVision.iOS.dll located in GVLXamarinFormsExample/GVLXamarinFormsExample.iOS. It needs to be added to your project as a reference.

The API for the iOS integration is provided through a proxy library (GVLProxy) and it's a limited version of what's available natively. Please contact Gini if you need to access any functionality that isn't exposed. Only the Screen API is supported at this point.

Example app

In order to run the example app on iOS, first supply your domain, id, and secret in the GiniVisionLib class. Then you can run the app and test the extraction. The extractions are written to the console.

The example app is meant to provide a sample code to show how the Gini Vision Library can be used. Please see the GiniVisionLib.cs in the GVLXamarinFromaExample.iOS project to get you started.

Prerequisits

In order to use the Gini Vision Library please ensure your project supplies the following:

  • Keychan capability should be enabled in Entitlements.plist
  • Camera Usage Description provided in the Info.plist
  • Photo Library Usage Description provided in the Info.plist (if you want to enable loading photographs from the user's Photo app)

The app will crash at various points of execution if the above are not provided.

Usage

Instantiate the GVLProxy and present the view controller accessible from the ViewController property:

GVLProxy gvlProxy = new GVLProxy(domain, id, secret, gvlConfiguration, gvlDelegate);
UIKit.UIViewController gvlViewController = gvlProxy.ViewController;

The GVLProxy initialiser takes your credentials (domain, id, and secret), a GVLConfigurationProxy instance, and a IGVLProxyDelegate instance.

The GVLConfigurationProxy allows you to configure different aspects of GVL such as whether you want to display a flash toggle button, or what tint should the navigation bar have. Please refer to the example app to see the currently available options and to the native documentation for explanation of the options.

Implement the IGVLProxyDelegate protocol in order to receive callbacks from GVL with extraction results or to be informed about lack of thereof.

Customization

Components can be customized either through the GiniConfiguration, the Localizable.strings file or through the assets. Take a look at the Customization Guide to see which resources can be customized.

Strings

String customization is possible by adding GVL's localized string keys with you own values to your Localizable.strings files.

The example adds ginivision.navigationbar.camera.title, ginivision.camera.qrCodeDetectedPopup.message and ginivision.camera.qrCodeDetectedPopup.buttonTitle localized string keys and own values to both the German and the English Localizable.strings file.

Buttons

Some buttons in the GVL UI can be customized by setting their title or image. To do that, set a property on yout GVLConfigurationProxy instance to a SimplePreferredButtonResource. The initaliser of SimplePreferredButtonResource takes two agruments: preferredImage and preferredText. If you want the button to have an icon, pass a UIKit.UIImage instance as the preferredImage and null as the preferredText. Pass your desired button title as preferredText if you want the button to have a text title.

For instance in order to set the close button to have a text title instead of the default cross icon:

GiniConfigurationProxy gvlConfiguration = new GiniConfigurationProxy();
...
gvlConfiguration.CloseButtonResource = new SimplePreferredButtonResource(null, "Close please");

Navigation Bar

To configure the look of the navigation bars in GVL you should use the GiniConfiguration instead of UIAppearance. This allows GVL to prevent issues with the navigation bar colors in the UIDocumentPickerViewController.

If you use UIAppearance you should reset navigation bar related customizations before launching GVL and restore them after GVL has exited.

You can customize the following navigation bar and item properties:

GiniConfigurationProxy gvlConfiguration = new GiniConfigurationProxy
{
    NavigationBarItemTintColor = UIColor...,
    NavigationBarTintColor = UIColor...,
    NavigationBarTitleColor = UIColor...,
    NavigationBarItemFont = UIFont...,
    NavigationBarTitleFont = UIFont...,
    DocumentPickerNavigationBarTintColor = UIColor...,
};

Onboarding Pages

You can change the onboarding pages in two ways:

  1. By adding your array of custom UIViews to gvlConfiguration.OnboardingPages.
  2. By retrieving the default pages from gvlConfiguration.OnboardingPages then altering the order of the pages or remove/add pages. Pass the modified array to gvlConfiguration.OnboardingPages.

The buttons currently available for customization are:

Asset name in native documentation GiniConfigurationProxy property
navigationCameraClose CloseButtonResource
navigationCameraHelp HelpButtonResource
navigationReviewBack BackToCameraButtonResource
navigationReviewBack BackToMenuButtonResource
navigationReviewContinue NextButtonResource
navigationAnalysisBack CancelButtonResource

Troubleshooting

  • The app crashes at various points without an informative error message: please make sure that you have enabled all capabilities and provided all usage strings in your Info.plist file.
  • Document picker navigation bar buttons are not visible: please apply navigation bar customizations using the GiniConfiguration and reset your UIAppearance customizations related to navigation bars before launching GVL. After GVL has finished you can restore your UIAppearance customizations.

About

Contains projects to help you use the Android and iOS Gini Vision Libraries with Xamarin.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published