2023-07-11 15:03:50 +08:00
|
|
|
|
现在你已经具备了使用 ESP-IDF 的所有条件,接下来将介绍如何开始第一个工程。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
本指南将介绍如何初步上手 ESP-IDF,包括如何使用 {IDF_TARGET_NAME} 创建第一个工程,并构建、烧录和监控设备输出。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
如果还未安装 ESP-IDF,请参照 :ref:`get-started-step-by-step` 中的步骤,获取使用本指南所需的所有软件。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
开始创建工程
|
|
|
|
|
================
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
现在,可以准备开发 {IDF_TARGET_NAME} 应用程序了。可以从 ESP-IDF 中 :idf:`examples` 目录下的 :example:`get-started/hello_world` 工程开始。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
|
|
|
|
|
|
ESP-IDF 编译系统不支持 ESP-IDF 路径或其工程路径中带有空格。
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
将 :example:`get-started/hello_world` 工程复制至本地的 ``~/esp`` 目录下:
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
.. code-block:: batch
|
|
|
|
|
|
|
|
|
|
cd %userprofile%\esp
|
|
|
|
|
xcopy /e /i %IDF_PATH%\examples\get-started\hello_world hello_world
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
.. note:: ESP-IDF 的 :idf:`examples` 目录下有一系列示例工程,可以按照上述方法复制并运行其中的任何示例,也可以直接编译示例,无需进行复制。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
连接设备
|
|
|
|
|
==============
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
现在,请将 {IDF_TARGET_NAME} 开发板连接到 PC,并查看开发板使用的串口。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
2022-04-22 11:18:11 +08:00
|
|
|
|
在 Windows 操作系统中,串口名称通常以 ``COM`` 开头。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
有关如何查看串口名称的详细信息,请见 :doc:`establish-serial-connection`。
|
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
请记住串口名,以便后续使用。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
配置工程
|
|
|
|
|
=============
|
|
|
|
|
|
|
|
|
|
请进入 ``hello_world`` 目录,设置 {IDF_TARGET_NAME} 为目标芯片,然后运行工程配置工具 ``menuconfig``。
|
|
|
|
|
|
2022-05-07 17:15:18 +08:00
|
|
|
|
Windows
|
|
|
|
|
~~~~~~~
|
|
|
|
|
|
2022-04-15 16:26:21 +02:00
|
|
|
|
.. code-block:: batch
|
|
|
|
|
|
|
|
|
|
cd %userprofile%\esp\hello_world
|
|
|
|
|
idf.py set-target {IDF_TARGET_PATH_NAME}
|
|
|
|
|
idf.py menuconfig
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
打开一个新工程后,应首先使用 ``idf.py set-target {IDF_TARGET_PATH_NAME}`` 设置“目标”芯片。注意,此操作将清除并初始化项目之前的编译和配置(如有)。也可以直接将“目标”配置为环境变量(此时可跳过该步骤)。更多信息,请见 :ref:`selecting-idf-target`。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
2022-04-22 11:18:11 +08:00
|
|
|
|
正确操作上述步骤后,系统将显示以下菜单:
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
.. figure:: ../../_static/project-configuration.png
|
|
|
|
|
:align: center
|
|
|
|
|
:alt: 工程配置 — 主窗口
|
|
|
|
|
|
|
|
|
|
工程配置 — 主窗口
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
可以通过此菜单设置项目的具体变量,包括 Wi-Fi 网络名称、密码和处理器速度等。``hello_world`` 示例项目会以默认配置运行,因此在这一项目中,可以跳过使用 ``menuconfig`` 进行项目配置这一步骤。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
.. only:: esp32
|
|
|
|
|
|
|
|
|
|
.. attention::
|
|
|
|
|
|
2023-10-14 03:55:41 +08:00
|
|
|
|
如果使用的是 ESP32-DevKitC(板载 ESP32-SOLO-1 模组)或 ESP32-DevKitM-1(板载 ESP32-MINI-1/1U 模组),请在烧写示例程序前,前往 ``menuconfig`` 中使能单核模式(:ref:`CONFIG_FREERTOS_UNICORE`)。
|
2022-04-15 16:26:21 +02:00
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
终端窗口中显示出的菜单颜色可能会与上图不同。可以通过选项 ``--style`` 来改变外观。请运行 ``idf.py menuconfig --help`` 命令,获取更多信息。
|
2022-05-13 13:16:43 +02:00
|
|
|
|
|
|
|
|
|
.. only:: esp32 or esp32s2 or esp32s3
|
|
|
|
|
|
2023-07-11 15:03:50 +08:00
|
|
|
|
如果使用的是支持的开发板,可以通过板级支持包 (BSP) 来协助开发。更多信息,请见 `其他提示 <#additional-tips>`__。
|
2022-08-01 17:08:06 +08:00
|
|
|
|
|
|
|
|
|
.. only:: esp32s2
|
|
|
|
|
|
|
|
|
|
如需使用 USB 烧录 {IDF_TARGET_NAME},请将控制台的输出通道改为 USB。对于 {IDF_TARGET_NAME},默认的控制台输出通道为 UART。
|
|
|
|
|
|
|
|
|
|
1. 前往选项 ``Channel for console output``。
|
|
|
|
|
|
|
|
|
|
``Component config ---> ESP System Settings ---> Channel for console output``
|
|
|
|
|
|
|
|
|
|
2. 将默认选项 UART 改为:
|
|
|
|
|
|
|
|
|
|
``USB CDC``
|
|
|
|
|
|
|
|
|
|
3. 保存设置,退出 ``menuconfig`` 界面。
|