用STM32点亮跑马灯(库函数)简洁版

发布者:Lihua1314520最新更新时间:2017-11-01 来源: eefocus关键字:STM32  跑马灯 手机看文章 扫描二维码
随时随地手机看文章

用STM32的GPIO来点亮跑马灯
步骤:
1.新建工程:复制模板中的一切文件夹,注意删除USER中模板Template产生的三个文件以及OBJ中的文件(OBJ中产生的是编译过程中产生的文件)。
2.打开keil,对工程中的各县设置进行修改(包括:右键Manage Project Items里面的各个组及头文件;魔术棒中的Output选项卡中HEX文件和Folder的修改;C/C++选项卡中Define和头文件路径的修改)
3.build工程,查看设置是否正确,注意此时各个文件前面有可能没有小加号,解决办法是Translate一下,要是还不行就关了重开。
至此新建工程完成



想要对外设进行驱动就要相应的编写函数,我们在这里只将具体要做什么事(如亮多久灭多久,一起亮还是轮流亮)放于main文件中,每个外设的初始化函数我们都放在HARDWARE文件夹下面相应的.c和.h文件中(初始化函数是要根据外设连接到了哪个端口来编写的,内容包括用了哪个端口,处于什么工作模式下等),在这里使用到了这两个文件,不要忘记添加头文件和相应的路径。

1.对.h文件的编写
(1).h文件一般用于存放函数的声明和宏定义等
(2)使用到的函数:ifndef,define,endif
#ifndef __XXXX_H
#define __XXXX_H

  A
#else
  B
#endif
这是一个宏定义,防止重复定义:如果没有定义(if not define,ifndef)过xxxx.h,那么定义(define)xxxx.h并执行A,如果定义过了就执行B,通常我们在用的时候不会用到else,那么也就直接跳过了这段代码(endif),其中的这些下划线和H是c语言的书写规范,并且都是用大写来写,如led.h就会写成_LED_H。
在本实验中的代码为:
#ifndef __LED_H  //if not define led.h
#define __LED_H  //define led.h,并执行下面的程序
void LED_Init(void);
#endif
注意:LED_Init是空函数,在末尾要加上分号,没有分号会报错。

2.对.c文件的编写
在本实验中,.c文件里面存放了led的初始化函数LED_Init,
LED_Init包括:
(1)include相应的.h文件
(2)对GPIO时钟的初始化:GPIO用的是时钟2,函数为:RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOx,ENABLE);
(3)对GPIO端口的初始化:
GPIO_InitTypeDef  GPIO_InitStructure;//定义需要初始化的结构
GPIO_InitStructure.GPIO_Mode=    //更改这个初始化了的结构中的成员Mode的初始值
GPIO_InitStructure.GPIO_Pin=        //更改这个初始化了的结构中的成员Pin的初始值
GPIO_InitStructure.GPIO_Speed=        //更改这个初始化了的结构中的成员Speed的初始值
GPIO_Init(GPIOx,&GPIO_InitStructure);  //参数设置完成,调用初始化函数
GPIO_SetBits(GPIOx,GPIO_Pin_x);   //更改端口的初始状态
下面来解释一下这些语句:
1.GPIO_Init(GPIOx,&GPIO_InitStructure);
这条语句为初始化语句,它要求我传过去两个参数,一个是到底是哪个端口,是GPIOA还是B还是C还是什么,另一个是我要初始化的东西,对于要初始化的参量,它们被放在一个名为GPIO_InitStructure的结构体里面了,对于这个结构体的定义,就是下一句话。
它所调用的函数是:void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct)。
2.GPIO_InitTypeDef  GPIO_InitStructure;
用到了结构必然要先定义,这句话的意思是定义一个GPIO_InitTypeDef类型的结构,名字叫做GPIO_InitStructure(当然可以叫别的名字),
在这里我们只是定义了一个结构,并没有对里面的成员进行定义(里面的都是默认值,需要设置哪个再单独去改),下面三行语句是以引用成员的方式对其初始值进行了修改。
GPIO_InitStructure.GPIO_Mode=
GPIO_InitStructure.GPIO_Pin=
GPIO_InitStructure.GPIO_Speed=
关于这三个初始状态的设置,我们需要根据自己具体的用途来设置,格式可以gotodefinition去看,里面是枚举类型,要严格按照人家的规定来写。
3.GPIO_SetBits(GPIOx,GPIO_Pin_x);
 对端口状态进行初始化:设置LED默认不点亮,置1是不点亮,至于为什么,看电路图就明白了,LED的正连的高电平,负连的管脚。

3.main.c的编写
(1)include各个需要的文件
#include "stm32f10x.h"
#include "led.h"
#include "delay.h"
(2)编写main主函数:
一般情况下,main中包含两部分:
1.用到的各个部分的初始化,在本实验中包括led的初始化(也就是刚刚在led.c里面写的那个初始化函数),delay(延时)函数的初始化
delay_init();
led_Init();
2.函数体,本实验中的while函数,基本上我们需要的函数都会放在while(1){ }里面,因为我们要让它一直执行,而不是执行一次就完事了,但是对于比较复杂的函数,往往不是这个样子的,会有许多的判断条件。
while(1)
{
    GPIO_SetBits(GPIOA,GPIO_Pin_8);//设置LED默认不点亮
    delay_ms(500);
    GPIO_ResetBits(GPIOA,GPIO_Pin_8);//设置LED默认不点亮
    delay_ms(500);
}
说明:本实验中,main函数的返回值类型是int型的,这里要写成int main (void){   }


关键字:STM32  跑马灯 引用地址:用STM32点亮跑马灯(库函数)简洁版

上一篇:STM32串口的基本用法
下一篇:用STM32点亮跑马灯(库函数)啰嗦版

推荐阅读最新更新时间:2024-03-16 15:42

STM32学习探究:流水灯的实现
流水灯的实现 这里我们使用 stm32mini 开发板实现外接流水灯,这里我采用了三个灯(说明问题就可以了)。外接的引脚分别为PA2,PB8,PC13三个引脚,在连接的时候,采用灯的正极接GPIO引脚,负极接GND(这是一种合理的方式)。 注意:虽然接VCC也可以发光,但是这样不是合理的连接方式,而且,发光的情况刚好与接GND的情况相反。 参考的相关资料如下: 时钟使能: 端口配置: 端口输出: 具体实现的代码如下: //led.h文件 #ifndef __LED_H #define __LED_H #include sys.h //LED端口定义 #define LED0 PAout(
[单片机]
<font color='red'>STM32</font>学习探究:流水灯的实现
STM32系列第3篇--GPIO初始化
使能和初始化IO口: GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD,ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE); GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2; GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz; GPIO_Init(GPIOD,
[单片机]
STM32的ADC DMA USART综合学习
学习STM32的ADC转换,在开发板上写程序调试。 四个任务: 1.AD以中断方式(单次)采集一路 2.AD以中断方式连续采集四路 3. AD 以DMA方式采集一路,DMA深度为一级 4. AD 以DMA方式采集四路,每路DMA深度为28级,并滤波,说明滤波原理。 总结: 第一个任务 :ADC以中断方式采集一路ADC,通过配置ADC_InitStructure结构体中的ADC_ScanConvMode,它规定模数转换工作在扫描模式(多通道)还是单次模式(单通道), ADC_InitStructure.ADC_ScanConvMode=DISABLE,为单通道单次模式。 ADC_ContinuousConvMode,
[单片机]
STM32 JTAG引脚做普通I/O口用
1、开启AFIO时钟: RCC_APB2PeriphClockCmd (RCC_APB2Periph_AFIO, ENABLE) 2、改变指定管脚的映射GPIO_Remap_SWJ_Disable,SWJ完全禁用(JTAG+SW-DP): GPIO_PinRemapConfig (GPIO_Remap_SWJ_Disable, ENABLE) 3、改变指定管脚的映射GPIO_Remap_SWJ_JTAGDisable,JTAG-DP禁用+SW-DP 使能: GPIO_PinRemapConfig (GPIO_Remap_SWJ_JTAGDisable, ENABLE) 注意:注意顺序,一定要先使能复用时钟,再失能JATG。
[单片机]
STM32时钟设置
3.5的库中什么也不用做。已经在启动文件中设置好了时钟。 大家都知道在使用单片机时,时钟速度决定于外部晶振或内部RC振荡电路的频率,是不可以改变的。而ARM的出现打破了这一传统的法则,可以通过软件随意改变时钟速度。这一出现让我们的设计更加灵活,但是也给我们的设计增加了复杂性。为了让用户能够更简单的使用这一功能,STM32的库函数已经为我们设计的更加简单方便。 在比较靠前的版本中,我们需要向下面那样设置时钟: ErrorStatus HSEStartUpStatus; void RCC_Configuration(void) { RCC_DeInit(); // RCC system reset
[单片机]
STM32 jtag调试程序时程序跑飞
开发环境:keil MDK V5.10 操作系统:windows 7(32位) 目标硬件:STM32F103C8 问题描述:在使用jtag对某软件进行调试的时候,KEIL可以正常的进行软件下载,一旦使用F5全速运行时,立即发现程序跑飞了,暂停后汇编代码显示“MOVS R0 R0”。程序跑飞的时候可以看到目标设备程序执行过程正常(灯正常闪烁,串口调试信息正常输出)。 问题原因:芯片的JTAG引脚被复用,在程序初始化阶段将JTAG引脚remap为了普通的IO引脚导致。 PS:在使用JTAG进行程序调试的时候,如果程序中开了看门狗,调试程序进行了单步调试的情况也可能导致JTAG无法正常使用,因为目标设备的看门狗不能因为单步执行
[单片机]
【STM32+W5500】20,W5500作为Client客户端
与DNS失败一样,只需要把W5500的默认IP改成和路由器的IP一样就可以互联网通信了 实测收到邮件
[单片机]
【STM32+W5500】20,W5500作为Client客户端
STM32低功耗唤醒方式
MCU进入低功耗之后,以极低的功耗维持着系统“活着”,但是醒过来是需要一定条件的,比如定个“闹钟”,按键“按一下”等,目前常用的“正常的”唤醒方式有以下几种: 1、RTC定时唤醒; 2、外部中断唤醒(按键或者通讯唤醒); 3、特殊唤醒引脚唤醒(某些引脚具有专门的唤醒功能)。 下面,我们再来看一看如何通过RTC和外部中断唤醒MCU。 1、RTC定时唤醒 依然是从手册中我们可以看到,所有的RTC时间都可以把MCU从低功耗模式中唤醒: 介绍使用RTC的定时功能实现,定时1S唤醒一次,使用cubemx进行对RTC进行配置: 生成代码的时候,勾选这个选项,可以把不用的引脚配置为模拟输入模式,降低功耗: RTC的配置如图,使能RTC,
[单片机]
<font color='red'>STM32</font>低功耗唤醒方式
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved