基于VSCode + PlatformIO创建运行第一个esp32程序

本文详细指导了如何使用VSCode创建ESP32项目,安装驱动,以及编写和烧录程序点亮LED灯的过程,包括驱动下载、设备识别和Arduino框架的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在之前的课程,我们已经介绍了ESP32单片机,并且也已经安装好了开发环境,从这节课开始,我们将正式步入ESP32的实战开发中来。

说到单片机开发,开篇一定离不开点亮LED灯,我们也不例外,接下来,我们一起写代码点亮ESP32开发板上的板载LED灯

使用VSCode创建项目

打开VSCode,点击左边的蚂蚁头图标,然后在PROJECT TASKS类目中,点击Create New Project,再点击Quick Access上的New Project,在Project Wizard中,填写规则如下:

  • Name填写自己的项目名称,自行定义(不建议起中文名称),比如esp32-demo1
  • Borad中搜索ESP32 DEV,然后选择Espressif ESP32 Dev Module,这是我们ESP32开发板对应的Board类型,一定要选择正确
  • Framework选择Arduino,表示我们是基于Arduino框架进行开发
  • Location可以勾选Use default location,表示将项目存方法在默认目录(鼠标悬浮在旁边的问号,可看到项目默认存放路径);或者不勾选,然后自己决定项目存放目录即可

创建项目

创建项目2

创建项目3

项目创建成功后,VSCode会弹出信任确认框,勾选信任父文件夹...,然后点击是...

信任项目目录

安装驱动

我们套件里面提供的ESP32开发板,USB转TTL的驱动芯片是CH340,所以我们需要在电脑上安装CH340的驱动(有些电脑插上开发板后会自动安装驱动),不然电脑无法识别开发板。

下载驱动

点击下方下载链接下载CH340驱动程序

点击这里下载CH340驱动程序

image-20231020204328388

安装驱动

下载完上面的驱动程序,双击打开,点击安装,等待安装完成即可

image-20231020204504731

连接开发板

拿出我们套件里面提供的ESP32开发板,使用TypeC数据线将其与电脑连接

image-20231020204732977

电脑识别开发板

连接好开发板后,点击电脑左下角开始按钮,搜索并打开设备管理器

image-20231020204852525

如果在设备管理器的端口(COM和LPT)类目下,能够看到如下图所示的设备,即表示开发板能够被电脑正确识别(设备名带有CH340标识),这里需要大家注意,设备名上的COM3就是咱们开发板的串口标识,这个标识在后续烧录程序的时候会用到。如果没看到设备列表,说明可能驱动安装有问题,请尝试卸载重装再试。

:::tip 温馨提示

如果大家使用的不是我淘宝店铺提供的配套的开发板,那驱动芯片有可能不是CH340,这种情况下需要安装对应的驱动,这里的设备名也会有区别。

:::

image-20231020204955757

编写程序

接下来复制下面提供的代码,粘贴到VSCode项目中的src/main.cpp文件,现在暂时不要关心代码逻辑是什么,原理是什么,先把流程走通,稍后讲解原理

#include <Arduino.h>

#define LED_PIN 2

void setup()
{
  pinMode(LED_PIN, OUTPUT);
}

void loop()
{
  digitalWrite(LED_PIN, HIGH);
  delay(1000);
  digitalWrite(LED_PIN, LOW);
  delay(1000);
}

image-20231020205536257

烧录程序

经过上面的步骤,一个简单的程序已经编写好了,接下来我们需要将程序(固件)上传(这个过程俗称烧录)到ESP32开发板。单片机开发和电脑程序开发有一个非常不同的点:电脑程序是在电脑上开发,电脑上运行,而单片机开发是电脑上开发,开发板上运行,所以编写好的代码需要通过数据线上传到开发板,才能运行。

第一步、编译程序

点击VSCode左下角的对钩图标,开始编译程序。编译通过则表示程序语法没问题,符合程序设计规则,如果编译失败,则需要根据提示信息进行相应的修改。

image-20231020205838227

编译成功的提示信息如下:

第二步、烧录程序

如果上一步编译成功,说明程序在语法上没问题,我们接下来就可以将程序上传到开发板。

:::tip 温馨提示

实际上,在实际的开发过程中,我们可以跳过第一步,直接执行第二步烧录程序,因为程序烧录之前会自动进行编译。

:::

先点击最下方的插头图标,点击后在最上方会出现设备列表,在这个列表中我们可以选择Auto,表示由软件自己自动化探测开发板,或者直接手动指定特定的设备,列表中的COM3就是之前在电脑设备管理器上看到的串口名称。

image-20231020210359357

开发板设备指定完成之后,点击最下方向右的箭头,表示开始烧录程序

image-20231020210713074

第三步、开发板观察效果

代码上传完成之后,会在开发板上自动运行(无需像电脑程序一样手动启动程序,因为单片机上只有一份程序,通电即自动运行),大家可以观察开发板上蓝色LED灯的效果(效果是点亮一秒,熄灭一秒,如此往复,这就是上面程序的最终效果)

image-20231020211041422

至此,恭喜大家已经打开单片机开发世界的大门,一个完整的基于Arduino框架的ESP32开发板的单片机程序就已经开发上传完毕。

原理讲解

虽然上面的流程我们已经跑通,最终实际效果也出来了,但是可能部分同学还是不明所以然,接下来我们讲解程序逻辑和原理

image-20231020211440097

  • 第1行:通过#include指令引入Arduino开发框架的基础头文件,因为我们的程序是基于Arduino框架开发,所以必须依赖Arduino.h提供的相关类库,不引入则后面的代码将报错,无法编译通过;
  • 第3行:通过#define宏定义指令定义一个常量,常量名称为LED_PIN,实际的值为2,用来表示我们开发板上蓝色LED灯关联的GPIO引脚,这个引脚2是开发板指定(看开发板上LED灯旁边标有D2字样,表示该板载LED灯由2号引脚控制,引脚输出高电平,LED点亮,引脚输出低电平,LED熄灭)的,并非我们随意写;
  • 第5行~第8行:这是setup函数的逻辑,其中的pinMode函数这一行,表示将2号引脚的工作模式设置为输出模式,只有开发板引脚设置为输出模式,才能控制外部设备的运行;
  • 第10行~第16行:这是loop函数的逻辑,首先通过digitalWrite函数向2号引脚输出高电平,然后调用delay函数延迟1000毫秒,随后再向2号引脚输出低电平,最后再延迟1000毫秒
  • setup函数的作用是初始化,该函数只会在单片机通电的时候执行一次,该函数执行完毕之后,会无限循环执行loop函数中的逻辑。

上面是程序的基本逻辑,更详细的介绍,下一节细说。

项目源码

本节课源码地址:点击这里访问

感谢阅读,对物联网或者电子DIY感兴趣的,欢迎关注公众号【微联实验室】获取免费视频/文档资料

<think>好的,用户想了解如何在VSCode中使用PlatformIO为ESP-WROOM-32核心板创建新工程。我需要一步步引导他们完成整个过程,确保每个环节都清晰易懂。 首先,用户可能已经安装了VSCode,但可能需要确认是否安装了PlatformIO插件。我应该先提安装步骤,避免他们卡在第一步。然后,创建新项目时要选择合适的开发板型号,比如ESP32 Dev Module,这对应ESP-WROOM-32。需要提醒他们注意选择正确的框架,通常是Arduino或ESP-IDF,这里用户可能更熟悉Arduino,所以默认选Arduino比较合适。 接下来,项目结构需要解释清楚,src目录放主代码,platformio.ini是配置文件。用户可能需要修改配置文件,比如调整串口波特率或添加库依赖,这部分需要详细说明。例如,添加特定的库名称,或者如何设置调试选项。 然后,编写示例代码,比如一个简单的Blink程序,要确保他们知道如何修改引脚,因为ESP32的LED可能不在D13,需要查证正确的GPIO引脚,比如GPIO2。代码结构要完整,包括setup和loop函数。 编译和上传步骤可能会有问题,比如端口选择错误或驱动问题。需要提醒他们在上传前确保正确选择端口,并安装必要的CP210x或CH340驱动。如果遇到错误,建议检查连接和配置。 最后,测试和扩展部分,建议他们通过串口监视器查看输出,或者扩展其他功能如WiFi。可能还需要提到常见问题,比如项目创建失败时的解决方法,比如检查网络或重新安装插件。 需要保持语言简洁,步骤明确,避免专业术语过多,适合新手理解。同时,预测他们可能遇到的困难,提前给出解决方案,比如驱动安装或配置修改。整个过程要逻辑清晰,逐步推进,确保用户能顺利创建运行第一个项目。</think>以下是使用 VSCode + PlatformIO 进行 ESP-WROOM-32 核心板开发的工程创建步骤: --- ### 一、环境准备 1. 安装 **VSCode**(官网下载) 2. 在 VSCode 扩展商店搜索安装 **PlatformIO IDE** --- ### 二、创建新工程 1. **打开 PlatformIO 主页** 左侧工具栏点击 🏠 图标 > 选择 "Create New Project" 2. **工程配置** - **Name**: 输入项目名称(如 `ESP32_Demo`) - **Board**: 搜索并选择 `ESP32 Dev Module`(ESP-WROOM-32 通用选择) - **Framework**: 选择 `Arduino`(推荐新手)或 `ESP-IDF`(高级开发) - **Location**: 选择项目保存路径 - 点击 **Finish** --- ### 三、工程结构说明 创建成功后会自动生成以下文件: ``` ├── include # 头文件目录 ├── lib # 第三方库目录 ├── src # 主代码目录 │ └── main.cpp # 主程序入口 └── platformio.ini # 项目配置文件 ``` --- ### 四、配置 ESP32 参数(关键步骤) 1. 打开 **platformio.ini** 文件 2. 修改为以下配置(基础模板): ```ini [env:esp32dev] platform = espressif32 board = esp32dev framework = arduino monitor_speed = 115200 ; 串口监视器波特率 ; 可选高级配置 ; upload_port = COMx ; 手动指定串口端口 ; lib_deps = ; 添加依赖库 ; adafruit/Adafruit SSD1306@^2.5.7 ``` --- ### 五、编写示例代码 1. 打开 `src/main.cpp` 2. 输入以下 LED 闪烁测试代码: ```cpp #include <Arduino.h> #define LED_PIN 2 // ESP-WROOM-32 板载LED通常接GPIO2 void setup() { pinMode(LED_PIN, OUTPUT); } void loop() { digitalWrite(LED_PIN, HIGH); delay(500); digitalWrite(LED_PIN, LOW); delay(500); } ``` --- ### 六、编译与上传 1. 底部状态栏点击 ✔️ 图标进行编译 2. 使用 🔌 图标连接开发板到电脑 3. 点击 ➡️ 图标上传程序 4. 观察板载LED是否开始闪烁 --- ### 七、常见问题处理 1. **端口识别失败**: - 安装 CP210x 或 CH340 驱动 - 在 `platformio.ini` 中添加 `upload_port = COMx`(Windows)或 `/dev/cu.usbserial-xxx`(Mac) 2. **库依赖问题**: - 通过 PlatformIO 的 Library Manager 搜索安装所需库 - 或在 `lib_deps` 中指定库名称 --- ### 八、进阶操作 - 按 `Ctrl+Alt+S` 打开串口监视器 - 使用 PlatformIO 的单元测试功能 - 添加 WiFi/BLE 功能示例: ```cpp #include <WiFi.h> void setup(){ Serial.begin(115200); WiFi.begin("SSID", "password"); while(WiFi.status() != WL_CONNECTED){ delay(500); Serial.print("."); } Serial.println("\nConnected!"); } ``` --- 通过以上步骤即可快速开始 ESP-WROOM-32 的开发PlatformIO 会自动处理工具链配置,无需手动设置 Arduino IDE 的板卡支持包。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值