Introdução

A biblioteca em C pode ser encontrada no Kit de desenvolvimento do iDBIO. Os headers com as definições das funções estão disponíveis na pasta "include". Esta biblioteca apresenta 3 versões: Linux x86, Linux x64 e Windows.

Para utilizar a biblioteca em seu projeto basta "linkar" a mesma ao seu executável.

Exemplo com gcc:

gcc example.c -lcidbio -o example

Códigos de Retorno

int32_t CIDBIO_GetErrorMessage (int32_t error, char** msg)

Retorna mensagem em inglês do erro passado.

Parâmetros de entrada:*

  • error: int32_t
    Código de erro

Parâmetros de saída:

  • msg: char**
    Descrição em inglês do erro.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.

Todas as funções desta biblioteca retornam um número inteiro. Este código de retorno pode indicar uma das 3 situações abaixo:

  • Sucesso (== 0) - Operação foi realizada com sucesso
  • Aviso (> 0) - Operação foi realizada mas com alguma ressalva
  • Erro (< 0) - Operação falhou
Valor Define Descrição
0 CIDBIO_SUCCESS Operação realizada com sucesso
1 CIDBIO_WARNING_ALREADY_INIT Biblioteca já inicializada
2 CIDBIO_WARNING_NO_IDS_ON_DEVICE Nenhum Template cadastrado
3 CIDBIO_WARNING_OVERWRITING_TEMPLATE Template foi sobrescrito
-1 CIDBIO_ERROR_UNKNOWN Erro desconhecido
-2 CIDBIO_ERROR_NO_DEVICE Dispositivo não encontrado
-3 CIDBIO_ERROR_NULL_ARGUMENT Argumento nulo
-4 CIDBIO_ERROR_INVALID_ARGUMENT Argumento inválido
-5 CIDBIO_ERROR_CAPTURE Erro durante a captura
-6 CIDBIO_ERROR_CAPTURE_TIMEOUT Tempo de captura expirado
-7 CIDBIO_ERROR_COMM_USB Erro de comunicação USB
-8 CIDBIO_ERROR_IO_ON_HOST Erro de comunicação do Host
-9 CIDBIO_ERROR_TEMPLATE_ALREADY_ENROLLED Template já cadastrado
-10 CIDBIO_ERROR_MERGING Falha no Merge
-11 CIDBIO_ERROR_MATCHING Falha no Match
-12 CIDBIO_ERROR_INVALID_FW_FILE Arquivo de Firmware inválido
-13 CIDBIO_ERROR_NO_SPACE_LEFT_ON_DEVICE Espaço no dispositivo esgotado
-14 CIDBIO_ERROR_NO_TEMPLATE_WITH_ID Template não cadastrado
-15 CIDBIO_ERROR_INVALID_ERRNO Código de erro inválido
-16 CIDBIO_ERROR_UNAVAILABLE_FEATURE Funcionalidade não disponível
-17 CIDBIO_ERROR_PREVIOUS_FW_VERSION Versão do firmware é anterior à atual
-18 CIDBIO_ERROR_NOT_IDENTIFIED Template não identificado
-19 CIDBIO_ERROR_BUSY Dispositivo esta ocupado
-20 CIDBIO_ERROR_CAPTURE_CANCELED Captura foi cancelada
-21 CIDBIO_ERROR_NO_FINGER_DETECTED Digital não foi detectada

Inicialização e Finalização

int32_t CIDBIO_SetSerialCommPort (char* comPort)

Configura em qual porta o dispositivo deve se conectar.
Disponível a partir da versão da SDK: 1.4.0

Parâmetro de entrada:

  • comPort: char*
    Porta serial ao qual o dispositivo deve se conectar. Deve ser "COMx" em Windows e "/dev/ttyACMx" em Linux

int32_t CIDBIO_Init (void)

Checa e inicializa o dispositivo.

int32_t CIDBIO_Terminate (void)

Finaliza o dispositivo.

Captura de dedo

int32_t CIDBIO_CaptureImage (byte** imageBuf, uint32_t* width, uint32_t* height)

Captura uma imagem de um dedo. Quando esta função é chamada o dispositivo entra no modo de captura de imagens. Esta função não retorna enquanto um dedo não for capturado, ou o tempo de captura for expirado (30 segundos).

Parâmetros de saída:

  • imageBuf: byte**
    Buffer com o conteúdo bitmap da imagem.
    Usar CIDBIO_FreeByteArray() para liberar memória deste parâmetro.
  • width: uint32_t*
    Largura da imagem
  • height: uint32_t*
    Altura da imagem

int32_t CIDBIO_CheckFingerprint (byte** imageBuf, uint32_t* width, uint32_t* height)

Checa se existe um dedo pressionando o leitor. Em caso positivo a imagem da digital é retornada, em caso negativo o erro CIDBIO_ERROR_NO_FINGER_DETECTED é retornado. Esta função sempre retorna imediatamente.
Disponível a partir da versão do firmware: 1.2.0

Parâmetros de saída:

  • imageBuf: byte**
    Buffer com o conteúdo bitmap da imagem.
    Usar CIDBIO_FreeByteArray() para liberar memória deste parâmetro.
  • width: uint32_t*
    Largura da imagem
  • height: uint32_t*
    Altura da imagem

int32_t CIDBIO_CaptureImageAndTemplate (char** temp, byte** imageBuf, uint32_t* width, uint32_t* height, int32_t* quality)

Captura uma imagem de um dedo e extrai o seu template. Quando esta função é chamada o dispostivo entra no modo de captura de imagens. Esta função não retorna enquanto um dedo não for capturado, ou o tempo de captura for expirado (30 segundos).

Parâmetros de saída:

  • temp: char**
    Base64 do template extraído.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.
  • imageBuf: byte**
    Buffer com o conteúdo bitmap da imagem.
    Usar CIDBIO_FreeByteArray() para liberar memória deste parâmetro.
  • width: uint32_t*
    Largura da imagem
  • height: uint32_t*
    Altura da imagem.
  • quality: int32_t*
    Valor de 0 a 100 que define a qualidade da imagem do dedo capturado.

int32_t CIDBIO_CaptureAndEnroll (int64_t id)

Captura 3 imagens de um dedo e o cadastra no dispositivo. Quando esta função é chamada o dispositivo entra no modo de captura de imagens. Esta função não retorna enquanto um dedo não for capturado 3 vezes, ou o tempo de captura for expirado (30 segundos por iteração).

Parâmetro de entrada:

  • id: int64_t
    Número identificador do template

int32_t CIDBIO_CaptureAndIdentify (int64_t* id, int32_t* score, int32_t* quality)

Captura uma imagem de um dedo e tenta encontrar uma biometria semelhante cadastrada no dispositivo. Quando esta função é chamada o dispositivo entra no modo de captura de imagens. Esta função não retorna enquanto um dedo não for capturado, ou o tempo de captura for expirado (30 segundos).

Parâmetros de saída:

  • id: int64_t*
    Número identificador do template encontrado.
  • score: int32_t*
    Valor entre 0 e 20000 que define a semelhança entre o dedo capturado e o cadastrado.
  • quality: int32_t*
    Valor de 0 a 100 que define a qualidade da imagem do dedo capturado.

int32_t CIDBIO_CaptureAndMatch (int64_t id, int32_t* score, int32_t* quality)

Captura uma imagem de um dedo e verifica a semelhança com a biometria cadastrada com identificador id. Quando esta função é chamada o dispositivo entra no modo de captura de imagens. Esta função não retorna enquanto um dedo não for capturado, ou o tempo de captura for expirado (30 segundos).

Parâmetros de entrada:

  • id: int64_t
    Número identificador do template a ser comparado.

Parâmetros de saída:

  • score: int32_t*
    Valor entre 0 e 20000 que define a semelhança entre o dedo capturado e o cadastrado.
  • quality: int32_t*
    Valor de 0 a 100 que define a qualidade da imagem do dedo capturado.

int32_t CIDBIO_CancelCapture ()

Cancela a operação de captura atual.
Disponível a partir da versão do firmware: 1.2.0

Gerenciar Templates

int32_t CIDBIO_ExtractTemplateFromImage (uint32_t width, uint32_t height, byte* imageBuf, char** temp, int32_t* quality)

Extrai o template de uma imagem.

Parâmetros de entrada:

  • width: uint32_t
    Largura da imagem
  • height: uint32_t
    Altura da imagem.
  • imageBuf: byte*
    Buffer com o conteúdo bitmap da imagem.

Parâmetros de saída:

  • temp: char**
    Base64 do template extraído.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.
  • quality: int32_t*
    Valor de 0 a 100 que define a qualidade da imagem do dedo capturado.

int32_t CIDBIO_MergeTemplates (char* temp1, char* temp2, char* temp3, char** tempFinal)

Mescla 3 templates em um único template. Templates devem pertencer ao mesmo dedo. (Formatos "ISO" e "ANSI" não são suportados para importação de templates)

Parâmetros de entrada:

  • temp1: char*
    Base64 do primeiro template.
  • temp2: char*
    Base64 do segundo template.
  • temp3: char*
    Base64 do terceiro template.

Parâmetros de saída:

  • tempFinal: char**
    Base64 do template mesclado.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.

int32_t CIDBIO_MatchTemplates (char* temp1, char* temp2, int32_t* score)

Verifica se 2 templates são iguais. (Formatos "ISO" e "ANSI" não são suportados para importação de templates)

Parâmetros de entrada:

  • temp1: char*
    Base64 do primeiro template.
  • temp2: char*
    Base64 do segundo template.

Parâmetros de saída:

  • score: int32_t*
    Valor entre 0 e 20000 que define a semelhança entre os 2 templates.

int32_t CIDBIO_MatchTemplateByID (int64_t id, char* temp, int32_t* score)

Verifica se o template temp é igual ao template cadastrado com identificador id. (Formatos "ISO" e "ANSI" não são suportados para importação de templates)

Parâmetros de entrada:

  • id: int64_t
    identificador do template a ser verificado.
  • temp: char*
    Base64 do template.

Parâmetros de saída:

  • score: int32_t*
    Valor entre 0 e 20000 que define a semelhança entre os 2 templates.

int32_t CIDBIO_GetTemplateIDs (int64_t** ids, uint32_t* len)

Carrega os identificadores de todos templates cadastrados.

Parâmetros de saída:

  • ids: int64_t**
    Identificadores de todos os templates cadastros no dispositivo.
    Usar CIDBIO_FreeIDArray() para liberar memória deste parâmetro.
  • len: uint32_t*
    Número de templates cadastros no dispositivo.

int32_t CIDBIO_GetTemplate (int64_t id, char** temp)

Carrega o template cadastrado com identificador id.

Parâmetros de entrada:

  • id: int64_t
    Identificador do templates cadastro no dispositivo.

Parâmetros de saída:

  • temp: char**
    Base64 do template.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.

int32_t CIDBIO_SaveTemplate (int64_t id, char* temp)

Salva o template temp com o identificador id. (Formatos "ISO" e "ANSI" não são suportados para importação de templates)

Parâmetros de entrada:

  • id: int64_t
    Identificador do templates cadastro no dispositivo.

  • temp: char*
    Base64 do template.

int32_t CIDBIO_DeleteTemplate (int64_t id)

Deleta o template cadastrado com identificador id.

Parâmetros de entrada:

  • id: int64_t
    Identificador do templates cadastro no dispositivo.

int32_t CIDBIO_DeleteAllTemplates (void)

Deleta todos os template cadastrados no dispositivo.

Configuração do dispositivo

É possível alterar o comportamento do dispositivo atráves das configurações abaixo:

Valor Define Descrição
1 CIDBIO_PARAM_MIN_VAR Variância mínima para captura de um dedo. (padrão: "1000")
2 CIDBIO_PARAM_SIMILIARITY_THRESHOLD Valor de 1 a 20000 que determina o valor mínimo para 2 templates serem considerados iguais. Valor 0 para automático (padrão)
4 CIDBIO_PARAM_BUZZER_ON "1" (padrão) ou "0" para ligar ou desligar o buzzer
5 CIDBIO_PARAM_TEMPLATE_FORMAT Configura o formato do template. Valores possíveis:
"ICS": Formato proprietário (padrão)
"ANSI": Formato ANSI (Somente para exportação de templates)
"ISO": Formato ISO (Somente para exportação de templates)
"ANSI_PLUS": Formato ANSI com informações proprietárias
"ISO_PLUS": Formato ISO com informações proprietárias
6 CIDBIO_PARAM_ROTATION Rotação máxima aceita para que dois dedos sejam aceitos como iguais. Esta rotação é aplicada no sentido horário e anti-horário. Este parâmetro impacta na velocidade de identificação, quanto maior este valor, mais tempo a identificação demorará. Valor de 0 a 180 (padrão: "30")
7 CIDBIO_PARAM_DETECT_TIMEOUT Tempo, em milissegundos, de espera para detecção de um dedo. (padrão: "30000")

int32_t CIDBIO_SetParameter (int32_t config, char* value)

Configura o parâmetro config com o valor value.

Parâmetros de entrada:

  • config: int32_t
    Parâmetro a ser configurado
  • value: char*
    Valor a ser configurado.

int32_t CIDBIO_GetParameter (int32_t config, char** value)

Lê o valor do parâmetro config.

Parâmetros de entrada:

  • config: int32_t
    Parâmetro a ser configurado

Parâmetros de saída:

  • value: char**
    Valor atual do parâmetro.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.

int32_t CIDBIO_GetDeviceInfo (char** version, char** serialNumber, char** model)

Lê as informações do dispositivo.

Parâmetros de saída:

  • version: _char**
    Versão do firmware do dispositivo.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.
  • serialNumber: char**
    Número de série do dispositivo.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.
  • model: char**
    Modelo do dispositivo.
    Usar CIDBIO_FreeString() para liberar memória deste parâmetro.

int32_t CIDBIO_UpdateFirmware (char* filePath)

Atualiza o firmware do dispositivo com o arquivo em filePath. Este procedimento pode demorar alguns minutos. Por favor, não desconecte o dispositivo durante este período, pois isto pode danificar o dispositivo de forma permanente.
A última versão do fimware pode ser encontrada aqui.

Parâmetros de entrada:

  • filePath: char*
    Caminho completo para o arquivo contendo a atualização de firmware.

Desalocação de memória

int32_t CIDBIO_FreeByteArray (byte* array)

Desaloca memória de um array de bytes.

Parâmetros de entrada:

  • array: byte*
    Array de bytes a ser desalocado da memória.

int32_t CIDBIO_FreeString (char* str)

Desaloca memória de uma string de c.

Parâmetros de entrada:

  • str: char*
    String a ser desalocado da memória.

int32_t CIDBIO_FreeIDArray (int64_t* ids)

Desaloca memória de um array de inteiros de 64 bits.

Parâmetros de entrada:

  • ids: int64_t*
    Array de inteiros de 64 bits a ser desalocado da memória.