STM32 CubeMX 控制LED(详细步骤)---初步认识CubeMX

实验工具

单片机:正点原子STM32F4探索者
软件:CubeMX、Keil5
参考文档:
《STM32F4xx中文参考手册》
《正点原子 STM32F4 开发指南V1.2–HAL 库版本 》
ST32 HAL库使用手册

一、STM32CubeMX 简介

STM32CubeMX 是 ST 意法半导体近几年来大力推荐的STM32 芯片图形化配置工具,目的就是为了方便开发者, 允许用户使用图形化向导生成C 初始化代码,可以大大减轻开发工作,时间和费用,提高开发效率。STM32CubeMX几乎覆盖了STM32 全系列芯片。
在CubeMX上,通过傻瓜化的操作便能实现相关配置,最终能够生成C语言代码,支持多种工具链,比如MDK、IAR For ARM、TrueStudio等 省去了我们配置各种外设的时间
在这里插入图片描述

二、LED的引脚信息

在进行设计之前,我们需要了解使用期间的具体引脚信息,这块板子上有3个LED,可控制的LED为LED0与LED1,电路原理图为下图,查阅单片机使用手册可知,两个LED分别与PF9,PF10相连,控制电平为高时灯灭,低时为亮。
在这里插入图片描述
在这里插入图片描述

三、CubeMX生成配置代码(HAL库)

1、CubeMX创建工程

新建工程可以有三种选项:
(1)选择MUC设计,只针对芯片不包含外围电路
(2)选择ST开发板设计,针对ST公司推出的一些开发板
(3)选择ST开发板例程进行设计
大部分时候我们使用的开发板都不是ST公司的,基本都是使用其他公司设计的开发板所以我们选择第一种方式,也是我们最常用的一种方式。
在这里插入图片描述

2、芯片选择

在这里我们可以选择我们将要使用的MCU的芯片型号,这里提供了很多筛选方式可以快速找到我们需要的芯片型号,本实验使用的是STM32F407ZGT6
在这里插入图片描述

3、硬件配置界面

界面展示出了STM407ZGTx系列的所有资源,接下来需要配置我们需要使用的引脚,这里对某一个功能进行整体配置,例如直接配置ADC,I2C什么的不需要逐个引脚去配置,可以在界面左边的资源列表进行选择。
在这里插入图片描述
我们只是简单的使用两个引脚做高低电平的输出,所以找到PF9与PF10进行设置
在这里插入图片描述
接下来是时钟配置,我们可以在这个界面设置接入到各个模块的时钟频率,STM32F4有5个时钟源
LSI、LSE、HSE、HSI、PLL。
STM32的时钟树系统比较复杂,具体可以参考STM32 F4的官方文档进行学习了解
在这里插入图片描述
图的左边部分就是芯片的时钟源,右边部分即为输出的时钟频率
实验使用最大频率168MHz
在这里插入图片描述
生成工程的名称与设置输出工程的软件类型
在这里插入图片描述
(1)在code设置中对项目的设置为只输出必要的文件,第一个选项生成的文件为完整的库很多文件用不到,我们使用这个软件只是需要截取配置部分的代码就可以了。
(2)生成文件勾选每个配置的代码文件和头文件单独生成,不然全部代码都会在main中很难看
在这里插入图片描述

四、代码分析与功能实现

生成代码的main函数分为几个部分
1、HAL_Init()为 HAL库的初始化
2、SystemClock_Config()为系统时钟的配置
3、MX_GPIO_Init() 为对配置的GPIO口的初始化
4、单片机的 while
在这里插入图片描述
GPIO配置代码,生成的这部分代码使能了GPIO口对应的时钟,设置了GPIO的初始状态为低,最后对GPIO的参数进行设置并进行初始化。
在这里插入图片描述
最后我们来编写LED流水灯的代码并烧写到板子上进行验证即可完成本次实验

HAL_GPIO_WritePin(LED0_GPIO_Port,LED0_Pin,GPIO_PIN_RESET); /*Low*/
HAL_GPIO_WritePin(LED0_GPIO_Port,LED1_Pin,GPIO_PIN_SET); /*HIGH*/
HAL_Delay(500);
HAL_GPIO_WritePin(LED0_GPIO_Port,LED0_Pin,GPIO_PIN_SET);/*HIGH*/
HAL_GPIO_WritePin(LED0_GPIO_Port,LED1_Pin,GPIO_PIN_RESET); /*Low*/
HAL_Delay(500);

五、实验改进

1、时钟配置并开启中断

为了观察CubeMX修改配置后的变化和学习CubeMX的中断配置,增加一部分实验,使用基本定时器TIM6通过中断去控制LED灯的亮灭。
在CubeMX中打开TIM6设置,
参数含义为:
Prescaler 分频系数
Counter Mode 计数模式(分为向上和向下)
Count Period 计数周期
auto-reload preload 自动重装载
TRGO Event Selection 触发事件
NVIC Settings中勾选中断使能
定时器溢出时间的计算公式如下
在这里插入图片描述
在这里插入图片描述
TIM6不知道挂在APB1还是APB2,这里我们把两个时钟都设置为84MHz,我们想实现500ms的延时则分频系数可以设置为psc=839,counter=49999。这里的两个参数为16bit Max=65535在这里插入图片描述

2、代码分析与实现

初始化部分仅多了一个TIM6的初始化函数
在这里插入图片描述
因为生成代码时勾选了重新生成项目时不删除用户编写的代码,所以即使重新生成了文件上一部分的控制代码依然还在注意代码要写在注释的begin与end之间,写在其他地方代码还是会被删除
在这里插入图片描述
使用这个函数开启时钟才能正常调用中断

HAL_TIM_Base_Start_IT(&htim6); //添加到时钟初始化函数之后

在这里插入图片描述
这个c文件,找到TIM6的中断,在其中添加翻转PA0的代码即可:

  HAL_GPIO_TogglePin(LED0_GPIO_Port,LED0_Pin);
  HAL_GPIO_TogglePin(LED1_GPIO_Port,LED1_Pin);

在这里插入图片描述

  • 4
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
### 回答1: STM32CubeMX是STMicroelectronics提供的一种STM32控制器配置工具,它可以帮助用户轻松配置STM32控制器的外设和参数。如果要使用STM32CubeMX控制LED灯,可以按照以下步骤进行: 1. 打开STM32CubeMX并选择要使用的STM32控制器型号。 2. 在"Pinout"标签页中,选择一个可用的GPIO引脚并将其配置为控制LED灯。 3. 在"Clock Configuration"标签页中,配置系统时钟,确保它为LED灯提供足够的时钟频率。 4. 在"Configuration"标签页中,选择"GPIO"并配置GPIO参数。 5. 在"Code Generation"标签页中,生成代码。 6. 在生成的代码中,找到控制LED灯的函数并调用它来控制LED灯。 7. 编译并烧录代码到微控制器中。 8. 打开串口调试工具,连接STM32控制器,发送对应的指令来控制LED灯。 ### 回答2: STM32CubeMX是一个用于快速搭建STM32控制器系列的软件开发环境。通过它,可以轻松地配置微控制器外围设备和中间件,并生成基于HAL库的完整示例项目。其中,串口通信是常见的应用场景之一。 下面是实现使用串口控制LED灯亮灭的步骤: 1. 配置串口通信:打开STM32CubeMX软件,选择对应的微控制器型号并创建新项目。然后,在“Pinout & Configuration”选项卡中,选择“USART”功能后,分别配置串口的波特率、数据位、停止位和奇偶校验等参数。最后,生成代码。 2. 编写代码:在生成的代码框架中,找到“main.c”文件,并添加以下的宏定义、变量和函数: - 宏定义:定义串口输入命令,并与相应的LED管脚关联(例如# define LED_ON ’1’和# define LED_OFF ’0’)。 - 变量:定义串口数据接收缓冲区、LED控制标志等变量。 - 函数:编写串口数据接收和LED控制函数,实现串口接收到指定的命令时,LED灯的亮灭控制。 3. 测试程序:将STM32控制器与计算机连接,打开串口调试助手,通过串口输入“1”或“0”命令,即可控制LED灯亮灭。 总之,使用STM32CubeMX通过串口通信控制LED灯的过程需要先进行串口通信的配置并生成代码,然后编写控制命令的代码实现LED灯亮灭的控制。这样可以大大简化控制代码的编写和调试过程,提高开发效率。 ### 回答3: STM32CubeMX是一个代码生成工具,可用于快速生成STM32控制器项目的初始化代码。在STM32CubeMX中,我们可以轻松地添加串口和LED库函数来控制LED灯的状态。在以下步骤中,我们将学习如何使用STM32CubeMXSTM32控制器上控制LED灯: 1. 配置串口 在STM32CubeMX中,我们需要先配置板载串口。为此,我们可以打开STM32CubeMX,选择正确的芯片系列和型号,然后单击“时钟配置”选项卡,以配置系统时钟。 2. 启用串口和GPIO 接下来,我们需要启用所需的串口(USART)和GPIO(General Purpose Input/Output)端口。选择“Pinout & Configuration”选项卡,然后单击“USART1”并将其设置为“Enable”状态。此外,我们需要启用控制LED的GPIO端口。选择与所选开发板中的LED灯对应的端口,并将其设置为输出模式。 3. 建立中断服务例程 在“Configuration”选项卡中,我们可以配置中断服务例程。选择“NVIC”选项卡,然后启用或禁用所需的中断。对于串口,我们需要启用“USART1 global interrupt”。 4. 处理中断和发送数据 在我们的代码中,我们可以实现一个自定义的USART1中断服务例程来处理接收的数据,并相应地改变LED状态。我们也可以使用库函数来发送数据到串口。例如,我们可以使用库函数“HAL_USART_Transmit”将“LED ON/OFF”这样的字符发送到串口上。 5. 编写代码 在以上步骤完成后,我们需要在IDE中编写代码来控制LED。使用库函数的示例代码如下: ``` #include "main.h" #include "stm32f1xx_hal_usart.h" void GPIO_Init(void); void USART1_Init(void); void USART1_IRQHandler(void); int main(void) { HAL_Init(); // 初始化 HAL 库 GPIO_Init(); // 初始化 GPIO USART1_Init();// 初始化 USART1 while (1) { // 循环等待中断触发 } } void GPIO_Init(void) { __HAL_RCC_GPIOC_CLK_ENABLE(); // 使能 GPIOC 时钟 GPIO_InitTypeDef GPIO_InitStruct = {0}; GPIO_InitStruct.Pin = GPIO_PIN_13; GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; HAL_GPIO_Init(GPIOC, &GPIO_InitStruct); } void USART1_Init(void) { __HAL_RCC_USART1_CLK_ENABLE(); // 使能 USART1 时钟 USART_HandleTypeDef USART_InitStruct = {0}; USART_InitStruct.Instance = USART1; USART_InitStruct.Init.BaudRate = 9600; USART_InitStruct.Init.WordLength = USART_WORDLENGTH_8B; USART_InitStruct.Init.StopBits = USART_STOPBITS_1; USART_InitStruct.Init.Parity = USART_PARITY_NONE; USART_InitStruct.Init.Mode = USART_MODE_TX_RX; USART_InitStruct.Init.HwFlowCtl = USART_HWCONTROL_NONE; USART_InitStruct.Init.OverSampling = USART_OVERSAMPLING_16; HAL_USART_Init(&USART_InitStruct); HAL_NVIC_SetPriority(USART1_IRQn, 0, 1); // 设置中断优先级 HAL_NVIC_EnableIRQ(USART1_IRQn); // 使能中断 } void USART1_IRQHandler(void) { uint32_t isrflags = READ_REG(USART1->ISR); // 读取中断状态寄存器 if (isrflags & USART_ISR_RXNE) // 如果是 USART 接收中断 { uint8_t ch; HAL_USART_Receive(&huart1, &ch, 1, HAL_MAX_DELAY); // 读取数据 if (ch == '0') // 接收到 '0',关闭 LED { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_13, GPIO_PIN_RESET); } else if (ch == '1') // 接收到 '1',开启 LED { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_13, GPIO_PIN_SET); } else { // 发送错误消息到串口 const char* errmsg = "Invalid command received!"; HAL_USART_Transmit(&huart1, (uint8_t*)errmsg, strlen(errmsg), HAL_MAX_DELAY); } } } ``` 在以上代码中,我们使用了库函数来初始化GPIO和USART1,然后等待中断触发。当接收到'0'或'1'字符时,我们将相应地关闭或开启LED灯。如果接收到其他字符,我们将发送一个错误消息。 如上所述,我们现在可以在STM32控制器上使用串口和LED库函数控制LED灯了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

伊丽莎白鹅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值