CardReader
一个为 SEGA/Bemani 街机音游设计的、可以兼容任何 NFC 卡的读卡器固件!(这样就可以用学生卡公交卡登录了!)
How it works / 实现方式
其实强制支持不同 NFC 卡的方式非常简单。因为 SEGA/Bemani 的游戏都是直接读了 Felica IDm 序列号发给服务器,所以如果想要让其他非 Felica 卡兼容的话,只需要把序列号转换成 Felica 的格式就可以了。具体的话,就是把 ID 垫零变成 8 字节,然后把前两个字节改成 0x01 0x2E 就可以了。
Usage / 使用方法:
制作与固件烧录
- 买一块 ESP32 开发板、一块 PN532 NFC 模块(我是直接买了红月的 PCB ¥109,看起来好看一点还有 RGB 灯)
- 把这个仓库 clone 下来
- 下载 PlatformIO Core,在 PlatformIO Boards 里面找到你的型号,然后编辑
platformio.ini里面的board字段 - 把 PN532 模块的 I2C_SDA、I2C_SCL、GND、VCC 连接到 ESP32 开发板上
- 如果有 RGB 灯的话在
src/main.cpp里面改一下setup()里面的 LED 引脚 pio run -t upload -t monitor烧录之后测试
与音游连接
- 如果你想玩 SEGA 的游戏,编辑 segatools.ini, 把设置改成如下:
[aime]
enable = 1
felicaPath = C:\MUGS\felica.txt # 这里改成一个固定的 Felica.txt 路径, 所有游戏共享
felicaGen = 0
scan = 0x6B
- 如果你想玩 Bemani 的游戏,在 Spice2x 里面设置 Felica.txt 路径,然后把 Insert Card 按钮映射成 "Naive" 0x6B (小键盘 +) 按键即可
- 下载 Python, 安装
pip install pyserial,然后运行python receiver.py,这样接上读卡器之后就可以自动转存卡片然后自动按下 Insert Card 按钮了
FAQ / 常见问题:
Q: 为什么不用红月的 PCB 自带的 ESP32-CardReader 固件?
A: 因为那个固件的目的是尽量还原原生街机的读卡器接口,所以只支持官方卡。而且切换 SEGA / Bemani 模式的时候需要开盖、按住按钮重启,非常麻烦。
Dependencies / 依赖:
- PN532 Library: https://github.com/Seeed-Studio/PN532
- FastLED: https://github.com/FastLED/FastLED

