11. GPIO原理与配置(跑马灯,蜂鸣器,按键)

发布者:精品古钱斋最新更新时间:2017-11-09 来源: eefocus关键字:GPIO  跑马灯  蜂鸣器  按键 手机看文章 扫描二维码
随时随地手机看文章

一。STM32 GPIO固件库函数配置方法

1. 根据需要在项目中删掉一些不用的固件库文件,保留有用的固件库文件

11. <wbr>GPIO原理与配置(跑马灯,蜂鸣器,按键)

2. 在stm32f10x_conf.h中注释掉这些不用的头文件

11. <wbr>GPIO原理与配置(跑马灯,蜂鸣器,按键)
3. STM32的IO口可以由软件配置成如下8种模式(4种输入模式,4种输出模式)

分别在CRL寄存器和CRH寄存器中配置,配置每一个IO口需要4位来配置

2位MODE位----配置是输入模式还是输出模式

2位CNF位---根据MODE位的配置来确定是哪种输入模式或输出模式

a。输入浮空

b。输入上拉

c。输入下拉

d。模拟输入

e。开漏输出

f。推挽输出

g。推挽式复用功能

h。开漏复用功能

配置函数

void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct);

4。GPIO输入值的读取

IDR是一个端口输入数据寄存器,只用了低16位。

操作IDR寄存器读取IO端口数据是通过GPIO_ReadInputDataBit函数实现的:

uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);

比如我要读 GPIOA.5 的电平状态,那么方法是:

GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_5);

uint16_t GPIO_ReadInputData(GPIO_TypeDef* GPIOx);

5. 往某个IO口输出数据

ODR 是一个端口输出数据寄存器,也只用了低 16 位。该寄存器为可读写,从该寄存器读出来的数据可以用于判断当前 IO 口的输出状态。而向该寄存器写数据,则可以控制某个 IO 口的输出电平。

在固件库中设置 ODR 寄存器的值来控制 IO 口的输出状态是通过函数 GPIO_Write 来实现的:

void GPIO_Write(GPIO_TypeDef* GPIOx, uint16_t PortVal); 

该函数一般用来往一次性一个 GPIO 的多个端口设值。

BSRR 寄存器是端口位设置/清除寄存器。该寄存器和 ODR 寄存器具有类似的作用,都可以用来设置 GPIO 端口的输出位是 1 还是 0。

低16位,往某个IO口写1对应高电平,写0不起任何作用

高16位,如果往某个IO口写1,则对应IO口为低电平,写0不起任何作用

void GPIO_SetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);

void GPIO_ResetBits(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);


6. GPIO的使用步骤

1)  使能 IO 口时钟。调用函数为 RCC_APB2PeriphClockCmd()。

2)  初始化 IO 参数。调用函数 GPIO_Init();

3)  操作 IO。

二。跑马灯实验

1.在项目中添加HARDWARE目录,在里面新建LED目录

2.项目中添加led.c文件以及头文件

//led.h文件

#ifndef __LED_H

#define __LED_H  

#include "sys.h"

#define LED0 PBout(5)// PB5

#define LED1 PEout(5)// PE5

void LED_Init(void);   //初始化

#endif

led.c文件

#include "led.h"

void LED_Init(void)

{

 

 GPIO_InitTypeDef  GPIO_InitStructure;

 

 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIOE, ENABLE); //使能PB,PE端口时钟

 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5; //LED0-->PB.5 端口设置

 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出

 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //IO口速度为50MHz

 GPIO_Init(GPIOB, &GPIO_InitStructure); //根据设定参数初始化GPIOB.5

 GPIO_SetBits(GPIOB,GPIO_Pin_5); //PB.5 输出高

 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;     //LED1-->PE.5 端口设置,推挽输出

 GPIO_Init(GPIOE, &GPIO_InitStructure);   //推挽输出,IO口速度为50MHz

 GPIO_SetBits(GPIOE,GPIO_Pin_5); //PE.5 输出高

}

三。位带操作

位带操作简单的说, 就是把每个比特膨胀为一个 32 位的字,当访问这些字的时候就达到了访问比特的目的。

并不是每一个位都可以映射到一个字。

在sys.h中的定义

//IO口操作,只对单一的IO口

//确保n的值小于16

#define PAout(n)   BIT_ADDR(GPIOA_ODR_Addr,n)  //输出

#define PAin(n)    BIT_ADDR(GPIOA_IDR_Addr,n)  //输入 

#define PBout(n)   BIT_ADDR(GPIOB_ODR_Addr,n)  //输出 

#define PBin(n)    BIT_ADDR(GPIOB_IDR_Addr,n)  //输入 

#define PCout(n)   BIT_ADDR(GPIOC_ODR_Addr,n)  //输出

#define PCin(n)    BIT_ADDR(GPIOC_IDR_Addr,n)  //ÊäÈë 

#define PDout(n)   BIT_ADDR(GPIOD_ODR_Addr,n)  //输出 

#define PDin(n)    BIT_ADDR(GPIOD_IDR_Addr,n)  //输入  

#define PEout(n)   BIT_ADDR(GPIOE_ODR_Addr,n)  //输出

#define PEin(n)    BIT_ADDR(GPIOE_IDR_Addr,n)  //输入 

#define PFout(n)   BIT_ADDR(GPIOF_ODR_Addr,n)  //输出

#define PFin(n)    BIT_ADDR(GPIOF_IDR_Addr,n)  //输入 

#define PGout(n)   BIT_ADDR(GPIOG_ODR_Addr,n)  //输出

#define PGin(n)    BIT_ADDR(GPIOG_IDR_Addr,n)  //输入 

四。蜂鸣器实验

11. <wbr>GPIO原理与配置(跑马灯,蜂鸣器,按键)
BEEP输出高电平,三极管导通,蜂鸣器响

五。按键输入实验

11. <wbr>GPIO原理与配置(跑马灯,蜂鸣器,按键)

因为要检测按键,所以IO口要设置成输入模式

//按键初始化函数

void KEY_Init(void) //IO 初始化

GPIO_InitTypeDef GPIO_InitStructure; 

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOE,ENABLE);  //使能 PORTA,PORTE 时钟

GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4;//GPIOE.2~4

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;      //PE2,PE3,PE4设置成上拉输入

GPIO_Init(GPIOE, &GPIO_InitStructure);  //初始化 GPIOE2,3,4

GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_0;        //初始化  WK_UP-->GPIOA.0

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD;    //PA0 设置成下拉输入

GPIO_Init(GPIOA, &GPIO_InitStructure);  //初始化 GPIOA.0

}

//按键处理函数,不支持多个按键同时按下

//返回按键值

//mode:0,不支持连续按;1,支持连续按;

//0,没有任何按键按下;1, KEY0 按下;2, KEY1 按下;3, KEY2 按下  ;4, KEY3 按下  WK_UP

//注意此函数有响应优先级,KEY0>KEY1>KEY2>KEY3!!

u8 KEY_Scan(u8 mode)

static u8 key_up=1;                               //按键按松开标志

if(mode)key_up=1;                                //支持连按   

if(key_up&&(KEY0==0||KEY1==0||KEY2==0||KEY3==1))

{

delay_ms(10);                               //去抖动

key_up=0;

if(KEY0==0)return KEY_RIGHT;

else if(KEY1==0)return KEY_DOWN;

else if(KEY2==0)return KEY_LEFT;

else if(KEY3==1)return KEY_UP;

}else if(KEY0==1&&KEY1==1&&KEY2==1&&KEY3==0)key_up=1; 

return 0;                                       //  无按键按下

}

定义了一个变量key_up保存按键的状态,如果支持连续按下,当按键按下后不用管以前按键的状态,返回这次按键按下有效,如果不支持连续按下,就要看key_up的状态,如果以前没有按下,则返回这次按键有效,如果以前已经按下了,key_up=0,则这次按键按下无效。

key.h文件

#ifndef __KEY_H

#define __KEY_H   

#include "sys.h"

#define KEY0   GPIO_ReadInputDataBit(GPIOE,GPIO_Pin_4)  //读取按键 0

#define KEY1   GPIO_ReadInputDataBit(GPIOE,GPIO_Pin_3)  //读取按键 1

#define KEY2   GPIO_ReadInputDataBit(GPIOE,GPIO_Pin_2)  //读取按键 2 

#define KEY3   GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_0)  //读取按键 3(WK_UP) 

#define KEY_UP      4

#define KEY_LEFT  3

#define KEY_DOWN  2

#define KEY_RIGHT  1

void KEY_Init(void);                                    //IO 初始化

u8 KEY_Scan(u8);                                       //按键扫描函数     

#endif


关键字:GPIO  跑马灯  蜂鸣器  按键 引用地址:11. GPIO原理与配置(跑马灯,蜂鸣器,按键)

上一篇:10. Systick定时器
下一篇:12. 串口实验

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

MSP430按键控制串口发送数据
#include msp430.h //MSP430G2553 - 使用USCI_A0,Up Mode, DCO SMCLK // // 介绍: 该程序利用USCI_A0来与计算机通信 通过接在P1.3口的按键来实现按一次发送一个数据 // 波特率9600,数据格式8N1 // // ACLK = 32768, SMCLK = 32768 MCLK = DCO-16M // // MSP430G2553 // ----------------- // /|| XIN|- // | | | // --|RST XOUT|- // |
[单片机]
单片机通过软件实现按键消抖
通过上图可以看出理想波形与实际波形之间是有区别的,实际波形在按下和释放的瞬间都有抖动的现象,抖动时间的长短和按键的机械特性有关,一般为5~10ms。通常我们手动按键然后释放,这个动作中稳定闭合的时间超过了20ms。因此单片机在检测键盘是否按下时都要加上去抖动操作,有专用的去抖动电路,也有专门的去抖动芯片,但通常我们采用软件延时的方法就可以解决抖动问题。 软件实现如下: //软件去抖if (0 == Keyport) // 如果有键按下{ delay_ms(8); // 延时一段时间消抖 if (0 == Keyport) // 如果真的有键按下检测到的是稳定闭合状态 { ......; /
[单片机]
单片机通过软件实现<font color='red'>按键</font>消抖
关于STM32中的GPIO位设置的相关纪要与总结
1.在对GPIOx_ODR的个别位进行编程时,软件不需要禁止中断。 2.GPIO具有锁定机制。主要是在一些关键引脚上为了防止程序跑掉而引起不必要的后果。 3.GPIO的库函数问题, GPIO_SetBits:置所选端口的一个或者多个位高; GPIO_ResetBits:相应的设置相应的一个或者多个位高; GPIO_Init:设置A,B,C,D,E端口的任一个I/O的输入输出配置信息,初始化I/O芯片; GPIO_Pin:设置带选择的引脚号(GPIO_Pin_1:选中1引脚); GPIO_Speed:设置所选中的引脚的频率(GPIO_Speed_10MHz); GPIO_Mode:设置所选中的引脚的工作状态,做以上几步都必须先定
[单片机]
STM32入门-GPIO端口的八种工作模式
STM32是一种高性能、低功耗、集成度高的微控制器,广泛应用于各种嵌入式系统中。其中,GPIO(General Purpose Input/Output)端口是STM32的核心功能之一,可以实现控制外设、输入输出数据等多种功能。GPIO端口具有八种不同的工作模式,本文将详细介绍这些工作模式及其应用。 1. 输入模式(Input mode) 输入模式是GPIO端口最基本的工作模式,用于接收外部信号并读取其电平状态。在输入模式下,GPIO端口通常具有三种状态:高电平、低电平和浮空状态。当外部信号为高电平时,GPIO端口会输出高电平;当外部信号为低电平时,GPIO端口会输出低电平;当外部信号未接入时,GPIO端口处于浮空状态。 输入
[单片机]
STM32入门-<font color='red'>GPIO</font>端口的八种工作模式
STM32学习笔记之GPIO的基本使用
楼学习中主要使用的资料有 战舰V3资料盘——教学视频 《STM32F1开发指南-库函数版本_V3.1》 (PDF) 《零死角玩转STM32》 野火出版 使用的学习板为屹讯电子嵌入式平台v2(MCU为 STM32F103RCT6) **某些IO口带有FT标识,代表其最大工作电压达到5V CPU能直接读取外设电平 上拉电阻的作用????????????????? 下拉电阻 CPU能直接读取外部电压变化(模拟量) 0-3.3v 输出控制电路置1,输出由外部电路决定(上拉或下拉) 输出控制电路置0,输出为0 置1置0的写入由CPU执行 输出控制电路的写入由外设模块决定 输出控制电路置1,输出1;置0,输出0。
[单片机]
STM32学习笔记之<font color='red'>GPIO</font>的基本使用
单片机三种按键模式 单击 双击 长按
/************************************************************************** 函数功能:按键扫描 入口参数:双击等待时间 返回 值:按键状态 0:无动作 1:单击 2:双击 key=0是按下的意思 **************************************************************************/ u8 click_N_Double (u8 time) { static u8 flag_key,count_key,double_key; static u16 count_single,Forever_coun
[单片机]
MCU学习之按键控制LED
程序 : /** * 读IO, 用按钮控制点灯. */ #include #include // 10个LED sbit P10 = P1^0; sbit P11 = P1^1; sbit P12 = P1^2; sbit P13 = P1^3; sbit P14 = P1^4; sbit P15 = P1^5; sbit P16 = P1^6; sbit P17 = P1^7; // 定义开关. 低电平有效. sbit K1 = P3^2; sbit K2 = P3^5; void main( void ) { while( 1 ) { if( !K1 ) // K1按下, 点亮LED
[单片机]
嵌入式系统中可配置式GPIO模拟SPI总线方法
在嵌入式系统处理器中有相当一部分处理器不带SPI接口,但基丁SPI接口的设备非常丰富,此外,SPI设备的不同以及处理器对GPIO口位寻址是否支持各处理器各有不同,因而不同处理器中软件模拟GPIO也各不相同。若能提供一种通用可配置可移植的GPIO模拟SPI总线的驱动则能很方便快捷的访问SPI设备,从而提高整个嵌入式系统的开发效率。本文针对GPIO口位寻址与否给出方面,给出了一种可配置GPIO模拟SPI总线的方法并详细介绍了其设计与实现过程,且具有代码小可移植性强使用方便等特点。 1 GPIO规范 SPI是一个全双工的串行接口。它设计成可以在一个给定总线上处理多个互联的主机和从机。在一定数据传输过程中,接口上只能有一个丰机和一个从
[应用]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • Linux内核移植
    实验步骤:(1)准备工作(2)修改顶层Makefile(3)修改falsh 分区(4)配置编译内核下面以Linux2 6 30 4内核移植到gec2440为例:一、准备 ...
  • S5PV210 PWM定时器
    第一节 S5PV210的PWM定时器S5PV210共有5个32bit的PWM定时器,其中定时器0、1、2、3有PWM功能,定时器4没有输出引脚。PWM定时器使用PCLK_PS ...
  • S5PV210 NAND Flash
    NAND Flash关于NAND FlashS5PV210的NAND Flash控制器有如下特点:1) 支持512byte,2k,4k,8k的页大小2) 通过各种软件模式来进行NAND Fl ...
  • S5PV210串口
    串口设置之输入输出字符S5PV210 UART相关说明 通用异步收发器简称UART,即UNIVERSAL ASYNCHRONOUS RECEIVER AND TRANSMITTER,它用来 ...
  • S5PV210按键控制LED
    原理图如图所示:查询用户手册得到:程序例子:(完整代码见“代码下载链接”)1、轮询的方式查询按键事件 *main c* 核心代码如下:while(1 ...
  • S5PV210控制蜂鸣器
  • S5PV210的启动过程
  • S5PV210点亮LED
  • S5PV210启动过程详解
何立民专栏 单片机及嵌入式宝典

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

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved