stm32f4读写w25q64

请根据提示描述你遇到的问题:stm32f4读写w25q64实现代码

  • 关于该问题,我找了一篇非常好的博客,你可以看看是否有帮助,链接:stm32f4xx-外部中断
  • 除此之外, 这篇博客: 基于stm32f4的按键检测中的 基于stm32f4的按键检测 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • 所谓按键检测,即是检测按键是长按,还是短按。(长按、短按由按键的时间的长短来衡量)通过查阅相关资料,找到了两种比较好理解的按键检测方法。一种是通过输入捕获的方式检测按键按下前后的电平转换时间,来判断按键是长按还是短按;另外一种是通过将按键扫描函数放在定时器中断里,检测按键按下前后的电平转换时间,进而判断按键状态 。但总的来说,以上这两种方式所用的方法是类似的,即通过检测电平转换时间的长短,从而确定按键是长按还是短按。
    第一种方式对应部分源码如下:

        long long temp=0;
     	temp=TIM5CH1_CAPTURE_STA&0X3F; 
    	temp*=0XFFFFFFFF;		 		         //溢出时间总和
    	temp+=TIM5CH1_CAPTURE_VAL;		   //得到总的高电平时间
    	printf("HIGH:%lld us\r\n",temp); //打印总的高点平时间
    	if(temp>=500000)//长按0.5s
        {
               switch_flag=1;
        }
       else if(temp>=100000)//短按至少0.1s
        {
              switch_flag=0;
        }
    

    第二种方式对应部分源码如下:

        //定时器3中断服务函数
    void TIM3_IRQHandler(void)
    {
    	if(TIM_GetITStatus(TIM3,TIM_IT_Update)==SET) //溢出中断
    	{
    		Key_scan();
    	}
    	TIM_ClearITPendingBit(TIM3,TIM_IT_Update);  //清除中断标志位
    }
    
    //Key_scan函数
    void Key_scan(void)
    {
    	//1 表示高电平,0表示低电平。低电平时按下	
    	if(!GPIO_ReadInputDataBit(GPIOE,GPIO_Pin_2) )//按键按下 记录按下的时间	
    	{
    		delay_ms(20);//消抖时间,后加
    		count++;
    	}
    	else //按键松开 计数值清零并返回按下的时间值
    	{
    		if(count>100)//按下经过1s  10*10ms=100ms
    		{
        		//长按
    			switch_flag= 1;
    		}
    		else if(count>10 && count <100)//表示超过10ms
    		{
    			//短按
    			switch_flag= 0;
    		}
    		else
    		{	
    			delay_ms(20);//消抖时间,后加
    		}
    		count=0;
    	}
    ...
    }
    

    而在判断出按键状态之后,可以简单地实现检测单个按键连续两次按下的相关状态。如一个按键短按一次,长按一次,控制LED翻转;随后再短按一次,长按一次,控制LED翻转。部分代码如下;

    unsigned int switch_flag=1;//初始状态设置为1,防止第一次长按时误判断
    unsigned int switch_flag_old=1;//初始状态设置为1,防止第一次长按时误判断
    unsigned int switch_flag_state=0;
    //以下语句放在key_scan函数中,上接...
    static unsigned int switch_flag_old=1;//利用static变量,防止第一次长按时,误判断		
    	if((switch_flag==1)&&(switch_flag_old==0)) //
    	{
    		if(switch_flag_state==0)//区分swtich开关状态,判断上一次开关的状态
    			switch_on();
    			else
    			switch_off(); 
    	}
    switch_flag_old=switch_flag;//表示前一个状态,到这里
    //switch闭合函数 
    void switch_on(void)
    {
    	LED1=!LED1;//DS1翻转
    	switch_flag_state=1;
    }
    //switch断开函数
    void switch_off(void)
    {
    	LED1=!LED1;//DS1翻转
    	switch_flag_state=0;
    }
    

    在实际调试过程中,参照了之前产生上升沿波形的例子。而对switch_flag,及switch_flag_old的初值设置为1,可以避免在第一次按键长按时,就会进入按键判断语句,从而使功能有误。完整代码已通过正点原子stm32f407开发板检测。欢迎各位指正。

  • 您还可以看一下 熊健老师的物联网之STM32F4编程详解课程中的 STM32F407ZGT6内部资源-02小节, 巩固相关知识点