基于ESP32的桌面小屏幕实战[6]:环境搭建和软件基础

news/2025/1/27 19:34:04/文章来源:https://www.cnblogs.com/xing9/p/18475499

摘要

本文分为两部分:Linux开发环境搭建和软件基础。Linux开发环境搭建介绍了Ubuntu虚拟机安装及SSH、Samba配置,可以实现用VSCode操作虚拟机。为了后续工作,搭建了乐鑫ESP32 SDK环境。软件基础介绍了Linux开发常用的软件基础,包括Linux指令、Git、Makefile、裸机和RTOS。

环境搭建

ESP32学习方法:主要看API手册和历程

API和寄存器的关系:因为寄存器的操作太复杂了,所以原厂工程师把寄存器的操作封装成API

1. UI交互图和程序流程图

在设计软件之前,要先画UI交互图和程序流程图

img

img

2. Ubuntu虚拟机安装及SSH、Samba配置

2.1 安装虚拟机

安装VMware Workstation,我安装的版本是17.6。VMware17.6 软件安装包下载及安装教程

2.2 安装Ubuntu

官网:https://ubuntu.com/download/desktop

实测不用“科学方法”下载速度较慢。我下载的是Ubuntu 24.04.1 LTS

img

参考Ubuntu 20.04 LTS安装教程:超详细VMware安装Ubuntu虚拟机步骤
顺序略有不同,但大体一致。

2.3 在虚拟机中安装SSH

打开Ubuntu的终端,输入

sudo apt-get install openssh-server
sudo /etc/init.d/ssh start
ps -e|grep ssh

2.4 Samba服务器搭建

Samba 允许不同操作系统(如 Windows、Linux 或 macOS)的设备访问和管理该文件夹中的内容。通过 Samba 共享的文件夹可以在网络上的其他设备之间共享文件。

在Ubuntu的终端中,输入

sudo apt-get update
sudo apt-get install samba
sudo apt-get install gedit
sudo gedit /etc/samba/smb.conf

会弹出一个文档,在文档底部加入下面配置。其中share是共享文件夹的名称,可以改为别的。

[share]valid user = xzhpath = /home/xzh/sharepublic = yeswritable = yescreate mask = 0644force create mode = 0644directory mask = 0755force directory mode = 0755available = yes

改完之后保存

在Ubuntu终端中继续输入下面命令重启Samba服务:

sudo service smbd restart
sudo ufw allow samba

输入sudo smbpasswd -a xzh创建Samba用户名,我取名为xzh,然后根据提示设置密码。

img

重启下一Samba:

sudo /etc/init.d/smbd  restart

在Ubuntu终端中输入ip addr show查询Samba的IP地址

img

Interface ens33 表示我的网络接口,通常表示有线网络连接。
inet 192.168.62.128/24 是我当前机器的 IPv4 地址,即 192.168.62.128。这就是其他设备用来连接到我 Samba 服务器的 IP 地址。
inet6 fe80::20c:29ff:fe2c/64 是我机器的 IPv6 地址,但通常局域网内共享文件更多使用 IPv4 地址。

在Windows系统上按下“Windows键+R”,输入\\192.168.62.128,点击确定。

img

Windows安全中心会出现弹窗“输入网络凭据”,输入刚刚创建的Samba用户名和密码,然后点击确定就可以进入共享文件夹了。

img

2.5 在Window的VSCode中通过SSH命令行方式访问Ubuntu

在Windows中打开VSCode,安装C/C++和SSH插件

img
img

配置连接Ubuntu

img

添加配置信息:

Host ubuntuHostName 192.168.62.128User xzh

192.168.62.128为Ubuntu的IP,xzh为我Ubuntu的用户名。

保存之后刷新一下,出现ubuntu。

img

选择linux

img

选择continue

img

输入密码,按回车

img

成功连接

img

3. 乐鑫ESP32 SDK环境搭建

3.1 安装环境依赖工具

在VSCode的终端中输入

sudo apt-get update
sudo apt-get install git wget flex bison gperf python3 python3-pip python3-setuptools cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0

3.2 下载源码

在终端中输入:

mkdir esp
cd ~/esp
git clone -b release/v4.4 --recursive https://github.com/espressif/esp-idf.git

在git clone时遇到了这个问题:

error: RPC failed; curl 92 HTTP/2 stream 5 was not closed cleanly: CANCEL (err 8)
error: 780 bytes of body are still expected
fetch-pack: unexpected disconnect while reading sideband packet
fatal: early EOF
fatal: fetch-pack: invalid index-pack output
fatal: clone of 'https://github.com/espressif/esp32-wifi-lib.git' into submodule path '/home/xzh/esp/esp-idf/components/esp_wifi/lib' failed
Failed to clone 'components/esp_wifi/lib' a second time, aborting

error: RPC failed; curl 92 HTTP/2 stream 5 was not closed cleanly: CANCEL (err 8)这是由于在使用 HTTP/2 协议通过 curl 下载时,网络连接中断或被取消。可能是因为网络不稳定或远程服务器的问题。

error: 780 bytes of body are still expectedGit 期望从服务器接收到更多数据,但数据传输中途中断了。

fetch-pack: unexpected disconnect while reading sideband packet在 Git 从服务器读取数据时连接被意外断开。

fatal: early EOFfatal: fetch-pack: invalid index-pack outputGit 收到了一个不完整的包,导致它在处理包时失败。EOF 表示文件或数据流提前结束。

fatal: clone of 'https://github.com/espressif/esp32-wifi-lib.git' into submodule path '/home/xzh/esp/esp-idf/components/esp_wifi/lib' failed
Git 无法完成克隆操作,因此将子模块克隆到指定路径失败。

Failed to clone 'components/esp_wifi/lib' a second time, aborting
Git 尝试重新克隆,但再次失败,因此操作中止。

解决办法

进入esp_idf文件夹内

cd /home/xzh/esp/esp-idf/components/esp_wifi/lib

单独更新子模块

git submodule update --init --recursive

3.3 安装编译链

进入到解压的esp-idf文件中,安装编译代码需要的工具链

cd ~/esp/esp-idf
export IDF_GITHUB_ASSETS="dl.espressif.com/github_assets"
./install.sh

出现报错:

pip 24.0 from /usr/lib/python3/dist-packages/pip (python 3.12)
Installing virtualenv
error: externally-managed-environment× This environment is externally managed
╰─> To install Python packages system-wide, try apt installpython3-xyz, where xyz is the package you are trying toinstall.If you wish to install a non-Debian-packaged Python package,create a virtual environment using python3 -m venv path/to/venv.Then use path/to/venv/bin/python and path/to/venv/bin/pip. Makesure you have python3-full installed.If you wish to install a non-Debian packaged Python application,it may be easiest to use pipx install xyz, which will manage avirtual environment for you. Make sure you have pipx installed.See /usr/share/doc/python3.12/README.venv for more information.note: If you believe this is a mistake, please contact your Python installation or OS distribution provider. You can override this, at the risk of breaking your Python installation or OS, by passing --break-system-packages.
hint: See PEP 668 for the detailed specification.
Traceback (most recent call last):File "/home/xzh/esp/esp-idf/tools/idf_tools.py", line 1587, in action_install_python_envimport virtualenv  # noqa: F401^^^^^^^^^^^^^^^^^
ModuleNotFoundError: No module named 'virtualenv'During handling of the above exception, another exception occurred:Traceback (most recent call last):File "/home/xzh/esp/esp-idf/tools/idf_tools.py", line 1996, in <module>main(sys.argv[1:])File "/home/xzh/esp/esp-idf/tools/idf_tools.py", line 1992, in mainaction_func(args)File "/home/xzh/esp/esp-idf/tools/idf_tools.py", line 1590, in action_install_python_envsubprocess.check_call([sys.executable, '-m', 'pip', 'install', '--user', 'virtualenv'],File "/usr/lib/python3.12/subprocess.py", line 413, in check_callraise CalledProcessError(retcode, cmd)
subprocess.CalledProcessError: Command '['/usr/bin/python3', '-m', 'pip', 'install', '--user', 'virtualenv']' returned non-zero exit status 1.

分析

error: externally-managed-environment
这条错误提示表明你的 Python 环境受到了外部管理(即,操作系统的包管理系统控制了这个环境),而不允许通过 pip 在全局安装 Python 包。这是为了保护系统环境不被破坏,因为不同的包管理系统之间可能会发生冲突。

This environment is externally managed
你的操作系统(例如,Ubuntu 或 Debian)将 Python 环境标记为外部管理,阻止 pip 在全局环境中安装包,以避免系统依赖关系被破坏。

ModuleNotFoundError: No module named 'virtualenv'
你尝试运行的 Python 脚本 idf_tools.py 需要使用 virtualenv 模块,但这个模块在系统中并未安装。

解决办法

使用 apt 安装系统范围的包

sudo apt install python3-virtualenv

3.4 设置环境

把esp-idf路径设为本地路径,在终端执行:

. /home/xzh/esp/esp-idf/export.sh

3.5 判断是否搭建成功

通过idf.py --version查看 ESP-IDF 版本
得到输出:
img

通过 git log 查看当前代码状态
得到输出:
img

提交历史和 Git 标签都表明我的代码库已经成功同步到最新版本,克隆没有问题,ESP-IDF 环境应该已经搭建完成。


软件基础

4. Linux 指令

4.1 cd (Change Directory)

cd 命令用于在目录之间切换或更改当前的工作目录。

  • cd <目录路径>: 切换到指定的目录。
  • cd ..: 切换到上一级目录。
    示例:如果当前在 /home/user/Documents,执行 cd .. 将切换到 /home/user。
  • cd ~: 切换到当前用户的主目录。
    示例:cd ~ 将切换到类似 /home/username 的路径。
  • cd -: 切换到上一个工作目录。
    示例:如果你从 /home/user 切换到 /var/log,执行 cd - 将回到 /home/user。

4.2 ls (List Directory Contents)

ls 命令用于显示当前目录或指定目录中的文件和子目录的列表。

  • ls: 显示当前目录中的文件和子目录。
  • ls <目录路径>: 显示指定目录中的文件和子目录。

4.3 mkdir (Make Directory)

mkdir 命令用于创建新的目录。

  • mkdir <目录名>: 创建一个新的目录。
    示例:mkdir my_folder 会在当前目录下创建一个名为 my_folder 的目录。
  • mkdir -p <路径>: 创建目录及其父目录(如果不存在)。
    示例:mkdir -p /home/user/docs/project 如果 docs 或 project 目录不存在,它们都会被创建。

4.4 rm (Remove)

rm 命令用于删除文件或目录。

  • rm <文件名>: 删除指定文件。
  • rm -r <目录名>: 递归删除目录及其内部所有内容。

4.5 cp (Copy)

cp 命令用于复制文件或目录。

  • cp <源文件> <目标路径>: 复制文件到目标路径。
    示例:cp file.txt /home/user/Documents/ 将 file.txt 复制到 /home/user/Documents/ 目录。
  • cp <源文件> <目标文件>: 复制文件并重命名。
    示例:cp file.txt newfile.txt 将 file.txt 复制为 newfile.txt。
  • cp -r <源目录> <目标路径>: 递归复制目录及其内容。
    示例:cp -r my_folder /home/user/backup/ 将整个 my_folder 目录及其所有内容复制到 /home/user/backup/ 目录。

4.6 mv (Move)

mv 命令用于移动或重命名文件或目录。它将文件从一个位置移动到另一个位置,或者将文件/目录重命名。

  • mv <源文件> <目标路径>: 移动文件到目标路径。
    示例:mv file.txt /home/user/Documents/ 将 file.txt 移动到 /home/user/Documents/ 目录。
  • mv <源文件> <新文件名>: 重命名文件。
    示例:mv oldname.txt newname.txt 将 oldname.txt 重命名为 newname.txt。
  • mv <源目录> <目标路径>: 移动整个目录到目标路径。
    示例:mv my_folder /home/user/backup/ 将 my_folder 目录移动到 /home/user/backup/。

5. Git 使用

Git是一个版本管理工具。

5.1 编辑文件

cd share
mkdir esp_demo1
cd esp_demo1
vim test.c

新建了一个test.c文件,随便输入点啥,按Esc+:+w+q保存该文件。输入ls命令,可以看到输出test.c。

用git init创建本地仓库
然后设置用户名和邮箱
img

git status查看当前状态。输出显示test.c是新添加的文件
img

git add *把当前路径下所有文件都添加进本地仓库。

git commit -m "标签名"去打标签
img

git log看一下日志
img

如果需要修改test.c文件,用vim test.c进入文件,保存完之后,再用git add *指令添加一下。然后打个标签git commit -m "fix xxx function"
img

git log可以看到修改记录
img

git show <哈希值>可以看到,某一次修改的内容
img

img

再用vim test.c加点东西,然后用git diff查看区别
img

5.2 添加分支

分支(branch)允许你在不同的开发线上工作,避免干扰主项目的稳定版本,并为不同的功能、修复或实验提供独立的空间。

git checkout -b dev添加分支,用git branch -a查看本地仓库有哪些分支。
img

vim test.c修改文件。用git add *添加,用git commit -m 打标签。用git log
img

git checkout main回到主分支,用git log查看日志,发现主分支的日志没被污染。
img

5.3 结束打标签

在软件发布时一般用git tag -a v1.0 -m "v1.0 version"打标签。输入git tag -l查看,输出显示:
img

6. Makefile

Makefile 是由 GNU Make 工具使用的文件,定义了项目的编译规则。它描述了如何从源代码生成可执行文件或其他目标文件,主要通过一系列的规则、依赖关系和命令来完成。

CMake 是一个跨平台的构建系统工具,比 Makefile 更高级,适合管理更复杂的项目。CMake 的主要作用是生成平台特定的构建文件(如 Makefile 或 Visual Studio 工程文件),简化跨平台构建流程。CMake 使用 CMakeLists.txt 文件来定义项目的构建规则。CMake 通过解析这个文件,根据目标平台生成相应的构建文件。

  • Makefile:较为基础,适用于单一平台和相对简单的项目,依赖于开发者自己定义的规则和依赖关系。
  • CMake:跨平台,适用于大型和复杂项目,自动处理依赖并生成平台特定的构建文件。

7. “裸机”和实时操作系统(RTOS)

在嵌入式系统开发中,"裸机"和"实时操作系统(RTOS)"是两种常见的编程模式。它们在资源管理、任务调度和系统复杂性等方面有显著的区别。

7.1 裸机编程

裸机编程(Bare Metal Programming)指的是直接在硬件上运行代码,不依赖任何操作系统。所有的系统资源、外设和任务调度由程序员手动管理。这种编程方式通常用于资源受限、系统简单且对实时性要求不高的嵌入式设备。

7.2 实时操作系统(RTOS)

实时操作系统(RTOS)是一类专门为实时应用设计的操作系统,能够提供确定性的任务调度,保证任务在严格的时间限制内完成。RTOS通过内核来管理任务调度、中断处理、资源共享等功能。

推荐链接

  • ESP-IDF 编程指南 release-v4.4
  • ESP-IDF 编程指南 版本 v5.3.1
  • DesktopScreen 1 环境搭建

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/875698.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringMvc请求与响应 -2025/1/19

请求 Post请求中文乱码处理List集合接受,请求后台接受参数 //集合参数:同名请求参数可以使用@RequestParam注解映射到对应名称的集合对象中作为数据 @RequestMapping("/listParam") @ResponseBody public String listParam(List<String> likes){System.out.pr…

Spring事务 -2025/1/15

Spring事务简介 Spring添加事务管理 1.2.Spring事务角色Spring事务配置 事务是可以进行配置的事务传播行为 事务传播行为:事务协调员对事务管理员所携带事务的处理态度。 propagation属性

AOP -2025/1/11

AOP简介连接点(JoinPoint):程序执行过程中的任意位置,粒度为执行方法、抛出异常、设置变量等在SpringAOP中,理解为方法的执行切入点(Pointcut):匹配连接点的式子在SpringAOP中,一个切入点可以描述一个具体方法,也可也匹配多个方法一个具体的方法:如com.itheima.dao包下的B…

牛客 小白109 20250119

牛客 小白 109 20250119 牛客小白月赛109_ACM/NOI/CSP/CCPC/ICPC算法编程高难度练习赛_牛客竞赛OJ A: 题目大意:根据不等式求值 #include<bits/stdc++.h>using namespace std;int main() {int n;cin>>n;if (n<=19375331) cout<<n;else cout<<1937…

Vue3+ElementPlus+Koa2 全栈开发后台系统

Vue3+ElementPlus+Koa2 全栈开发后台系统 9 18 第1章 项目规划/1-1.mp4 Vue3+ElementPlus+Koa2全栈开发后台系统@河畔一角 前端Vue3+ElementPlus后台Koa2+MongoDB 如何构建通用型的后台管理系统如何搭建完备的前后台系统架构 掌握开发工作技巧 开发概述全栈后台管理系统 架构设…

User Agent Switcher不改变客户端UA

描述 如图,下面这个软件。软件设置中,包含以下选项,有个选项是不改变客户端的UA(navigator全局对象)然而,就算不勾选这玩意,navigator依然没有被正常改变。获取UA 可以在下面的网站,查看当前浏览器环境UA。 https://tool.ip138.com/useragent/ 客户端(浏览器) const …

事件监听,Vue,Ajax

1.事件监听点击查看代码 <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JS事件</title>…

用M实现类似Lookup的等级查找(Power Query 之 M 语言)

问题:表1和表2,需要根据表2中金额下限的设置反应对应的等级(=LOOKUP(A2,D$2:E$4)的结果)。 let源1 = Excel.CurrentWorkbook(){[Name="表1"]}[Content], 源2 = Excel.CurrentWorkbook(){[Name="表2"]}[Content],查找 = (对应金额) =>let筛选行 = T…

用M实现类似Lookup的等级查找(Power Query)

问题:表1和表2,需要根据表2中金额下限的设置反应对应的等级(=LOOKUP(A2,D$2:E$4)的结果)。 let源1 = Excel.CurrentWorkbook(){[Name="表1"]}[Content], 源2 = Excel.CurrentWorkbook(){[Name="表2"]}[Content],查找 = (对应金额) =>let筛选行 = T…

题解:AT_abc373_g [ABC373G] No Cross Matching

前言 调整法真是好东西。 思路分析 如果你网络流题做得比较多的话,应该能感觉出来这道题有点像。 经过若干手摸,发现根本不存在无解的情况。 每次交叉时,我们一定可以将交叉的两条路径分开,如图:同时,根据四边形不等式,有蓝线段长度之和大于黄线段长度之和。 因此,我们…

再述 Dijkstra

再述 Dijkstra 学 Dijkstra 好久了,今天再学了一遍,感觉推翻了好多自己的知识…… 定义 一种用于求非负权值的图的单源最短路径的算法。 方法 已知:如果要求从起始点 s 到某一个点 x 的最短路径,显然只能从某一个已确认为最短路径的点转移。 给个图:假设我们的起始点是点 …

Docker 常见问题处理技巧

Docker 迁移存储目录默认情况系统会将 Docker 容器存放在 /var/lib/docker 目录下问题起因今天通过监控系统,发现公司其中一台服务器的磁盘块慢,随即上去看了下,发现 /var/lib/docker 这个目录特别大。由上述原因,我们都知道,在 /var/lib/docker 中存储的都是相关于容器的…