ESP-IDF + Vscode ESP32 开发环境搭建以及开发入门

这篇具有很好参考价值的文章主要介绍了ESP-IDF + Vscode ESP32 开发环境搭建以及开发入门。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

ESP-IDF + Vscode ESP32 开发环境搭建以及开发入门

创作不易,转载请注明出处!

Tips: 虽然笔者采用的是Linux开发环境,但是Windows开发环境的亦可阅读,所述内容与系统关联性不大,尤其是后文介绍的如何将自己的文件加入到工程,解决头文件找不到等问题,无论哪种系统均会存在。

Tips: 最近更新了一篇windows下搭建的,大家可以两篇结合起来参考学习 (点击跳转)ESP-IDF + (PowerShell / Vscode) ESP32开发环境搭建(windows)(点击跳转)

1. 前言

关于ESP32的开关环境搭建,其实有很多种,其中如果使用 Vscode 的话,通常大家会直接使用vscode里面的Espressif IDF插件,然后通过插件安装对应的配置工具搭建开发环境,使用此方法确实比较方便,操作也比较简单,但是此方法存在一定的缺陷,使用此方法搭建的环境不方便维护,ESP-IDF的版本升级切换不方便

使用 Espressif IDF 安装环境,在 ESP-IDF 目录下除了存放了 ESP-IDF 工具以外,编译工具链也丢在了这个里面(在IDF目录下使用git查看执行 git status 即可发现),两种文件混合在了一起,会导致无法单独维护,当想要升级ESP-IDF版本的时候,就必须要把环境全部重新安装一遍,而安装的时候下载又特别慢,所以这个过程会变为一个非常麻烦的事情

本文采用的方法称之为:ESP-IDF + Vscode开发方法,此方法成功的将 ESP-IDF 工具与编译工具分离,因此可以单独维护,关于ESP-IDF的版本切换可直接使用git切换即可,十分的方便,同时编辑器还是采用Vscode,编写代码还是很方便

此外,本文除了阐述如何搭建开发环境之外,还记载了博主关于ESP32开发过程中的相关笔记,主要介绍了如何采用ESP32的开发风格开始搭建我们自己的工程进行开发。

tips: 推荐使用最新发布版本的 ESP-IDF,最新的修复了许多有关问题!!! 踩过的坑就不要踩了 T…T

2. 下载开发工具

  1. 下载 IDF 工具
    mkdir -p ~/esp
    cd ~/esp
    git clone --recursive https://github.com/espressif/esp-idf.git
    
  2. 下载 Vscode 软件
  3. 安装Vscode插件 Espressif IDF,注意这里下载好就行了,不要去配置
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

3. 配置工具

  1. 配置 IDF 工具,为所有ESP32设备环境
    cd ~/esp/esp-idf
    ./install.sh
    
  2. 设置环境变量
    cd ~/esp/esp-idf
    ./export.sh
    
  3. 但是每个terminator窗口都得像第2步一样运行下export.sh指令,对应的命令窗口才有相应的idf环境变量,非常麻烦,因此需要让其智能一点,在 ~/.bashrc 里面加一个宏命令
    • 运行vi ~/.bashrc,打开 ~/.bashrc ,在最后添加一行命令 alias get_idf='. $HOME/esp/esp-idf/export.sh'
    • 之后每次打开一个新terminator窗口,只需要输入 get_idf 命令,即可给对应的 terminator 添加 IDF 的环境变量esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

4. 创建工程

  1. 使用 idf 工具创建工程
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

  2. 进入工程目录,设置目标设备,如开发esp32,则输入idf.py set-target esp32
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

  3. 使用vscode打开编辑
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

5. 解决vscode找不到头文件,波浪线警告

问题描述:

默认使用IDF创建工程之后,可使用 idf.py build编译工程,但是使用vscode打开工程,添加头文件之后,vscode会提示找不到头文件,以及相应宏、函数无法跳转,这是由于vscode没有配置导致
esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

解决方案:

  1. 安装 Espressif IDF 插件
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
  2. 进入IDF目录,重新运行 install.sh 脚本,此脚本会配置 Espressif IDF 插件(建议这么操作,因为我运行 ./install.sh 的时候插件是以及装好了的)
    cd ~/esp/esp-idf
    ./install.sh
    
  3. 使用vscode打开相应工程, 注意vscode打开的是对应的工程路径,而不是包含多个工程的路径
  4. 按快捷键 Ctrl + Shift + P 打开命令行, 找到 ESP-IDF:Add vscode configuration folder,点击一下即可自动生成对应的vscode配置文件
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
  5. 点击之后可以看到工程目录下多了一个 .vscode 目录,并产生了相应的文件,其中c_cpp_properties.json 内描述的就是对应的头文件路径
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
  6. 之后可以看到波浪线警告消失了,对应的文件也可以通过 ctrl+鼠标左键 打开esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

6. 添加自己的组件

说明:本博客ESP-IDF版本 V5.0

6.1 组件说明

当我们开始真正使用ESP32进行开发的时候,我们肯定期望将我们的程序按照各自的功能,分解成各自的 .c 文件,这样方便编辑、管理和移植,如GPIO的驱动在单独编写的 drv_gpio.c 内实现,那么针对ESP32如何实现类似的功能呢?

之前编写 stm32 的时候有IDE的支持,IDE自动帮我们完成,但是这里Vscode仅仅只是一个代码编辑器,关于代码的编译,esp32采用的是Cmake工具来完成, 因此我们需要补充相关的cmake文件来实现。

ESP32的组件分为几大类,均记录在cmake的变量COMPONENT_DIRS内:

  • ESP-IDF内部组件 IDF_PATH/components
  • 扩展组件 EXTRA_COMPONENT_DIRS
  • 项目组件 PROJECT_DIR/components

ESP-IDF内部组件:也就是官方提供的组件,在ESP-IDF目录内
扩展组件:工程目录一般长这样

- myProject/
             - CMakeLists.txt
             - sdkconfig
             - components/ - component1/ - CMakeLists.txt
                                         - Kconfig
                                         - src1.c
                           - component2/ - CMakeLists.txt
                                         - Kconfig
                                         - src1.c
                                         - include/ - component2.h
             - main/       - CMakeLists.txt
                           - src1.c
                           - src2.c

             - build/

官方文档是这么解释的:可选的 “components” 目录中包含了项目的部分自定义组件,并不是每个项目都需要这种自定义组件,但它有助于构建可复用的代码或者导入第三方(不属于 ESP-IDF)的组件。或者,您也可以在顶层 CMakeLists.txt 中设置 EXTRA_COMPONENT_DIRS 变量以查找其他指定位置处的组件。

因此扩展组件是我们自行添加的目录,之后通过在顶层CMakeLists.txt中设置 EXTRA_COMPONENT_DIRS变量指定对应的位置;
项目组件是工程目录下components目录下的组件,默认没有这个目录,可自行创建

需要注意的是,各组件不同同名,否则会发生覆盖,组件的编译顺序为 ESP-IDF内部组件 -> 扩展组件 -> 项目组件,后编译的组件会覆盖之前编译的同名组件,(此特点也有优点:允许将组件复制到项目目录中再修改以覆盖ESP-IDF组件,如果使用这种方式,ESP-IDF 目录本身可以保持不变)

6.2 添加项目组件

  1. 创建 components 目录
  2. 创建组件
    • 方法一:使用idf命令创建组件:idf.py -C <组件集目录地址> create-component <component name>
      • esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
    • 方法二:创建对应的目录并创建对应的源文件,复制其他组件的CMakeLists.txt文件
  3. 在组件内编写对应的程序即可
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
  4. 清除工程,之后重新编译 idf.py clean -> idf.py build
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

6.3 添加扩展组件

一定注意创建的组件名,不要和系统组件名相同,否则会覆盖造成报错,除非你主动为之,可通过搜索 COMPONENT_DIRS 中的目录列表以查找项目的组件(搜索方法:在CmakeList.txt中把这个变量打印出来)

  1. 创建自己存放组件集的组件目录,之后在组件目录下创建组件,不能直接创建组件目录,如这里创建组件集目录user,在user目录下创建gpio驱动组件目录gpio
  2. 复制其他组件的CMakeLists.txt
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
  3. 修改组件目录内的CMakeLists.txt
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
  4. 修改顶层CMakeLists.txt,添加EXTRA_COMPONENT_DIRS指定,注意此添加需要在project()之前,因为执行project指令的时候已经创建工程了
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
  5. 编写对应的drv_gpio.c drv_gpio.h,并在main.c中引用,之后编译测试**(先清除工程,之后重新编译 idf.py clean -> idf.py build)**
    esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
    编译测试成功esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF

7. 解决组件内引用 ESP-IDF 内函数、头文件报错

当我们创建好单独的组件后,将在单独的组件内编写各自的应用,如上,我们创建了 gpio 组件,那么相应将会在gpio组件中编写对应的gpio驱动,驱动中肯定会要应用ESP-IDF内的组件,但是当我们编译的时候会提示找不到相应文件。

我们的驱动程序如下:
esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
编译报错:../user/gpio/drv_gpio.c:2:10: fatal error: driver/gpio.h: No such file or directory

这是由于依赖问题没有解决导致,我们编写的drv_gpio.c文件没有指定依赖,那么编译器将不知道去哪里找这个driver/gpio.h文件,因此报错,所以我们需要给它加上依赖,修改对应组件的CMakeLists.txt文件,增加 REQUIRES driver 指定依赖driver组件:
esp32 idf vscode,物联网 ESP32,vscode,git,ESP32,IDF,ESP-IDF
那么有人肯定会问,为什么在默认的main组件内这么写不会报错呢?这是由于main组件是一个特殊组件,工程的$ENV{IDF_PATH}/tools/cmake/project.cmake 默认为其添加了所有依赖

注意修改CMakeLists.txt后清除工程再重新编译 idf.py clean -> idf.py build


创作不易,转载请注明出处!

关注、点赞+收藏,可快速查收博主有关分享!文章来源地址https://www.toymoban.com/news/detail-785856.html


到了这里,关于ESP-IDF + Vscode ESP32 开发环境搭建以及开发入门的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ESP32开发环境搭建Windows VSCode集成Espressif IDF插件ESP32_IDF_V5.0开发编译环境搭建

    下载网址:https://dl.espressif.com/dl/esp-idf/ 打开上面的网页,选择单击页面中 ESP32-IDF v5.0.2 - Offine Installer,5.0.2是当前最新版本,如果没有ESP32-IDF v5.0.2 - Offine Installer,说明官方有更新最新版本,如果想要安装此教程版本可以把页面翻到最下面,会列出所有历史版本供用户下载。

    2024年02月13日
    浏览(58)
  • VSCode安装Esp-IDF开发环境(pip version)出错解决办法

    可以看出是 pip版本问题 ,所以只需要在安装程序使用pip命令之前,完成pip的升级即可。 好像下载4点几的版本会出现此警告,导致安装失败;而下面安装5.0.1版本的时候同样出现了此警告,但是能够安装成功。 在VSCode扩展中找到Esp-IDF插件,点击卸载按钮。 注意:此时并没有

    2024年02月08日
    浏览(68)
  • 使用一键安装工具快速搭建 ESP-IDF 开发环境 (Windows)

    我们收到用户对 ESP-IDF SDK 软件开发环境感到搭建难、门槛高的反馈。为解决用户在此方面的问题。为此,我们推出本期教程介绍在 Windows 操作系统下使用一键安装工具快速搭建 ESP-IDF 开发环境。 您可以观看下面的教程视频,也可以阅读接下来本篇的图文教程。 【乐鑫教程】

    2024年02月09日
    浏览(82)
  • 使用 VS Code 快速搭建 ESP-IDF 开发环境 (Windows、Linux、MacOS)

    ESP-IDF 是乐鑫官方的物联网开发框架,适用于 ESP32、ESP32-S、ESP32-C 和 ESP32-H 系列 SoC。它基于 C/C++ 语言提供了一个自给自足的 SDK,方便用户在这些平台上开发通用应用程序,并集成了大量的软件组件,包括 RTOS、外设驱动程序、网络栈、多种协议实现技术以及常见应用程序的使

    2024年02月14日
    浏览(68)
  • ESP32的ESP-IDF在VScode工程下,头文件标红警告、报错、无法跳转

    具体问题如下:在VScode环境中,通过ESP-IDF插件开发ESP32系列设备,但是工程代码中提示找不到头文件、相关的函数也无法跳转,这样不仅不美观,也一定程度上影响了开发效率,需要着手解决。 解决方法: 顺利解决的前提是要确保已经正确安装了ESP-IDF和其依赖项。 检查VS

    2024年02月19日
    浏览(63)
  • ESP-IDF开发框架添加自定义组件 ESP32-C3

    因为熟悉了STM32的开发方式,同时随着项目文件越来越多,可以将自己写的代码分模块添加到工程中,下面分析如何将自己写的组件添加到工程中使其能够正常编译运行。 在ESP-IDF中,构建,编译,以及下载都是通过idf.py脚本来实现的,该脚本使用 CMake,配置待构建的项目 N

    2024年02月02日
    浏览(63)
  • 小陈笔记(一):Vscode 安装ESP-IDF插件

            本文主要描述如何在Vscode安装esp-idf插件。同时也是记录自己在安装过程中遇到的日记。 材料:         1.Windows10专业版         2.vscode稳定版本         3.esp-idf4.4.4版         4.硬件:esp32         vscode的安装教程网上有很多优秀的例程,这里就不要一一赘述

    2024年04月22日
    浏览(54)
  • 【ESP32】Espressif-IDE及ESP-IDF安装

    1.打开ESP-IDF 编程指南 2.点击快速入门–安装–手动安装–Windows Installer–Windows Installer Download 3.点击下载Espressif-IDE 2.10.0 with ESP-IDF v5.0.2 1.双击安装 espressif-ide-setup-2.10.0-with-esp-idf-5.0.2.exe 2.点击“确定” 3.选择“我同意此协议(A)”,点击“下一步” 4.点击“下一步” 5.点击“

    2024年02月15日
    浏览(65)
  • ESP32在ESP-IDF框架下使用LVGL(v8.3)

    VSCode + ESP-IDF 插件 说明: IDF版本为4.4.4 ,最新版的5.0.1弃用了些东西,而lvgl_esp32_drivers对5以上的版本未适配,所以 不建议使用5以上的版本 。 安装:安装教程,建议整体看完在进行安装,以免安装失败, 教程安装的是5.0.1,需要改为4.4.4 。 Arduino移植教程:点击此处 lvgl :g

    2023年04月16日
    浏览(70)
  • ESP32 ESP-IDF + LVGL + SquareLine Studio 设计 UI 界面

    陈拓 2022/12/10-2022/12/12 关于SquareLine Studio,乐鑫官方的ESP技术文章有介绍: 在 ESP 开发板上开发 UI 不再复杂 - 知乎 如果您尝试过在没有图形库的情况下开发 UI,那么您一定知道这有多困难。幸运的是,由乐鑫芯片驱动的屏幕,可支持用户使用多种图形库来开发 UI, LVGL 就是其

    2024年01月19日
    浏览(62)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包