Selfie Capture
In this section, you will find all the necessary information for using and integrating the Unico IDCloud platform SDK into your Android applications for selfie capture
This guide has been designed to help you implement the Android SDK quickly and easily. Below, you'll find a step-by-step process for the entire integration. Afterward, if you wish to customize the experience, be sure to check out the Android Customization section.
Initializing the SDK
Create an instance of the builder (generated through the IAcessoBioBuilder
interface), providing the context and environment as parameters, along with the implementation of the AcessoBioListener
class.
The implementation of this class is quite simple and can be done in just a few lines of code. All you need to do is instantiate the builder by providing the relevant context and override the callback methods with the business logic of your application:
Environment configuration
Configure the environment that will be used during the SDK execution. Use the Environment
enum, which contains the following options:
Environment.PROD
: for production environment;Environment.UAT
: for approval environment.
See how to implement it in the example below:
Implementing Callback Functions
Note that the work of implementing the AcessoBioListener
class is, for the most part, configuring the callback methods. Each method is called in a specific situation based on the SDK's return.
Simply override the methods shown in the previous step with your application's business logic.
This method is invoked whenever any implementation error occurs while using one of our methods:
onErrorAcessoBio(ErrorBio errorBio)
When invoked, the method receives a parameter of type ErrorBio that contains details about the error. Learn more about the ErrorBio
type in the error handling section.
onUserClosedCameraManually()
This method is invoked whenever the user manually closes the camera, such as when clicking the "Back" button.
onSystemClosedCameraTimeoutSession()
This method is invoked as soon as the maximum session time is reached (without capturing any image).
It can be configured in the builder through the setTimeoutSession method. This method should receive the maximum session time in seconds. You can change the maximum session time for your user when using the face detection feature (Selfie camera with smart capture). If the user exceeds the time set for capturing the photo, you can display a customizable message or instruction to the user. The default value is 40 seconds, and the minimum value is also 40 seconds.
onSystemChangedTypeCameraTimeoutFaceInference()
This method is invoked as soon as the maximum time for face detection is reached (without detecting anything). In this case, the camera mode is automatically switched to manual capture mode (without the smart capture outline).
The maximum capture time when using face detection (Selfie camera with smart capture) is 13 seconds. If the user encounters difficulty capturing the photo through face detection and exceeds the time set in the process, the capture is automatically switched to manual mode, aiming to make the action easier for the user (TimeoutToFaceInference).
All of the above methods must be created as indicated in your project (even if without any logic). Otherwise, the project will not compile successfully.
Configuring Camera Mode
The SDK has smart framing and automatic capture configured and enabled by default. As a result, you must configure the camera mode in your builder as follows:
The false/true values of the methods above do not alter the capture experience; they are only used for the internal logic of the SDK's operation.
Implementing Listeners for Camera Events
The camera opening method, which is called in the next step, needs to know what to do when it successfully captures an image or when an error occurs in the process. It is necessary to inform "what to do" to the camera opening method by implementing listeners that are called in cases of success or error.
Through the configuration of the listeners, you can specify what happens in your app in error situations (onErrorSelfie
method) or success situations (onSuccessSelfie
method) during image capture.
Changes in naming conventions for versions lower than 4.2.1:
The method
prepareCamera
, which was previouslyprepareSelfieCamera
.The class
CameraListener
, which was previouslySelfieCameraListener
.The object
UnicoCheckCameraOpener.Camera
, which was previouslyUnicoCheckCameraOpener.Selfie
.
To configure the listeners, it is necessary to implement:
Prepare and open the camera
To proceed with opening the camera, it is first necessary to prepare it using the prepareCamera method. This method receives as parameters the implementation of the CameraListener
class, the class, or the JSON with the credentials generated in this step.
When the camera is prepared, the onCameraReady
event is triggered, which receives an object of type UnicoCheckCameraOpener.Camera
as a parameter.
It is necessary to override this method, opening the camera with the object received through the open()
method. The open()
method should receive as parameters the listeners configured in the previous steps.
onSucessSelfie
Method
onSucessSelfie
MethodWhen an image capture is successful, this method is invoked and returns an object of type ResultCamera
, which is used later in the REST API calls:
The ResultCamera
object returns two attributes: base64
and encrypted
:
The
base64
attribute can be used if you want to display a preview of the image in your app.The
encrypted
attribute must be sent in the REST API calls to by Client.
The
encrypted
attribute is strictly intended for sending the image through the by Client APIs. It should not be opened or serialized, as its characteristics may change without notice. Its use must be exclusive to interactions with the APIs to ensure data integrity and security. Unico is not responsible for any damages resulting from this practice, as modifications can occur unexpectedly.The
base64/encrypted
files may vary in size due to several factors, including the quality of the devices and the photos generated by them, as well as Unico's business rules. To avoid issues in your application, do not limit the size of the string generated by the SDK for the files in your programming logic or infrastructure.
onErrorSelfie
Method
onErrorSelfie
MethodWhen an error occurs during image capture, this method is invoked and returns an object of type ErrorBio
:
If it's necessary to convert base64 to bitmap, the standard method doesn't work for Android. It is necessary to perform a split at the comma (,
) for it to work. If you'd like to learn more, read the article: How to convert a Base64 string into a Bitmap image to show it in an ImageView?
Making a POST Request to the Client API
Image capture is just the first part of the journey. After capturing the image, it is necessary to send the encrypted
generated by the SDK to the by Client REST APIs. Learn more in the CreateProcess section of by Client.
For security reasons, the interval between the generation of the encrypted
and its submission via one of the available flows must be a maximum of 10 minutes. Submissions made beyond this period will be automatically rejected by the API.
Still need help?
Didn't find something or still need help? If you're already a client or partner, you can reach out through our Help Center.
Atualizado
Isto foi útil?