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.
El prueba de vitalidad pasiva está disponible solo a partir de la versión 4.4.0 en adelante.
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:
Google ML Kit, detección de rostros versión 16.0.2;
Lottie, versión 3.0.0;
Libyuv-android, versión 1.0.0;
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.gradleandroid/app/build.gradle, agregue al final del archivo:
Configurando todas las dependencias
Realice cambios en los siguientes archivos:
android/build.gradleandroid/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()yremoveHeadRotation()) 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 entre0.0y1.0.startsMuted- Define si las instrucciones comienzan en silencio o no (truepara silencio).pitch- Define la tonalidad de la voz para las instrucciones entre0.5(baja) y2.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:
La prueba de vitalidad activa (usando sonrisa y rotación aleatoria de la cabeza) está habilitada por defecto. Para usar solo la comprobación de vitalidad pasiva, antes de agregarla, es necesario eliminar los métodos de vitalidad activa del constructor:
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).
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?

