STM32按键控制

void GPIO_Config(void)
{
	//使能APB2总线外设时钟
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | RCC_APB2Periph_AFIO, ENABLE);
	//GPIO_PinRemapConfig(GPIO_Remap_SWJ_Disable, ENABLE);  //关闭调试 端口重新映射  使用仿真器调试时,不能用此语
	
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;  // 选择脚
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;  //配置成上拉输入
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //输出模式下 I/O输出速度 50M HZ
	GPIO_Init(GPIOB, &GPIO_InitStructure);  //初始化PB口

	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;  // 选择脚
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;  //配置成推挽输出
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //输出模式下 I/O输出速度 50M HZ
	GPIO_Init(GPIOB, &GPIO_InitStructure);  //初始化PB口
}
int main(void)
{
	RCC_Configuration(); //系统时钟配置函数    
	NVIC_Configuration();	 //NVIC配置函数
	GPIO_Config(); 
//	GPIO_Write(GPIOA,0XFFFF); //初始化PA端口让 LED处于熄灭状态
	while (1)
	{ 
		if(!GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_0))  //检测PB口的第1个管脚的电平
		{
			GPIO_SetBits(GPIOB,GPIO_Pin_1); //使第1个管脚为 1 
		}
		else
			GPIO_ResetBits(GPIOB,GPIO_Pin_1);	  //使第1个管脚为 0
	}
}

结论:

当需要从外部感应输入状态的时候,首先要做到如下几点:

1、把相应IO口设置成为输入模式;

2、调用下面的函数,返回的值就是外部的高低电平的状态。

GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_0)

当需要从控制外部元件的时候,首先要做到如下几点:

1、把相应IO口设置成为输出模式;

2、调用下面的函数,输出为高电平:

GPIO_SetBits(GPIOB,GPIO_Pin_1); //使第1个管脚为 1

3、调用下面的函数,输出为低电平:

GPIO_ResetBits(GPIOB,GPIO_Pin_1); //使第1个管脚为 0


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值