按键/串口控制STM32单片机LED灯的亮度

如题,实际上是通过操作单片机定时器发出的PWM输出来点亮LED,而我们可以通过操作占空比来改变LED的亮度。首先找一个单片机定时器TIM14通道1对应针脚PF9将其复用。GPIO_InitTypeDef GPIO_Initure;__HAL_RCC_TIM14_CLK_ENABLE(); //使能定时器 14 __HAL_RCC_GPIOF_CLK_ENABLE(); //开启 GPIOF时钟GPIO_Initure.Pin=GPIO_PIN_9;//PF9 GPIO_Initure.Mode=G
摘要由CSDN通过智能技术生成

如题,实际上是通过操作单片机定时器发出的PWM输出来点亮LED,而我们可以通过操作占空比来改变LED的亮度。
首先找一个单片机定时器TIM14它可以发出PWM输出
对应针脚PF9将其复用。
GPIO_InitTypeDef GPIO_Initure;
__HAL_RCC_TIM14_CLK_ENABLE(); //使能定时器 14 __HAL_RCC_GPIOF_CLK_ENABLE(); //开启 GPIOF时钟
GPIO_Initure.Pin=GPIO_PIN_9;
GPIO_Initure.Pull=GPIO_PULLUP; //上拉
GPIO_Initure.Speed=GPIO_SPEED_HIGH; //高速
GPIO_Initure.Alternate= GPIO_AF9_TIM14; //PF9复用为 TIM14_CH1 HAL_GPIO_Init(GPIOF,&GPIO_Initure);
设置完io后我们要初始化定时器14的通道为PWM模式1,输出极性
TIM_OC_InitTypeDef TIM14_CH1Handler; //定时器 14通道 1句柄
TIM3_CH4Handler.OCMode=TIM_OCMODE_PWM1; //模式选择 PWM1 TIM3_CH4Handler.Pulse=arr/2; //设置比较值 ,此值用来确定占空比
TIM3_CH4Handler.OCPolarity=TIM_OCPOLARITY_LOW; //输出比较极性为低
HAL_TIM_PWM_ConfigChannel(&TIM3_Handler,&TIM3_CH4Handler,TIM_CHANNEL_4);
初始化全部完成 下面只需要操作PWM输出的占空比即可
//占空比函数实现
void TIM_SetTIM14Compare1(u32 compare) {
TIM14–>CCR1=co

  • 6
    点赞
  • 80
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要通过串口控制STM32单片机上的LED,需要以下步骤: 1. 首先,需要在STM32单片机上配置串口通信。具体方法如下: - 配置GPIO引脚为串口通信所需的TX和RX引脚。 - 根据串口通信的参数,配置USART寄存器,包括波特率、数据位、停止位、校验位等。 2. 在主函数中,需要初始化LED引脚为输出模式。 3. 在主函数中,通过串口接收数据,并根据接收到的数据控制LED的亮灭。具体方法如下: - 使用USART_GetFlagStatus函数判断是否接收到了数据。 - 使用USART_ReceiveData函数获取接收到的数据。 - 根据接收到的数据,控制LED的亮灭。例如,当接收到字符‘1’时,将LED引脚输出高电平,LED亮起;当接收到字符‘0’时,将LED引脚输出低电平,LED熄灭。 下面是一个简单的示例代码: ```c #include "stm32f10x.h" void USART_Config(void) { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; // 使能USART1和GPIOA的时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE); // 配置USART1的TX引脚为复用推挽输出模式,RX引脚为浮空输入模式 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, &GPIO_InitStructure); // 配置USART1的工作参数,包括波特率、数据位、停止位、校验位等 USART_InitStructure.USART_BaudRate = 9600; USART_InitStructure.USART_WordLength = USART_WordLength_8b; USART_InitStructure.USART_StopBits = USART_StopBits_1; USART_InitStructure.USART_Parity = USART_Parity_No; USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; USART_Init(USART1, &USART_InitStructure); // 使能USART1 USART_Cmd(USART1, ENABLE); } void LED_Config(void) { GPIO_InitTypeDef GPIO_InitStructure; // 使能GPIOC的时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE); // 配置PC13引脚为推挽输出模式 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOC, &GPIO_InitStructure); } int main(void) { USART_Config(); LED_Config(); while (1) { // 如果接收到了数据 if (USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == SET) { // 获取接收到的数据 uint8_t data = USART_ReceiveData(USART1); // 根据接收到的数据控制LED的亮灭 if (data == '1') GPIO_WriteBit(GPIOC, GPIO_Pin_13, Bit_SET); else if (data == '0') GPIO_WriteBit(GPIOC, GPIO_Pin_13, Bit_RESET); } } } ``` 在上述代码中,使用USART1配置了串口通信,使用PC13引脚控制了一个LED。当接收到字符‘1’时,LED亮起;当接收到字符‘0’时,LED熄灭。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值