Seeed Studio XIAO ESP32C3 入门指南

介绍
Seeed Studio XIAO ESP32C3 是一款基于乐鑫 ESP32-C3 WiFi/蓝牙双模芯片的物联网迷你开发板,采用 32位 RISC-V CPU,凭借其高效的架构提供强大的计算性能。它具有出色的射频性能,支持 IEEE 802.11 b/g/n WiFi 和 蓝牙 5 (BLE) 协议。该开发板包含一个外置天线,可增强无线应用的信号强度。它还具有 小巧精致的外形 和 单面表贴设计。配备丰富的接口,拥有 11个数字I/O 可用作 PWM引脚 和 4个模拟I/O 可用作 ADC引脚。支持四种串行接口,如 UART、I2C和SPI。板上还有一个小的 复位按钮 和一个 引导加载程序模式按钮。XIAO ESP32C3 完全兼容 Grove Shield for Seeeduino XIAO 和 Seeeduino XIAO Expansion board,但对于 Seeeduino XIAO 扩展板,板上的 SWD 弹簧触点将不兼容。
基于上述突出特性,XIAO ESP32C3 定位为 高性能、低功耗、高性价比的物联网迷你开发板,适用于 低功耗物联网应用和无线可穿戴应用。
本wiki将向您展示如何快速开始使用XIAO ESP32C3!
规格参数
项目 | Seeed Studio XIAO ESP32C3 | Seeeduino XIAO | Seeed XIAO RP2040 | Seeed XIAO nRF52840 | Seeed XIAO nRF52840 Sense |
---|---|---|---|---|---|
处理器 | ESP32-C3 32位 RISC-V @160MHz | SAMD21 M0+@48MHz | RP2040 双核 M0+@133Mhz | nRF52840 M4F@64MHz | nRF52840 M4F@64MHz |
无线连接 | WiFi 和蓝牙 5 (BLE) | N/A | N/A | 蓝牙 5.0/BLE/NFC | 蓝牙 5.0/BLE/NFC |
内存 | 400KB SRAM,4MB 板载闪存 | 32KB SRAM 256KB FLASH | 264KB SRAM 2MB 板载闪存 | 256KB RAM,1MB Flash 2MB 板载闪存 | 256KB RAM,1MB Flash 2MB 板载闪存 |
内置传感器 | N/A | N/A | N/A | N/A | 6轴IMU (LSM6DS3TR-C),PDM 麦克风 |
接口 | I2C/UART/SPI | I2C/UART/SPI | I2C/UART/SPI | I2C/UART/SPI | I2C/UART/SPI |
PWM/模拟引脚 | 11/4 | 11/11 | 11/4 | 11/6 | 11/6 |
板载按钮 | 复位/启动按钮 | N/A | 复位/启动按钮 | 复位按钮 | 复位按钮 |
板载LED | 充电LED | N/A | 全彩RGB/三合一LED | 三合一LED/充电LED | 三合一LED/充电LED |
电池充电芯片 | ETA4054S2F | N/A | N/A | BQ25101 | BQ25101 |
编程语言 | Arduino/MicroPython | Arduino/CircuitPython | Arduino/MicroPython/CircuitPython |
特性
- 强大的CPU: ESP32-C3,32位RISC-V单核处理器,运行频率高达160 MHz
- 完整的Wi-Fi子系统: 符合IEEE 802.11b/g/n协议,支持Station模式、SoftAP模式、SoftAP + Station模式和混杂模式
- 蓝牙LE子系统: 支持蓝牙5和蓝牙mesh功能
- 超低功耗: 深度睡眠功耗约43μA
- 更好的射频性能: 包含外置射频天线
- 电池充电芯片: 支持锂电池充放电管理
- 丰富的片上资源: 400KB SRAM和4MB板载闪存
- 超小尺寸: 拇指大小(21x17.8mm) XIAO系列经典外形,适用于可穿戴设备和小型项目
- 可靠的安全功能: 支持AES-128/256、Hash、RSA、HMAC、数字签名和安全启动的加密硬件加速器
- 丰富的接口: 1个I2C、1个SPI、2个UART、11个GPIO(PWM)、4个ADC、1个JTAG焊盘接口
- 单面元件,表贴设计
硬件概述
*A3(GP105) - 使用 ADC2,可能由于错误的采样信号而失效。为了可靠的模拟读取,请使用 ADC1(A0/A1/A2)。请参考 ESP32-C3 数据手册。
XIAO ESP32C3 正面指示图 |
---|
![]() |
XIAO ESP32C3 背面指示图 |
![]() |
XIAO ESP32C3 引脚列表 |
![]() |
电源引脚
- 5V - 这是来自 USB 端口的 5v 输出。您也可以将其用作电压输入,但必须在外部电源和此引脚之间使用某种二极管(肖特基、信号、功率),阳极连接电池,阴极连接 5V 引脚。
- 3V3 - 这是板载稳压器的稳压输出。您可以提取 700mA
- GND - 电源/数据/信号地
启动引脚
根据 ESP32C3 的芯片手册,芯片中的 GPIO2、GPIO8 和 GPIO9 是启动引脚,这些引脚的高低电平配置可能使芯片进入不同的启动模式,使用这些引脚时请注意这一点,否则可能会阻止您的 XIAO 一直上传或执行程序。

开始使用
首先,我们将把 XIAO ESP32C3 连接到计算机,将 LED 连接到开发板,并从 Arduino IDE 上传一个简单的代码,通过闪烁连接的 LED 来检查开发板是否正常工作。
硬件准备
您需要准备以下物品:
- 1 x Seeed Studio XIAO ESP32C3
- 1 x 计算机
- 1 x USB Type-C 数据线
某些 USB 数据线只能供电而无法传输数据。如果您没有 USB 数据线或不确定您的 USB 数据线是否可以传输数据,您可以查看 Seeed USB Type-C support USB 3.1。
- 步骤 1. 通过 USB Type-C 数据线将 XIAO ESP32C3 连接到您的计算机。

- 步骤 2. 按如下方式将 LED 连接到 D10 引脚

注意: 确保串联连接一个电阻(约 150Ω)来限制通过 LED 的电流,防止过大的电流烧坏 LED
软件准备
- 步骤 1. 根据您的操作系统下载并安装最新版本的 Arduino IDE
-
步骤 2. 启动 Arduino 应用程序
-
步骤 3. 将 ESP32 开发板包添加到您的 Arduino IDE
导航到 File > Preferences,并在 "Additional Boards Manager URLs" 中填入以下网址: https://jihulab.com/esp-mirror/espressif/arduino-esp32.git

导航到 Tools > Board > Boards Manager...,在搜索框中输入关键词 "esp32",选择最新版本的 esp32,然后安装它。

- 步骤 4. 选择您的开发板和端口
开发板
导航到 Tools > Board > ESP32 Arduino 并选择 "XIAO_ESP32C3"。开发板列表有点长,您需要滚动到底部才能找到它。

端口
导航到 Tools > Port 并选择已连接的 XIAO ESP32C3 的串口名称。这通常是 COM3 或更高(COM1 和 COM2 通常保留给硬件串口)。
运行您的第一个闪烁程序
- 步骤 1. 将以下代码复制到 Arduino IDE
确保您的 D10
按照上图所示连接到 LED。
// define led according to pin diagram in article
const int led = D10; // there is no LED_BUILTIN available for the XIAO ESP32C3.
void setup() {
// initialize digital pin led as an output
pinMode(led, OUTPUT);
}
void loop() {
digitalWrite(led, HIGH); // turn the LED on
delay(1000); // wait for a second
digitalWrite(led, LOW); // turn the LED off
delay(1000); // wait for a second
}
- 步骤 2. 点击 Upload 按钮将代码上传到开发板

上传完成后,您将看到连接的 LED 以每次闪烁间隔 1 秒的频率闪烁。这意味着连接成功,现在您可以使用 XIAO ESP32C3 探索更多项目了!
电池使用
XIAO ESP32C3 能够使用 3.7V 锂电池作为电源输入。您可以参考以下图表了解接线方法。

焊接时请小心不要短路正负极,以免烧坏电池和设备。
电池使用说明:
- 请使用符合规格的合格电池。
- 使用电池时,XIAO 可以通过数据线连接到您的计算机设备,请放心,XIAO 内置电路保护芯片,是安全的。
- XIAO ESP32C3 在电池供电时不会有任何 LED 亮起(除非您编写了特定程序),请不要通过 LED 状态来判断 XIAO ESP32C3 是否工作,请根据您的程序合理判断。
- 抱歉,我们目前无法通过软件帮助您检查剩余电池电量(因为没有更多芯片引脚可用),您需要定期给电池充电或使用万用表检查电池电量。
检查电池电压
由于 ESP32C3 引脚数量的限制,工程师为了确保 XIAO ESP32C3 具有与其他 XIAO 系列相同数量的可用 GPIO,没有额外的引脚分配给电池进行电压测量。
但如果您希望使用单独的引脚进行电池电压测量,可以参考 msfujino 的巧妙操作。我们也要特别感谢 msfujino 为 XIAO ESP32C3 分享的所有经验和努力。
基本操作思路是:电池电压通过 200k 电阻分压 1/2 并连接到 A0 端口,这样就可以监测电压。

数据手册显示标称 2500mV 满量程 AD 转换,但芯片之间存在很大差异,实际上为 ±10%。我的芯片是 2700mV 满量程。
幸运的是,每个芯片的校准修正值都写在熔丝区域,通过使用函数 analogReadMilliVolts()
,我可以读取修正后的电压值,无需做任何特殊处理。
AD 转换结果与万用表测量的电压非常吻合,误差约为 5 mV,在实际使用中没有问题。
此外,在通信过程中特别是会出现尖峰状错误,必须平均 16 次才能消除。
以下是测试电池电压的程序。
void setup() {
Serial.begin(115200);
pinMode(A0, INPUT); // ADC
}
void loop() {
uint32_t Vbatt = 0;
for(int i = 0; i < 16; i++) {
Vbatt = Vbatt + analogReadMilliVolts(A0); // ADC with correction
}
float Vbattf = 2 * Vbatt / 16 / 1000.0; // attenuation ratio 1/2, mV --> V
Serial.println(Vbattf, 3);
delay(1000);
}
以上内容来自 Seeed Studio 论坛用户 msfujino,原帖地址: https://forum.seeedstudio.com/t/battery-voltage-monitor-and-ad-conversion-for-xiao-esp32c/267535。 我们建议您在尝试基于上述方法测量电池电压之前具备良好的动手能力和更好的焊接技能,并谨慎对待电池短路等危险操作。
深度睡眠模式和唤醒
XIAO ESP32C3 设计支持深度睡眠模式和唤醒功能。对于这两个功能的使用,我们提供以下使用示例。
#define BUTTON_PIN_BITMASK 0x200000000 // 2^33 in hex
RTC_DATA_ATTR int bootCount = 0;
/*
打印ESP32从睡眠中唤醒原因的方法
*/
void print_wakeup_reason(){
esp_sleep_wakeup_cause_t wakeup_reason;
wakeup_reason = esp_sleep_get_wakeup_cause();
switch(wakeup_reason)
{
case ESP_SLEEP_WAKEUP_EXT0 : Serial.println("Wakeup caused by external signal using RTC_IO"); break;
case ESP_SLEEP_WAKEUP_EXT1 : Serial.println("Wakeup caused by external signal using RTC_CNTL"); break;
case ESP_SLEEP_WAKEUP_TIMER : Serial.println("Wakeup caused by timer"); break;
case ESP_SLEEP_WAKEUP_TOUCHPAD : Serial.println("Wakeup caused by touchpad"); break;
case ESP_SLEEP_WAKEUP_ULP : Serial.println("Wakeup caused by ULP program"); break;
default : Serial.printf("Wakeup was not caused by deep sleep: %d\n",wakeup_reason); break;
}
}
void setup(){
Serial.begin(115200);
delay(1000); //花一些时间打开串口监视器
//增加启动次数并在每次重启时打印
++bootCount;
Serial.println("Boot number: " + String(bootCount));
//打印ESP32的唤醒原因
print_wakeup_reason();
esp_deep_sleep_enable_gpio_wakeup(BIT(D1), ESP_GPIO_WAKEUP_GPIO_LOW);
//现在进入睡眠
Serial.println("Going to sleep now");
esp_deep_sleep_start();
Serial.println("This will never be printed");
}
void loop(){
//这不会被调用
}
如果您能够在XIAO进入深度睡眠之前及时打开串口监视器,那么您可以看到如下所示的消息输出。这意味着XIAO现在处于"睡眠"状态。

进入深度睡眠模式后,XIAO的端口将消失,您需要唤醒它才能再次看到其端口号!
在程序中,我们使用D1低电平来唤醒。这意味着我们可以将按钮连接到引脚D1,当我们按下按钮时XIAO将被唤醒。
目前XIAO ESP32C3仅支持GPIO唤醒,支持唤醒的引脚只有D0~D3。此程序可能在其他引脚上无法工作。
故障排除
Q1: 我的Arduino IDE在向开发板上传代码时卡住了
您可以首先尝试在开发板连接到PC时单击一次RESET按钮来重置开发板。如果这不起作用,请按住BOOT按钮,在按住BOOT按钮的同时将开发板连接到PC,然后释放它以进入引导加载程序模式。
Q2: 我的开发板在Arduino IDE中没有显示为串行设备
按照上面Q1的相同答案。
Q3: 我想用出厂固件重新刷写引导加载程序
您可以简单地通过USB Type-C将开发板连接到PC,并使用ESP RF Test Tool用出厂固件重新刷写引导加载程序。
-
步骤1. 按住BOOT按钮并将XIAO ESP32C3连接到PC以进入引导加载程序模式
-
步骤2. 连接后,释放BOOT按钮
-
步骤3. 访问此页面并下载ESP RF Test Tool and Test Guide

- 步骤4. 解压**.zip文件,导航到
ESP_RF_Test_EN\ESP_RF_Test_EN\EspRFTestTool_v2.8_Manual
并打开EspRFTestTool_v2.8_Manual.exe**

- 步骤5. 选择ESP32C3作为ChipType,您的COM端口,115200作为BaudRate并点击open

您将看到以下输出

- 步骤6. 选择Flash并点击Select Bin

-
步骤7. 下载XIAO ESP32C3的出厂固件并选择它。
-
步骤8. 最后点击Load Bin

刷写成功时您将看到以下输出

MicroPython GitHub 仓库
资源
-
📄**[PDF]** ESP32C3 数据手册
-
📄 [PDF] Seeed Studio XIAO ESP32C3 原理图
-
🗃️ [ZIP] Seeed Studio XIAO ESP32C3 KiCAD 库
-
🗃️ [ZIP] Seeed Studio XIAO ESP32C3 Eagle 库
-
🗃️ [ZIP] Seeed Studio XIAO ESP32C3 出厂固件
-
📄 [XLSX] Seeed Studio XIAO ESP32C3 引脚图表
-
🔗 [STEP] Seeed Studio XIAO ESP32C3 3D 模型
-
🔗 [GitHub] Seeed Studio XIAO ESP32C3 MicroPython 库
-
🔗 [WiKi] Seeed Studio XIAO ESP32C3 初探 XIAO ESP32C3 的精彩介绍,涵盖关键特性和基本用法。
-
📚 [电子书] XIAO: 大功率,小板子 掌握 Arduino 和 TinyML 在 XIAO 板上掌握 Arduino 和 TinyML 的优秀指南。
-
🔗 [Kicad] Seeed Studio XIAO ESP32C3 封装
课程资源

技术支持与产品讨论
感谢您选择我们的产品!我们在这里为您提供不同的支持,以确保您使用我们产品的体验尽可能顺畅。我们提供多种沟通渠道,以满足不同的偏好和需求。