名称介绍

简介

该电容指纹模块集指纹采集、处理、存储及指纹比对为一体。以ID809高性能处理器和半导体指纹传感器为核心,内置 IDfinger6.0指纹算法,能够独立完成全部的指纹识别工作。该模块采用标准I2C通讯,配合Arduino库,非常容易实现录入指纹、删除指纹、比对指纹等指纹识别功能。同时我们提供了一个上位机软件,通过该软件就能操作该模块。
该模块外观精致轻薄一体化,具有环形炫酷呼吸灯,指纹识别速度快、安全性高,支持360度任意角度识别、深度自学习功能、高性能、低功耗。

相比SEN0348:电容式指纹识别传感器,本模块接线更加方便,同时做了3.3V和5V兼容,将UART通讯转为I2C通讯,使得UNO、micro:bit等主控也能轻松驱动。

注意:此产品在Mind+的1.7.2 RC3.0中暂时无法使用灯环功能,建议使用Arduino IDE进行编程使用灯环或等待后续Mind+版本更新。

特性

  • 360°指纹录入与匹配
  • 自动学习功能
  • CNC金属环,炫酷灯环

应用场景

  • 指纹门锁
  • 抽屉锁
  • 身份识别
  • 授权许可

技术规格

  • 工作电压:3.3V-5V
  • 工作电流:<60mA
  • 通信方式:I2C
  • 存储容量:80枚指纹
  • 1:1的验证时间:300~400ms
  • 像素分辨率: 508dpi
  • 像素点数:160x160
  • 指纹检测区域:8.0mm x 8.0mm
  • 工作环境:‐40‐60℃/<RH 90%
  • 指纹模块尺寸:直径21mm / 高5mm
  • 转接板尺寸:22.5*32mm

引脚说明

序号 名称 功能描述
1 VCC 正极
2 GND 公共地
3 SCL I2C时钟线
4 SDA I2C数据线
5 IRQ 手指感应输出:高电平有效
6 LED 板载红色LED指示灯,手指触摸后亮起

使用教程

准备

  /**
   * @brief 测试模块是否正常连接
   * @return true or false
   */
  bool isConnected();
   
  /**
   * @brief 设置LED灯
   * @param mode:in typedef enum eLEDMode_t
   * @param color:in typedef enum eLEDColor_t
   * @param blink Count: 0表示一直呼吸、闪烁,该参数仅在eBreathing、eFastBlink、eSlowBlink模式下有效
   * @return 0(succeed) or ERR_ID809
   */
  uint8_t ctrlLED(eLEDMode_t mode,eLEDColor_t color,uint8_t blinkCount);
  
  /**
   * @brief 检测是否有手指触碰
   * @return 1(有手指) or 0(无手指)
   */
  uint8_t detectFinger();
  
  /**
   * @brief 获取可注册首个编号
   * @return 可注册ID号 or ERR_ID809
   */
  uint8_t getEmptyID();
  
  /**
   * @brief 检查ID是否已被注册
   * @return 0(已注册)、1(未注册) or ERR_ID809
   */
  uint8_t getStatusID(uint8_t ID);
  
  /**
   * @brief 获取注册用户数量
   * @return 注册用户数量 or ERR_ID809
   */
  uint8_t getEnrollCount();
  
  /**
   * @brief 获取已注册用户列表
   * @return 0(succeed) or ERR_ID809
   */
   uint8_t getEnrolledIDList(uint8_t* list);
  
  /**
   * @brief 采集指纹
   * @return 0(succeed) or ERR_ID809
   */
  uint8_t collectionFingerprint(uint16_t timeout);
  
  /**
   * @brief 保存指纹
   * @param 指纹ID
   * @return 0(succeed) or ERR_ID809
   */
  uint8_t storeFingerprint(uint8_t ID);
  
  /**
   * @brief 删除指纹
   * @param 指纹ID or DELALL(全部删除)
   * @return 0(succeed) or ERR_ID809
   */
  uint8_t delFingerprint(uint8_t ID);
  
  /**
   * @brief 将指纹与全部指纹匹配
   * @return 匹配成功的指纹ID、0(匹配失败) or ERR_ID809
   */
  uint8_t search();

  /**
   * @brief 将指纹与指定指纹匹配
   * @return 匹配成功的指纹ID、0(匹配失败) or ERR_ID809
   */
  uint8_t verify(uint8_t ID);
  
  /**
   * @brief 获取错误信息
   * @return 错误信息的文本描述
   */
  String getErrorDescription();

接线图

SEN0359接线

样例代码1 - 获取模块信息

获取模块的参数信息并通过串口打印

/*!
 * @file getDeviceInformation.ino
 * @brief 获取指纹模块信息
 * @n 实验现象:串口打印出模块的ID、安全等级、波特率等信息
 * @copyright  Copyright (c) 2010 DFRobot Co.Ltd (http://www.dfrobot.com)
 * @licence     The MIT License (MIT)
 * @author [Eddard](Eddard.liu@dfrobot.com)
 * @version  V1.0
 * @date  2020-03-19
 * @get from https://www.dfrobot.com
 * @url https://github.com/DFRobot/DFRobot_ID809
*/

#include <DFRobot_ID809_I2C.h>

DFRobot_ID809_I2C fingerprint;
//DFRobot_ID809_UART fingerprint(115200);
//String desc;   //错误码信息,启用此功能将占用较大内存

void setup(){
  /*初始化打印串口*/
  Serial.begin(9600);
  /*初始化指纹模块*/
  fingerprint.begin();
  /*等待Serial打开*/
  while(!Serial);
  /*测试设备与主控是否能正常通讯,
    返回true or false
    */
  while(fingerprint.isConnected() == false){
    Serial.println("与设备通讯失败,请检查接线");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
    delay(1000);
  }
}

uint8_t enrollCount;   //已注册用户数

void loop(){
  /*设置模块ID号,可设置值1-255*/
  //fingerprint.setDeviceID(/*Device ID = */1);
  Serial.print("模块ID为:");
  /*读取模块ID*/
  Serial.println(fingerprint.getDeviceID());
  
  /*设置模块安全等级,可设置值1-5,默认安全等级3
    Security Level          识别率
      Level 1          认假率 FAR  0.1%
                       拒真率 FRR  0.005%
      Level 2          认假率 FAR  0.003%
                       拒真率 FRR  0 01%
      Level 3          认假率 FAR  0.001%
                       拒真率 FRR  0.1%
      Level 4          认假率 FAR  0.003%
                       拒真率 FRR  0.5%
      Level 5          认假率 FAR  0.0001%
                       拒真率 FRR  1%
   */
  //fingerprint.setSecurityLevel(/*Security Level = */3);
  Serial.print("模块安全等级为:");
  /*读取模块安全等级*/
  Serial.println(fingerprint.getSecurityLevel());
  
  /*设置模块波特率,可设置范围如下所示:
    e9600bps    e19200bps   e38400bps   e57600bps   e115200bps
       1           2            3          4            5
   */
  //fingerprint.setBaudrate(fingerprint.e115200bps);
  Serial.print("模块波特率为:");
  /*读取模块波特率*/
  Serial.println(fingerprint.getBaudrate());
  
  /*设置模块自学功能,1(ON) 0(OFF)*/
  //fingerprint.setAutoLearn(/*Auto Learn = */1);
  Serial.print("模块自学功能:");
  /*读取模块自学功能状态
    如果开启则打印ON,否则打印OFF*/
  Serial.println(fingerprint.getSelfLearn()?"ON":"OFF");
  
  /*设置模块序列号,序列号字符数必须小于15个*/
  //fingerprint.setModuleSN(/*Module SN = */"DFRobot");
  Serial.print("模块序列号为:");
  /*读取模块序列号*/
  Serial.println(fingerprint.getModuleSN());
  
  Serial.print("模块内部已注册指纹数量:");
  /*获取注册用户数量*/
  Serial.println(enrollCount = fingerprint.getEnrollCount());
  /*声明一个数组用来存放ID列表*/
  uint8_t list[80] = {0};
  /*获取用户列表
    传入一个数组指针用来接收ID列表
   */
  fingerprint.getEnrolledIDList(list);
  Serial.print("已注册用户ID列表:");
  for(uint8_t i = 0; i < enrollCount; i++){
    Serial.print(list[i]);
    Serial.print(",");
  }
  
  Serial.print("\n指纹损坏数量:");
  /*获取损坏的指纹数量*/
  Serial.println(fingerprint.getBrokenQuantity());
  /*获取第一个损坏的指纹ID号*/
  //fingerprint.getBrokenID();
  Serial.println("-----------------------------");

  delay(1000);
}     
  • Result

SEN0348结果2

样例代码2 - 增加指纹

本样例自动获取可注册ID,然后采集三次指纹,采集成功黄色灯快闪3次,最后将指纹保存到获取到的未注册的编号中,绿色灯亮1S然后熄灭

/*!
 * @file fingerprintRegistration.ino
 * @brief 采集指纹并保存
 * @n 该模块可以使用硬串口或软串口控制
 * @n 实验现象:自动获取空白ID,然后采集三次指纹,采集时
 * @n           设置灯环为蓝色呼吸灯,采集成功黄色灯快闪
 * @n           3次,最后将指纹保存到获取到的未注册的编
 * @n           号中,绿色灯亮1S然后熄灭
 * @copyright  Copyright (c) 2010 DFRobot Co.Ltd (http://www.dfrobot.com)
 * @licence     The MIT License (MIT)
 * @author [Eddard](Eddard.liu@dfrobot.com)
 * @version  V1.0
 * @date  2020-03-19
 * @get from https://www.dfrobot.com
 * @url https://github.com/DFRobot/DFRobot_ID809
*/

#include <DFRobot_ID809_I2C.h>

#define COLLECT_NUMBER 3  //指纹采样次数,可设置2-3

DFRobot_ID809_I2C fingerprint;
//DFRobot_ID809_UART fingerprint(115200);
//String desc;   //错误码信息,启用此功能将占用较大内存

void setup(){
  /*初始化打印串口*/
  Serial.begin(9600);
  /*初始化指纹模块*/
  fingerprint.begin();
  /*等待Serial打开*/
  while(!Serial);
  /*测试设备与主控是否能正常通讯,
    返回true or false
    */
  while(fingerprint.isConnected() == false){
    Serial.println("与设备通讯失败,请检查接线");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
    delay(1000);
  }
}

uint8_t ID,i,ret;

void loop(){
  /*获取一个未注册编号,用来保存指纹
    获取成功返回ID号,
    获取失败返回ERR_ID809
   */
  if((ID = fingerprint.getEmptyID()) == ERR_ID809){
    while(1){
      /*获取错误码信息*/
      //desc = fingerprint.getErrorDescription();
      //Serial.println(desc);
      delay(1000);
    }
  }
  Serial.print("未注册编号,ID=");
  Serial.println(ID);
  i = 0;   //采样计数清零
  /*指纹采样三次*/
  while(i < COLLECT_NUMBER){
    /*设置指纹灯环模式、颜色和闪烁次数,
      可设置参数如下:
      参数1:<LEDMode>
      eBreathing   eFastBlink   eKeepsOn    eNormalClose
      eFadeIn      eFadeOut     eSlowBlink   
      参数2:<LEDColor>
      eLEDGreen  eLEDRed      eLEDYellow   eLEDBlue
      eLEDCyan   eLEDMagenta  eLEDWhite
      参数3:<呼吸、闪烁次数> 0表示一直呼吸、闪烁,
      该参数仅在eBreathing、eFastBlink、eSlowBlink模式下有效
     */
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eBreathing, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
    Serial.print("正在进行第");
    Serial.print(i+1);
    Serial.println("次指纹采样");
    Serial.println("请按下手指");
    /*采集指纹图像,超过10S没按下手指则采集超时,如果timeout=0,关闭采集超时功能
      如果获取成功返回0,否则返回ERR_ID809
     */
    if((fingerprint.collectionFingerprint(/*timeout = */10)) != ERR_ID809){
      /*设置指纹灯环为黄色快闪3次*/
      fingerprint.ctrlLED(/*LEDMode = */fingerprint.eFastBlink, /*LEDColor = */fingerprint.eLEDYellow, /*blinkCount = */3);
      Serial.println("采集成功");
      i++;   //采样计数+1
    }else{
      Serial.println("采集失败");
      /*获取错误码信息*/
      //desc = fingerprint.getErrorDescription();
      //Serial.println(desc);
    }
    Serial.println("请松开手指");
    /*等待手指松开
      检测到手指返回1,否则返回0
     */
    while(fingerprint.detectFinger());
  }
  
  /*将指纹信息保存到一个未注册的编号中*/
  if(fingerprint.storeFingerprint(/*Empty ID = */ID) != ERR_ID809){
    Serial.print("保存成功,ID=");
    Serial.println(ID);
    Serial.println("-----------------------------");
    /*设置指纹灯环为绿色常亮*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDGreen, /*blinkCount = */0);
    delay(1000);
    /*关闭指纹灯环*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eNormalClose, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
    delay(1000);
  }else{
    Serial.println("保存失败");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
  }
} 
  • 结果

SEN0348结果3

样例代码3 - 指纹匹配

采集指纹图像并与指纹库中的指纹做对比,对比成功亮绿色灯并打印ID号,对比失败亮红色灯并提示匹配失败

/*!
 * @file fingerprintMatching.ino
 * @brief 采集指纹并与指纹库中指纹做对比
 * @n 实验现象:采集指纹图像并与指纹库中的指纹最对比,
                对比成功亮绿色灯并打印ID号,对比失败返回0
 * @copyright  Copyright (c) 2010 DFRobot Co.Ltd (http://www.dfrobot.com)
 * @licence     The MIT License (MIT)
 * @author [Eddard](Eddard.liu@dfrobot.com)
 * @version  V1.0
 * @date  2020-03-19
 * @get from https://www.dfrobot.com
 * @url https://github.com/DFRobot/DFRobot_ID809
*/
#include <DFRobot_ID809_I2C.h>

DFRobot_ID809_I2C fingerprint;
//DFRobot_ID809_UART fingerprint(115200);
//String desc;   //错误码信息,启用此功能将占用较大内存

void setup(){
  /*初始化打印串口*/
  Serial.begin(9600);
  /*初始化指纹模块*/
  fingerprint.begin();
  /*等待Serial打开*/
  while(!Serial);
  /*测试设备与主控是否能正常通讯,
    返回true or false
    */
  while(fingerprint.isConnected() == false){
    Serial.println("与设备通讯失败,请检查接线");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
    delay(1000);
  }
}

void loop(){
  uint8_t ret = 0;
  /*设置指纹灯环模式、颜色和闪烁次数,
    可设置参数如下:
    参数1:<LEDMode>
    eBreathing   eFastBlink   eKeepsOn    eNormalClose
    eFadeIn      eFadeOut     eSlowBlink   
    参数2:<LEDColor>
    eLEDGreen  eLEDRed      eLEDYellow   eLEDBlue
    eLEDCyan   eLEDMagenta  eLEDWhite
    参数3:<呼吸、闪烁次数> 0表示一直呼吸、闪烁,
    该参数仅在eBreathing、eFastBlink、eSlowBlink模式下有效
   */
  fingerprint.ctrlLED(/*LEDMode = */fingerprint.eBreathing, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
  Serial.println("请按下手指");
  /*采集指纹图像,关闭采集超时功能
    如果获取成功返回0,否则返回ERR_ID809
   */
  if((fingerprint.collectionFingerprint(/*timeout=*/10)) != ERR_ID809){
    /*设置指纹灯环为黄色快闪3次*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eFastBlink, /*LEDColor = */fingerprint.eLEDYellow, /*blinkCount = */3);
    Serial.println("采集成功");
    Serial.println("请松开手指");
    /*等待手指松开
      检测到手指返回1,否则返回0
     */
    while(fingerprint.detectFinger());
    /*将采集到的指纹与指纹库中的所有指纹对比,
      成功返回指纹编号(1-80),失败返回0
     */
    ret = fingerprint.search();
    /*将采集到的指纹与指定编号指纹对比
      成功返回指纹编号(1-80),失败返回0
     */
    //ret = fingerprint.verify(/*Fingerprint ID = */1);  
    if(ret != 0){
      /*设置指纹灯环为绿色常亮*/
      fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDGreen, /*blinkCount = */0);
      Serial.print("匹配成功,ID=");
      Serial.println(ret);
    }else{
      /*设置指纹灯环为红色常亮*/
      fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDRed, /*blinkCount = */0);
      Serial.println("匹配失败");
    }
  }else{
    Serial.println("采集失败");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
  }
  Serial.println("-----------------------------");
  delay(1000);
}            
  • 结果

SEN0348结果4

样例代码4 - 删除指纹

运行代码,按下需要删除指纹的手指

/*!
 * @file fingerprintDeletion.ino
 * @brief 删除指定指纹
 * @n 实验现象:按下手指,如果该手指指纹已注册则删除指纹,并亮绿灯
                如果未注册或采集指纹失败,则亮红灯
 * @copyright  Copyright (c) 2010 DFRobot Co.Ltd (http://www.dfrobot.com)
 * @licence     The MIT License (MIT)
 * @author [Eddard](Eddard.liu@dfrobot.com)
 * @version  V1.0
 * @date  2020-03-19
 * @get from https://www.dfrobot.com
 * @url https://github.com/DFRobot/DFRobot_ID809
*/
#include <DFRobot_ID809_I2C.h>

DFRobot_ID809_I2C fingerprint;
//DFRobot_ID809_UART fingerprint(115200);
//String desc;   //错误码信息,启用此功能将占用较大内存

void setup(){
  /*初始化打印串口*/
  Serial.begin(9600);
  /*初始化指纹模块*/
  fingerprint.begin();
  /*等待Serial打开*/
  while(!Serial);
  /*测试设备与主控是否能正常通讯,
    返回true or false
    */
  while(fingerprint.isConnected() == false){
    Serial.println("与设备通讯失败,请检查接线");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
    delay(1000);
  }
}

void loop(){
  uint8_t ret = 0;
  /*设置指纹灯环模式、颜色和闪烁次数,
    可设置参数如下:
    参数1:<LEDMode>
    eBreathing   eFastBlink   eKeepsOn    eNormalClose
    eFadeIn      eFadeOut     eSlowBlink   
    参数2:<LEDColor>
    eLEDGreen  eLEDRed      eLEDYellow   eLEDBlue
    eLEDCyan   eLEDMagenta  eLEDWhite
    参数3:<呼吸、闪烁次数> 0表示一直呼吸、闪烁,
    该参数仅在eBreathing、eFastBlink、eSlowBlink模式下有效
   */
  fingerprint.ctrlLED(/*LEDMode = */fingerprint.eBreathing, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
  Serial.println("请按下需要删除指纹的手指");
  /*采集指纹图像,超过10S没按下手指则采集超时,如果timeout=0,关闭采集超时功能
    如果获取成功返回0,否则返回ERR_ID809
   */
  if((fingerprint.collectionFingerprint(/*timeout=*/10)) != ERR_ID809){
    /*将采集到的指纹与指纹库中的所有指纹对比,
      成功返回指纹编号(1-80),失败返回0
     */
    ret = fingerprint.search();
    /*将采集到的指纹与指定编号指纹对比
      成功返回指纹编号(1-80),失败返回0
     */
    if(ret != 0){
      /*删除该编号的指纹*/
      fingerprint.delFingerprint(/*Fingerprint ID = */ret);
      //fingerprint.delFingerprint(DELALL);  //删除所有指纹
      Serial.print("删除成功,ID=");
      Serial.println(ret);
      /*设置指纹灯环为绿色常亮*/
      fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDGreen, /*blinkCount = */0);
    }else{
      Serial.println("指纹未注册");
      /*设置指纹灯环为红色常亮*/
      fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDRed, /*blinkCount = */0);
    }
  }else{
    Serial.println("采集失败");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
    /*设置指纹灯环为红色常亮*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDRed, /*blinkCount = */0);
  }
  Serial.println("请松开手指");
  /*等待手指松开
    检测到手指返回1,否则返回0
   */
  while(fingerprint.detectFinger());

  /*检查指纹编号是否被注册
    如果已注册返回1,否则返回0
   */
//  if(fingerprint.getStatusID(/*Fingerprint ID = */FINGERPRINTID)){
//    Serial.println("ID已注册");
//  }else{
//    Serial.println("ID未注册");
//  }
  Serial.println("-----------------------------");
  delay(1000);
}
  • 结果

SEN0348结果5

样例代码5 - 综合示例

本样例是对指纹模块的综合应用,根据手指按下时间长短不同进入不同的模式。按下手指,蓝灯快闪3次表示进入对比指纹模式;黄灯快闪3次,表示进入指纹注册模式;红灯快闪3次,表示进入删除指纹模式,删除该指纹。
本实验需要将IRQ引脚接到D6引脚。

/*!
 * @file comprehensiveExample.ino
 * @brief 综合示例
 * @n 该模块可以使用硬串口或软串口控制,本实验需要将IRQ引脚接到D6
 * @n 实验现象:按下手指,蓝灯快闪3次表示进入对比指纹模式
 * @n           黄灯快闪3次,表示进入指纹注册模式
 * @n           红灯快闪3次,表示进入删除指纹模式,删除该指纹
 * @copyright  Copyright (c) 2010 DFRobot Co.Ltd (http://www.dfrobot.com)
 * @licence     The MIT License (MIT)
 * @author [Eddard](Eddard.liu@dfrobot.com)
 * @version  V1.0
 * @date  2020-03-19
 * @get from https://www.dfrobot.com
 * @url https://github.com/DFRobot/DFRobot_ID809
*/

#include <DFRobot_ID809_I2C.h>

#define COLLECT_NUMBER 3  //指纹采样次数,可设置1-3
#define IRQ         6  //唤醒引脚

DFRobot_ID809_I2C fingerprint;
//DFRobot_ID809_UART fingerprint(115200);
//String desc;   //错误码信息,启用此功能将占用较大内存

void setup(){
  /*初始化打印串口*/
  Serial.begin(9600);
  /*初始化指纹模块*/
  fingerprint.begin();
  /*等待Serial打开*/
  while(!Serial);
  /*测试设备与主控是否能正常通讯,
    返回true or false
    */
  while(fingerprint.isConnected() == false){
    Serial.println("与设备通讯失败,请检查接线");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
    delay(1000);
  }
}

//蓝灯 匹配模式  黄灯 注册模式  红灯  删除模式
void loop(){
  if(digitalRead(IRQ)){
    uint16_t i = 0;
    /*采集指纹图像,超过5S没按下手指则采集超时,如果timeout=0,关闭采集超时功能
      如果获取成功返回0,否则返回ERR_ID809
     */
    if((fingerprint.collectionFingerprint(/*timeout=*/5)) != ERR_ID809){
      /*获取手指按下时间*/
      /*设置指纹灯环模式、颜色和闪烁次数,
        可设置参数如下:
        参数1:<LEDMode>
        eBreathing   eFastBlink   eKeepsOn    eNormalClose
        eFadeIn      eFadeOut     eSlowBlink   
        参数2:<LEDColor>
        eLEDGreen  eLEDRed      eLEDYellow   eLEDBlue
        eLEDCyan   eLEDMagenta  eLEDWhite
        参数3:<呼吸、闪烁次数> 0表示一直呼吸、闪烁,
        该参数仅在eBreathing、eFastBlink、eSlowBlink模式下有效
       */
      fingerprint.ctrlLED(/*LEDMode = */fingerprint.eFastBlink, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */3);  //蓝灯快闪3次,表示正处于对比指纹模式
      /*等待手指松开*/
      while(fingerprint.detectFinger()){
        delay(50);
        i++;
        if(i == 15){             //黄灯快闪3次,表示正处于注册指纹模式
          /*设置指纹灯环为黄色常亮*/
          fingerprint.ctrlLED(/*LEDMode = */fingerprint.eFastBlink, /*LEDColor = */fingerprint.eLEDYellow, /*blinkCount = */3);
        }else if(i == 30){      //红灯快闪3次,表示正处于删除指纹模式
          /*设置指纹灯环为红色常亮*/
          fingerprint.ctrlLED(/*LEDMode = */fingerprint.eFastBlink, /*LEDColor = */fingerprint.eLEDRed, /*blinkCount = */3);
        }
      }
    }
    if(i == 0){
      /*采集指纹失败*/
    }else if(i > 0 && i < 15){
      Serial.println("进入匹配指纹模式");
      /*对比指纹*/
      fingerprintMatching();
    }else if(i >= 15 && i < 30){
      Serial.println("进入注册指纹模式");
      /*注册指纹*/
      fingerprintRegistration();
    }else{
      Serial.println("进入删除指纹模式");
      /*删除该指纹*/
      fingerprintDeletion();
    }
  }
}

//对比指纹
void fingerprintMatching(){
  /*将采集到的指纹与指纹库中的所有指纹对比,
    成功返回指纹编号(1-80),失败返回0
   */
  uint8_t ret = fingerprint.search();
  if(ret != 0){
    /*设置指纹灯环为绿色常亮*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDGreen, /*blinkCount = */0);
    Serial.print("匹配成功,ID=");
    Serial.println(ret);
  }else{
    /*设置指纹灯环为红色常亮*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDRed, /*blinkCount = */0);
    Serial.println("匹配失败");
  }
  delay(1000);
  /*关闭指纹灯环*/
  fingerprint.ctrlLED(/*LEDMode = */fingerprint.eNormalClose, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
}

//注册指纹
void fingerprintRegistration(){
  uint8_t ID,i;
  /*将采集到的指纹与指纹库中的所有指纹对比,
    成功返回指纹编号(1-80),失败返回0
    此处作用:清除上次采集的指纹图像。
   */
  fingerprint.search();       //可增加判断语句,检测该指纹是否注册
  /*获取一个未注册编号,用来保存指纹
    获取成功返回ID号,
    获取失败返回ERR_ID809
   */
  if((ID = fingerprint.getEmptyID()) == ERR_ID809){
    while(1){
      /*获取错误码信息*/
      //desc = fingerprint.getErrorDescription();
      //Serial.println(desc);
      delay(1000);
    }
  }
  Serial.print("未注册编号,ID=");
  Serial.println(ID);
  i = 0;   //采样计数清零
  /*指纹采样三次*/
  while(i < COLLECT_NUMBER){
    /*设置指纹灯环为蓝色呼吸*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eBreathing, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
    Serial.print("正在进行第");
    Serial.print(i+1);
    Serial.println("次指纹采样");
    Serial.println("请按下手指");
    /*采集指纹图像,超过10S没按下手指则采集超时
      如果获取成功返回0,否则返回ERR_ID809
     */
    if((fingerprint.collectionFingerprint(/*timeout = */10)) != ERR_ID809){
      /*设置指纹灯环为黄色快闪3次*/
      fingerprint.ctrlLED(/*LEDMode = */fingerprint.eFastBlink, /*LEDColor = */fingerprint.eLEDYellow, /*blinkCount = */3);
      Serial.println("采集成功");
      i++;   //采样计数+1
    }else{
      Serial.println("采集失败");
      /*获取错误码信息*/
      //desc = fingerprint.getErrorDescription();
      //Serial.println(desc);
    }
    Serial.println("请松开手指");
    /*等待手指松开
      检测到手指返回1,否则返回0
     */
    while(fingerprint.detectFinger());
  }
  
  /*将指纹信息保存到一个未注册的编号中*/
  if(fingerprint.storeFingerprint(/*Empty ID = */ID) != ERR_ID809){
    Serial.print("保存成功,ID=");
    Serial.println(ID);
    Serial.println("-----------------------------");
    /*设置指纹灯环为绿色常亮*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDGreen, /*blinkCount = */0);
    delay(1000);
    /*关闭指纹灯环*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eNormalClose, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
  }else{
    Serial.println("保存失败");
    /*获取错误码信息*/
    //desc = fingerprint.getErrorDescription();
    //Serial.println(desc);
  }
}


//删除指纹
void fingerprintDeletion(){
  uint8_t ret;
  /*将采集到的指纹与指纹库中的所有指纹对比,
    成功返回指纹编号(1-80),失败返回0
   */
  ret = fingerprint.search();
  if(ret){
    /*设置指纹灯环为绿色常亮*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDGreen, /*blinkCount = */0);
    fingerprint.delFingerprint(ret);
    Serial.print("已删除指纹,ID=");
    Serial.println(ret);
  }else{
    /*设置指纹灯环为红色常亮*/
    fingerprint.ctrlLED(/*LEDMode = */fingerprint.eKeepsOn, /*LEDColor = */fingerprint.eLEDRed, /*blinkCount = */0);
    Serial.println("匹配失败或该指纹未注册");
  }
  delay(1000);
  /*关闭指纹灯环*/
  fingerprint.ctrlLED(/*LEDMode = */fingerprint.eNormalClose, /*LEDColor = */fingerprint.eLEDBlue, /*blinkCount = */0);
}               
  • 结果

SEN0348结果6

Mind+ 上传模式编程

1、下载及安装软件。下载地址:http://mindplus.cc 详细教程:安装教程
2、切换到“上传模式”。 详细教程:Mind+基础wiki教程-上传模式编程流程
3、“扩展”中选择“主控板”中的“Arduino Uno”。用户库中搜索电容指纹识别模块加载扩展库。 详细教程:Mind+基础wiki教程-加载扩展库流程
4、进行编程,程序如下图:
5、菜单“连接设备”,“上传到设备”
6、程序上传完毕后,打开串口根据提示进行注册指纹。详细教程:Mind+基础wiki教程-串口打印

注册指纹(适用Mind+版本1.7.2 RC3及以下)

注册指纹(适用Mind+版本1.7.3 RC1及以上)

识别指纹(适用Mind+版本1.7.2 RC3及以下)

识别指纹(适用Mind+版本1.7.3 RC1及以下)

删除指纹

Mind+ Python模式编程(行空板)

Mind+Python模式为完整Python编程,因此需要能运行完整Python的主控板,此处以行空板为例说明

连接图

操作步骤

1、下载及安装官网最新软件。下载地址:https://www.mindplus.cc 详细教程:Mind+基础wiki教程-软件下载安装

2、切换到“Python模式”。“扩展”中选择“官方库”中的“行空板”和“pinpong库”中的”pinpong初始化“和“指纹传感器”。切换模式和加载库的详细操作链接

3、进行编程

4、连接行空板,程序点击运行后,可在终端查看数据。行空板官方文档-行空板快速上手教程 (unihiker.com)

样例代码1-注册指纹

图形化编程

代码编程

以pinpong库为例,行空板官方文档-行空板快速上手教程 (unihiker.com)

#  -*- coding: UTF-8 -*-

# MindPlus
# Python
from pinpong.libs.dfrobot_id809 import ID809
from pinpong.board import Board


Board().begin()
p_capfinger = ID809()
while p_capfinger.connected() == False:
	print("Communication with device failed, please check connection")
	time.sleep(1)


while True:
    ID = 0
    NUM = 0
    while not ((NUM == 3)):
        print((str("请按下手指,采集第") + str((str((NUM + 1)) + str("次指纹")))))
        if p_capfinger.collection_fingerprint(10) != p_capfinger.error:
            NUM = (NUM + 1)
            print("采集成功,请松开手指")
            while not ((not p_capfinger.detect_finger())):
                pass
        else:
            print("采集失败,请松开手指")
            while not ((not p_capfinger.detect_finger())):
                pass
    ID = p_capfinger.get_empty_id()
    if p_capfinger.store_fingerprint(ID) != p_capfinger.error:
        p_capfinger.ctrl_led(p_capfinger.fast_blink, p_capfinger.green, 2)
        print((str("注册成功ID=") + str(ID)))
    else:
        p_capfinger.ctrl_led(p_capfinger.fast_blink, p_capfinger.red, 2)
        print("注册失败")

样例代码2-识别指纹

图形化编程

代码编程

#  -*- coding: UTF-8 -*-

# MindPlus
# Python
from pinpong.libs.dfrobot_id809 import ID809
from pinpong.board import Board
import time


Board().begin()
p_capfinger = ID809()
while p_capfinger.connected() == False:
	print("Communication with device failed, please check connection")
	time.sleep(1)


while True:
    ID = 0
    p_capfinger.ctrl_led(p_capfinger.breathing, p_capfinger.yellow, 1)
    if p_capfinger.detect_finger():
        if p_capfinger.collection_fingerprint(10) != p_capfinger.error:
            p_capfinger.ctrl_led(p_capfinger.fast_blink, p_capfinger.blue, 1)
            print("采集成功")
            ID = p_capfinger.search()
            if (ID > 0):
                p_capfinger.ctrl_led(p_capfinger.fast_blink, p_capfinger.green, 1)
                print((str("匹配成功,ID=") + str(ID)))
                time.sleep(0.5)
            else:
                p_capfinger.ctrl_led(p_capfinger.fast_blink, p_capfinger.red, 1)
                print("匹配失败")
                time.sleep(0.5)
        else:
            p_capfinger.ctrl_led(p_capfinger.fast_blink, p_capfinger.red, 1)
            print("采集失败")
            time.sleep(0.5)

样例代码3-删除指纹

图形化编程

代码编程

#  -*- coding: UTF-8 -*-

# MindPlus
# Python
from pinpong.libs.dfrobot_id809 import ID809
from pinpong.board import Board


Board().begin()
p_capfinger = ID809()
while p_capfinger.connected() == False:
	print("Communication with device failed, please check connection")
	time.sleep(1)

p_capfinger.ctrl_led(p_capfinger.breathing, p_capfinger.red, 1)
p_capfinger.del_fingerprint(p_capfinger.DELALL)

常见问题

还没有客户对此产品有任何问题,欢迎通过qq或者论坛联系我们!

更多问题及有趣的应用,可以 访问论坛 进行查阅或发帖。

更多

DFshopping_car1.png DFRobot商城购买链接