/Arduino-Aime-Reader

使用 Arduino 制作的 Aime 兼容读卡器。

Primary LanguageC

Arduino-Aime-Reader

使用 Arduino + PN532 + WS2812B 制作的 Aime 兼容读卡器。
支持 FeliCa(Amusement IC、Suica、八达通等)和 MIFARE(Aime,Banapassport)。
实现逻辑为官方读卡器串口数据对比 + 脑补,不保证正确实现。
通信数据格式参考了 Segatools 和官方读卡器抓包数据,可在 Example.txtnfc.txt 查看。

使用方法:

  1. 按照 PN532 的提示安装库;
  2. Arduino 和 PN532 接好 VCC,GND,SDA,SCL;
  3. PN532 的拨码开关按照 PCB 上丝印的指示,调整到 I2C 模式;
  4. 接上 WS2812B 灯条(可选);
  5. 上传 ReaderTest 测试硬件是否工作正常;
  6. 若读卡正常,可按照支持列表打开设备管理器设置 COM 端口号后,按照游戏的波特率设置代码的high_baudrate选项;
  7. 上传程序打开游戏测试。

某些 Arduino 可能需要在游戏主程序连接前给串口以正确的波特率发送 DTR/RTS,需要先打开一次 Arduino 串口监视器再启动主程序。
如果是 SDBT,可以在启动前运行一次 DTR-RTS.exe 以向 COM1 和 COM12 发送DTR/RTS。
如果需要向其他端口和特定的波特率发送,可以修改 DTR-RTS.c 然后编译。

支持列表:

  • SDBT:COM12,支持读取 FeliCa 和 MIFARE
  • SDDT/SDEZ:COM1,支持读取 FeliCa 和 MIFARE
  • SBZV/SDDF:COM10,支持读取 FeliCa 和 MIFARE
  • SDEY:COM2,仅支持读取 MIFARE
  • SDHD:COM4,支持读取 FeliCa 和 MIFARE

有使用 amdaemon 的,可以参考 config_common.json 内 aime > unit > port,high_baudrate 来确定 COM 号和波特率。

已测试开发板:

  • SparkFun Pro Micro(ATmega32U4),需要发送 DTR/RTS
  • SparkFun SAMD21 Dev Breakout(ATSAMD21G18)
  • NodeMCU 1.0(ESP-12E + CP2102 & CH340),SDA=D2,SCL=D1

已知问题:

  • Felica 在非 amdaemon 游戏可能无法正常工作,因为 NDA_06 未正确回复
  • 未确定res.status的意义,因此res.status = 1;可能是错误的
  • 因为get_fwget_hw返回的是自定义版本号,启动时可能触发 amdaemon 的固件升级,可以将 aime_firm 文件夹重命名或删除
  • 未实现mifare_select_tag,未支持多卡选择,只会读到最先识别的卡片

引用库: