Android

BCC Face es una biblioteca de Android que debe integrarse en una aplicación Android.

Utiliza la cámara del dispositivo para tomar una foto de un rostro con fines biométricos. Proporciona una prueba de vitalidad activa simple, que requiere que la persona sonría durante aproximadamente un segundo y/o mire hacia la derecha o la izquierda. La prueba de vitalidad incluye una opción para pronunciar las instrucciones, facilitando el flujo de trabajo para los usuarios. Además, proporciona una prueba de vitalidad pasiva que puede utilizarse para comprobar si la foto fue tomada de una persona real sin requerir interacción del usuario.

Este manual está actualizado a la versión de BCC Face Mobile Android 4.8.0.

Requisitos

BCC Face es una biblioteca de Android y debe importarse en el proyecto target.

  • Versión mínima de Android: Android 6.0 (SDK 23), "Marshmallow".

  • El dispositivo móvil debe tener una cámara.

  • La aplicación nativa debe construirse con tecnología Android.

  • Entorno de desarrollo: se requiere un IDE de Android, como Android Studio (recomendado).

  • Dependencias externas adicionales:

  • Servicios externos:

    • Firebase, de Google. Se requiere una cuenta, pero no se aplicarán cargos ya que la biblioteca utiliza solo APIs en el dispositivo.

Instalación

Agregar la Biblioteca en el Proyecto de la App

BCC Face es proporcionado por Griaule como un .aar archivo.

Para agregar las bibliotecas, vaya al directorio de su proyecto, abra la app carpeta y cree los directorios: libs/bccface. Luego, agregue la bccfacelib-release.aar dependencia. La estructura de carpetas debe ser similar a esta:

El siguiente paso es hacer que estos archivos sean visibles para las dependencias de gradle. Para ello, agregue la siguiente línea en el archivo build.gradle (:app), en el objeto dependencies:

Dentro del build.gradle (:app) archivo, también agregue las opciones de compilación y establezca Source Compatibility y Target Compatibility para usar 1.8 (Java 8):

Configurando Google ML Kit

Se recomienda seguir las instrucciones proporcionadas en "Opción 1: Use el flujo de configuración de la consola de Firebase" de la documentación de Firebase para Android: Agregar Firebase a su proyecto Android.

Se requiere una cuenta, pero no se aplicarán cargos ya que la biblioteca utiliza solo APIs en el dispositivo: Ver detalles de precios de Firebase.

Si Opción 1 fue elegida, asegúrese de generar el google-services.json archivo y colocarlo en android/app/ directorio.

Realice cambios en los siguientes archivos:

  • android/build.gradle

  • android/app/build.gradle, agregue al final del archivo:

Configurando todas las dependencias

Realice cambios en los siguientes archivos:

  • android/build.gradle

  • android/app/build.gradle

Uso

Parámetros y Constructor

Para usar correctamente la biblioteca BCC Face, se requieren algunos parámetros.

A continuación se muestra un ejemplo simple de uso de la biblioteca:


El BCCFaceBuilder el constructor de la clase recibe los siguientes parámetros:

  • context: Context - El contexto de la aplicación.

  • delegate: BCCFaceDelegate - Interfaz responsable de notificar eventos de captura (p. ej., fallo o éxito).


El BCCFaceBuilder la clase es responsable de manejar la configuración de uso para BCCFace. Los siguientes parámetros son aceptados para configurar la captura biométrica y el comportamiento del software:

  • buildSmileCheck(smileProbability: Float = 0.8f) - Agrega la sonrisa para la prueba de vitalidad y define el umbral de aceptación. Esta característica está habilitada por defecto.

  • removeSmileCheck() - Elimina la comprobación de sonrisa para la prueba de vitalidad.

  • buildRotationCheck(livenessConfigList: List<HeadRotationCheck>, headRotationAngle: Float = 20f) - Define una lista de pruebas de vitalidad para la rotación de la cabeza y el ángulo máximo de rotación. Esta característica está habilitada por defecto. Las opciones de rotación de cabeza son:

  • removeHeadRotation() - Elimina la rotación de cabeza para la prueba de vitalidad.

  • addPassiveLiveness() - Agrega la prueba de vitalidad pasiva. Esta función se usa para comprobar si la foto capturada es de una persona real sin requerir ninguna interacción del usuario. Para usar esta función, DEBE deshabilitar las comprobaciones de vitalidad activa (removeSmileCheck() y removeHeadRotation()) que se agregan por defecto.

  • buildSpeechSettings(speechSettings: SpeechSettings?) - Define los criterios para el habla de accesibilidad, usando los siguientes parámetros:

    • volume - El volumen de audio entre 0.0 y 1.0.

    • startsMuted - Define si las instrucciones comienzan en silencio o no (true para silencio).

    • pitch - Define la tonalidad de la voz para las instrucciones entre 0.5 (baja) y 2.0 (alta).

    • speed - Define la velocidad de la voz para las instrucciones. Este valor debe ser positivo.

    Los valores predefinidos se pueden acceder a través de la variable estática:

  • removeSpeech() - Elimina el habla de accesibilidad.

  • setReviewEnable(enable: Boolean) - Define si la pantalla de revisión de captura biométrica está habilitada o deshabilitada.

  • setInstructionEnable(enable: Boolean) - Define si la pantalla de instrucciones está habilitada o deshabilitada.

  • forceLanguage(language: BCCFaceAPI.BCCLanguages?) - Fuerza que las instrucciones se muestren en un único idioma. Si el idioma del dispositivo no es compatible, se usará inglés. Los idiomas compatibles son:

  • removeLanguage() - Elimina el idioma forzado.

  • enableFlipCameraButton(enable: Boolean) - Activa (true) o desactiva (false) el botón de cambio de cámara (frontal o trasera). Predeterminado: habilitado (true).

  • setCameraInitialDirection(CameraFacingDirection.<FRONT or BACK>) - Define la dirección inicial de la cámara, elija entre:

    • CameraFacingDirection.FRONT - Cámara frontal (configuración predeterminada).

    • CameraFacingDirection.BACK - Cámara trasera.


Todas las configuraciones de dirección de la cámara se obtienen mediante la combinación de los métodos enableFlipCameraButton y setCameraInitialDirection . Por ejemplo:

  • Comenzar con la cámara frontal y habilitar el botón de cambio de cámara:

  • Comenzar con la cámara trasera y deshabilitar el botón de cambio de cámara:


Para referencia, aquí hay una lista completa de parámetros y valores predeterminados:

Aquí hay un fragmento de código para inicializar una captura usando solo la prueba de vitalidad pasiva:

Valores de Retorno

Los resultados de la última captura facial se pueden recuperar usando el método faceCaptureDidFinish del BCCFaceDelegate interfaz:

El data el objeto contiene ambas imágenes capturadas durante el proceso:

Las propiedades devueltas son:

  • originalPhoto (imagen) - La foto original tomada por la cámara.

  • croppedPhoto (imagen) - La foto recortada, que es la imagen del rostro recortada de la foto original.

  • passiveResult (ByteArray) - Contenido de archivo de la colección para vitalidad pasiva. Está presente solo si se capturó con éxito. Es el retorno de la colección para vitalidad pasiva como JPEG ByteArray. Estos datos pueden guardarse/exportarse directamente a un archivo o enviarse por la red (para redes: la codificación del sistema puede hacerse fácilmente, p. ej. cadena Base64).

El originalPhoto y croppedPhoto propiedades devuelven null cuando la captura se realiza solo para pruebas pasivas (es decir, sin incluir una prueba activa).

Si el usuario aborta la captura, cerrando antes de capturar los biométricos, se llamará al método faceCaptureDidAbort que puede implementar este método para tratar este escenario.

Proyecto de Ejemplo

Este es un proyecto de ejemplo funcional para una captura facial usando BCC Mobile Face Android:

Última actualización

¿Te fue útil?