百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

VScode中集成esp8266/32开发环境详解

suiw9 2025-03-29 21:59 9 浏览 0 评论

引言

文章的起点源于一个小伙伴私信我,想了解如何在vscode中直接开发esp8266。vscode其轻便,小巧等优点越来越受各类程序员的喜爱。 前面我分别介绍了如何在Windows中使用msys32,以及在Ubuntu(linux的一种发行版)搭建esp8266的开发环境,直接基于命令行编译,配置,下载等操作,这样做的好处是避免直接基于IDE(集成开发环境)开发,IDE背后帮我们封装了很多操作,让我们无法了解其背后实现的原理和机制,比如配置文件是如何生成的,多文件是如何编译的,头文件是如何关联起来的等等问题,这就需要我们去了解工程Makefile,一步步探索其中的原理。

回到正题,接下来主要介绍如何配置使得能够在vscode中直接开发esp8266,实现代码编辑和编译下载等操作全部在vscode中完成。OK, 开始行动~

开始前工作准备

开始前需要小伙伴先搭建好esp8266/32(之后以esp8266为例子)开发环境,包括下载ESP8266_RTOS_SDK, 交叉工具链,msys32等,并设置IDF_PATH,PATH 环境变量,这里不再赘述,不熟悉的小伙伴请参考我之前的视频Windows中搭建esp8266开发环境。 当然还要下载vscode编辑器啦~,其下载安装很简单,只需要到官网下载傻瓜式安装即可。 下载后需要安装一个"C/C++"插件

配置settings.json文件

点击“文件”->"打开文件夹",打开自己的工程目录,比如我的“Humiture”

点击vscode左下方“齿轮”图标, 选择“设置”:

接着会出现“用户”, “工作区” 2种类型的设置, 其中“用户”设置相当于全局设置,如果工作区中未进行相关配置,会默认使用“用户”下的设置, 而“工作区”相当于局部设置,只作用于当前打开的工作区,这里我们选择“工作区”来介绍,无论哪种模式设置操作都是一样的,只是作用域不同而已。

点击“工作区”->"终端",点击“settings.json”:

打开“settings.json”后,将其修改成以下内容,并保存:

{
    "terminal.integrated.shell.windows": "D:\\msys32\\msys2_shell.cmd",//这里根据自己的实际路径
    "terminal.integrated.shellArgs.windows": [
        "-defterm",
        "-no-start",
        "-mingw32",
        "-here"
    ],
    "terminal.integrated.automationShell.linux": "",
    "terminal.integrated.automationShell.windows": "",
    "extensions.confirmedUriHandlerExtensionIds": [
    
    ]

}

settings.json配置

以上配置说明:

  • "terminal.integrated.shell.windows": "D:\\msys32\\msys2_shell.cmd"

----------------------是设置Windows环境集成终端,即msys32文件下的\msys2_shell.cmd

  • "terminal.integrated.shellArgs.windows": 中的参数:

"-defterm" 表示将windows中集成终端作为默认终端,即上面的msys2_shell.cmd

"-no-start" 表示当我们点击vscode下方的“终端”时,不要默认msys32终端界面(小伙伴可以去掉这个选项,自行感受下)

"-mingw32" 表示指定使用mingw32终端,因为在msys32文件中有mingw32和mingw64,而esp8266在Makefile中就指定了必须使用mingw32,否则编译会通不过,感兴趣的小伙伴自行分析下Makefile就能验证了。

"-here" 表示打开终端时,默认的路径就在工程,若不加此选项,这默认是在家目录下(~),这样方便我们直接点击vscode中的终端时,就可以直接make编译拉,不然还要cd切换目录~

  • 其他的参数,关系不大,这里就不一一说明了

验证下配置效果,点击vscode下方的信息栏,打开我们的终端:

尝试配置,编译

首先我们先尝试下配置下我们的工程,在终端输入make menuconfig命令:

发现配置失败,根据提示“Your display is too small to run Menuconfig!” , 我们知道esp8266采用kconfig(类似linux内核配置方式)图形界面配置,因此我们只需要把终端界面拖大一点,以满足能够全部显示出menuconfig界面问题就解决啦~

这里会出现一些乱码(其实kconfig并是真正图形,只是用工具模拟出图形,之后有机会讲解如何配置linux内核时,我再来详细说明~), 解决的方法:在msys32\etc\profile.d\export_idf_path.sh脚本中添加export LAND="en_US" ,导出LANG环境变量即可。

接着重启vscode,重新配置,正常显示~

尝试编译, make -j4, 也是成功编译:


创建工作区,实现跳转,代码自动补全

前面我们只将工程代码添加进来,而依赖的ESP8266_RTOS_SDK还没关联起来呢, 接下来我们就将其添加到当前工作区中。

  • 首先将工作区保存:点击"文件"->“将工作区另存为...”

  • 接着将ESP8266_RTOS_SDK添加进来, “文件”->"将文件夹添加到工作区",选择ESP8266_RTOS_SDK

  • 配置c_cpp_properties.json 文件, 按住键盘的: shift + ctrl + p, 出现如下图所示:

点击框选,会默认创建c_cpp_properties.json, 并在“includePath”栏中添加以下自己实际的
ESP8266_RTOS_SDK/components路径,当然如果你的工作还有其他依赖,按此格式添加即可。

{
    "configurations": [
        {
            "name": "Win32",
            "includePath": [
                "${workspaceFolder}/**",
                "D:/msys32/home/40806/esp/ESP8266_RTOS_SDK/components/**"//自己要添加的头文件路径
            ],																																																//其他内容是默认生成的,无需改动
            "defines": [
                "_DEBUG",
                "UNICODE",
                "_UNICODE"
            ],
            "windowsSdkVersion": "10.0.18362.0",
            "compilerPath": "E:/visual stdio2019/VC/Tools/MSVC/14.25.28610/bin/Hostx64/x64/cl.exe",
            "cStandard": "c11",
            "cppStandard": "c++17",
            "intelliSenseMode": "msvc-x64"
        }
    ],
    "version": 4
}

当然修改完记得保存哦, 接下来我们就可以看到工程中包含的头文件都显示正常了(在此设置前很多#include “xxx”都红色波浪线+黄灯提示无法加载头文件):

接着我们再试试能否代码自动补全功能和函数和变量跳转:

可以看到随着一边输入,vscode也一边提示相关补全,同时跳转功能也是OK的。

总结

至此我们已经成功在vscode搭建了esp8266/32的开发配置, 接下来我们就可以在vscode一边编写代码,一边配置,编译,下载拉(其实就是把msys32终端集成到vscode中),感兴趣的小伙伴赶紧尝试下吧。好了,今天的分享就先到这,记得收藏,转发,关注~ 同时欢迎大家留言对嵌入式相关内容感兴趣的话题,有机会我会专门介绍~



<script type="text/javascript" src="//mp.toutiao.com/mp/agw/mass_profit/pc_product_promotions_js?item_id=6832680647912325646"></script>

相关推荐

看完这一篇数据仓库干货,终于搞懂什么是hive了

一、Hive定义Hive最早来源于FaceBook,因为FaceBook网站每天产生海量的结构化日志数据,为了对这些数据进行管理,并且因为机器学习的需求,产生了Hive这们技术,并继续发展成为一个成...

真正让你明白Hive参数调优系列1:控制map个数与性能调优参数

本系列几章系统地介绍了开发中Hive常见的用户配置属性(有时称为参数,变量或选项),并说明了哪些版本引入了哪些属性,常见有哪些属性的使用,哪些属性可以进行Hive调优,以及如何使用的问题。以及日常Hi...

HIVE SQL基础语法(hive sql是什么)

引言与关系型数据库的SQL略有不同,但支持了绝大多数的语句如DDL、DML以及常见的聚合函数、连接查询、条件查询。HIVE不适合用于联机事务处理,也不提供实时查询功能。它最适合应用在基于大量不可变数据...

[干货]Hive与Spark sql整合并测试效率

在目前的大数据架构中hive是用来做离线数据分析的,而在Spark1.4版本中spark加入了sparksql,我们知道spark的优势是速度快,那么到底sparksql会比hive...

Hive 常用的函数(hive 数学函数)

一、Hive函数概述及分类标准概述Hive内建了不少函数,用于满足用户不同使用需求,提高SQL编写效率:...

数仓/数开面试题真题总结(二)(数仓面试时应该讲些什么)

二.Hive...

Tomcat处理HTTP请求流程解析(tomcat 处理请求过程)

1、一个简单的HTTP服务器在Web应用中,浏览器请求一个URL,服务器就把生成的HTML网页发送给浏览器,而浏览器和服务器之间的传输协议是HTTP,那么接下来我们看下如何用Java来实现一个简单...

Python 高级编程之网络编程 Socket(六)

一、概述Python网络编程是指使用Python语言编写的网络应用程序。这种编程涉及到网络通信、套接字编程、协议解析等多种方面的知识。...

[904]ScalersTalk成长会Python小组第20周学习笔记

Scalers点评:在2015年,ScalersTalk成长会Python小组完成了《Python核心编程》第1轮的学习。到2016年,我们开始第二轮的学习,并且将重点放在章节的习题上。Python小...

「web开发」几款http请求测试工具

curl命令CURL(CommandLineUniformResourceLocator),是一个利用URL语法,在命令行终端下使用的网络请求工具,支持HTTP、HTTPS、FTP等协议...

x-cmd pkg | hurl - 强力的 HTTP 请求测试工具,让 API 测试更加简洁高效

简介...

Mac 基于HTTP方式访问下载共享文件,配置共享服务器

方法一:使用Python的SimpleHTTPServer进行局域网文件共享Mac自带Python,所以不需要安装其他软件,一条命令即可...

Python 基础教程十五之 Python 使用requests库发送http请求

前言...

使用curl进行http高并发访问(php curl 大量并发获得结果)

本文主要介绍curl异步接口的使用方式,以及获取高性能的一些思路和实践。同时假设读者已经熟悉并且使用过同步接口。1.curl接口基本介绍curl一共有三种接口:EasyInterface...

Django 中的 HttpResponse理解和用法-基础篇1

思路是方向,代码是时间,知识需积累,经验需摸索。希望对大家有用,有错误还望指出。...

取消回复欢迎 发表评论: