ESP32 + ESP-IDF |GPIO 01 - 驱动外部两个LED灯,以每300ms的时间间隔闪烁

一、前言


我使用的硬件:
在这里插入图片描述
嵌入式软件开发从来都不是从hello world开始,而是从GPIO驱动LED闪烁开始。
本次实验的目的是使用GPIO26与GPIO27各驱动一个LED灯,以300ms的时间间隔闪烁。
在这里插入图片描述
ESP-IDF Monitor打印出来的调试信息:
在这里插入图片描述
需要注意⚠️:
在这里插入图片描述

二、VSCODE + ESP-IDF


2.1、快速创建项目

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.2、选择串口通道,ESP芯片型号

在这里插入图片描述
在这里插入图片描述
创建项目模块成功,代码成功被编译。

三、代码


3.1、main.c

3.1.1、头文件

  • ESP-IDF是基于freertos的SDK,所以需要包含FreeRTOS.h头文件与task.h头文件。
  • 使用ESP_LOGI( )函数打印一些调试信息,所以包含esp_log.h头文件。
  • 使用GPIO,所以包含driver/gpio.h。
    在这里插入图片描述

3.1.2、全局变量

在这里插入图片描述

3.1.3、app_main( )函数

  • 第一步通过gpio_reset_pin( )函数初始化引脚。
  • 第二步通过gpio_set_direction( )函数将对应的GPIO口设置为输出。
  • 第三步通过gpio_set_level( )函数将电平输出到pin脚上。
    在这里插入图片描述

3.2、实验代码

#include <stdio.h>
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "driver/gpio.h"
#include "esp_log.h"

static uint8_t s_led_state = 0;
static const char *TAG = "first_example";

void app_main(void)
{
    
    
    ESP_LOGI(TAG, "Example configured to blink GPIO LED!");
    /* 复位GPIO的状态 */
    gpio_reset_pin(26);
    gpio_reset_pin(27);

    /* 设置GPIO为输出模式 */
    gpio_set_direction(26,GPIO_MODE_OUTPUT);
    gpio_set_direction(27,GPIO_MODE_OUTPUT);

    while(1)
    {
    
    
        ESP_LOGI(TAG, "Turning the LED %s!", s_led_state == true ? "ON" : "OFF");

        gpio_set_level(26,s_led_state);         /* GPIO26输出电平 */
        gpio_set_level(27,s_led_state);         /* GPIO27输出电平 */

        s_led_state = !s_led_state;             /* 取反LED的状态 */
        vTaskDelay(300 / portTICK_PERIOD_MS);   /* 延时300ms */

    }
}

四、相关API


esp官方网址:https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/gpio.html

4.1、gpio_reset_pin(gpio_num_t gpio_num)

在这里插入图片描述
这个函数用于重置mcu引脚的状态,值得注意的是引脚被重置后会使能“上拉”。

4.2、gpio_set_direction(gpio_num_t gpio_num,gpio_mode_t mode)

在这里插入图片描述
这个函数用于设置mcu引脚的功能(输入或者输出,或者即是输入又是输出)。

4.3、gpio_set_level(gpio_num_t gpio_num, uint32_t level)

在这里插入图片描述

gpio_set_level(GPIO_NUM_16,0);  //gpio16输出低电平
gpio_set_level(GPIO_NUM_16,1);  //gpio16输出高电平

4.4、vTaskDelay(const TickType_t xTicksToDelay)

在这里插入图片描述
没有学习过rtos的同学可以认为它是一个延时函数。学过rtos的同学其实知道它会启动rtos的调度器,将CPU的执行权交给其他线程,等待一段时间后回来继续执行代码。

至于为什么以下代码会延时300ms,是因为freeRTOS的滴答定时器的频率被设置为1000Hz。

vTaskDelay(300 / portTICK_PERIOD_MS);   /* 延时300ms */

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/wallace89/article/details/123969903