STM32F4探索者LED灯闪烁-库函数

原理

在这里插入图片描述
在这里插入图片描述
我们可以看到两个LED是和电阻串联然后接在VCC上的,共阳极,另一端的引脚分别接在PF9和PF10。所以我们只需要控制PF9和PF10的高低电平就可以控制LED的亮和灭。低电平为亮,高电平为灭。
我们要先了解几个函数:
1个初始化函数:
void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct)//初始化一个或者多个IO口(同一组)的工作模式,输出类型,速度以及上下拉方式。也就是一组IO口的4个配置寄存器。;

2个读取输入电平函数:

uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);//读取某个GPIO的输入电平
uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx);//读取某组GPIO的输入电平

2个读取输出电平函数:

uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);//读取某个GPIO的输出电平
uint16_t GPIO_ReadOutputData(GPIO_TypeDef* GPIOx);//读取某组GPIO的输出电平

4个设置输出电平函数:

void GPIO_SetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);//设置某个IO口输出为高电平
void GPIO_ResetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);//设置某个IO口输出为低电平
void GPIO_WriteBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, BitAction BitVal);
void GPIO_Write(GPIO_TypeDef* GPIOx, uint16_t PortVal);

初始化GPIO

void LED_Init()
{
  GPIO_InitTypeDef  GPIO_InitStructure;//定义结构体

  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF, ENABLE);//设置时钟使能

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10;//设置为9和10口
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;//设置为输出模式
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//设置为推挽
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//设置速度
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  GPIO_Init(GPIOF, &GPIO_InitStructure);//初始化GPIOF这里用了结构体
	
	GPIO_SetBits(GPIOF,GPIO_Pin_9 | GPIO_Pin_10);//设置GPIOF9和10为高电平
}

注:
1.推挽输出:
可以输出强高低电平,连接数字器件
开漏输出:
只可以输出强低电平,高电平得靠外部电阻拉高。输出端相当于三极管的集电极. 要得到高电平状态需要上拉电阻才行. 适合于做电流型的驱动,其吸收电流的能力相对强(一般20ma以内)
2.时钟使能函数我们可以在stm32f4xx_rcc.c中使用搜索功能(Ctrl+F)可以找到
3.函数的参数我们可以使用go to definition of来快速查找

在这里插入图片描述
我们点击一下go to definition of在这里插入图片描述
is开头的就是对参数的一个判断语句 所以我们对对蓝标再使用一次go to definition of在这里插入图片描述
光标会在最下面,上面就是我们可以填入的参数了。

主要代码

led.h

#ifndef __LED__H
#define __LED__H

void LED_Init();

#endif

led.c

#include"LED.H"
#include"sys.h"
void LED_Init()
{
  GPIO_InitTypeDef  GPIO_InitStructure;

  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOF, ENABLE);

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  GPIO_Init(GPIOF, &GPIO_InitStructure);
	
	GPIO_SetBits(GPIOF,GPIO_Pin_9 | GPIO_Pin_10);
}

main.c

#include "sys.h"
#include "delay.h"
#include "usart.h"
#include "led.h"

int main(void)
{ 
 
	delay_init(168);		  
	LED_Init();		        

	while(1)
	{
	GPIO_ResetBits(GPIOF,GPIO_Pin_9);  
	GPIO_SetBits(GPIOF,GPIO_Pin_10);  
	delay_ms(500);  		  
	GPIO_SetBits(GPIOF,GPIO_Pin_9);	   
	GPIO_ResetBits(GPIOF,GPIO_Pin_10); 
	delay_ms(500);                    
	}
}

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
探索者STM32F4开发指南-库函数版是一本针对STM32F4系列微控制器的开发指南,它提供了丰富的内容和实例,以帮助初学者深入了解和掌握STM32F4的开发和应用。该指南基于库函数的开发方法,以简明易懂的方式介绍了STM32F4的各种功能和特性,并通过实例演示了如何使用库函数来编程开发。 该指南的下载方式一般有几种。首先,可以在官方网站或STM32F4相关的开发社区论坛上搜索并下载。这种方式可以确保下载到官方提供的最新版本,同时还可以访问到丰富的技术文档和资料。其次,一些电子书籍网站或资源分享网站上也可能提供该指南的下载。不过,在选择这种方式时,请注意确保来源可信,并且下载内容的完整性和准确性。 另外,如果您有购买某款开发板或器件的计划,有些厂商会提供一份开发指南或使用手册作为附带资料,并提供下载。这种方式可以确保下载到与您拥有的器件完全匹配的开发指南。 无论选择何种方式进行下载,我们建议事先对下载来源进行验证,并参考其他用户的评价和评级。同时,确保下载到的指南版本与您所使用的开发工具和器件相匹配,并留意相关的更新和补丁文件。 总之,探索者STM32F4开发指南-库函数版是一本实用的开发指南,可以帮助开发者快速上手和深入学习STM32F4的开发和应用。希望以上信息能够对您有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

天地神仙

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

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

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

打赏作者

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

抵扣说明:

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

余额充值