stm32中,运用计时器(Tim)实现按键测速,要求:按下某一键,计时器从0

stm32中,运用计时器(Tim)实现按键测速,要求:按下某一键,计时器从0,第1张

这里我说一下软件方面的 *** 作,根据你的描述,要实现这个功能,需要一个定时器和两个外部中断配合使用。

开始先把定时器和外部中断初始化设置好,时钟和中断也是。外部中断配置为边沿触发,就是按键按下说产生的边沿信号(上升凳旁沿或下降沿),在外部中断函数里面一个写清零定时器并使能计时,另一个里面写读取计时值,并显示计时桥运数据,就好了。

其实是个很简单的程序,楼主基础不够牢实,需要多了解学习一下单片机的工作原理等知识。

上述是我提供的思路,写出完整工枣消橡程代码需要有些基础才行,不过,这个小功能很适合初学者练习。

我有一个大问题。我不知道如何用按钮停止计时器并用另一个按钮重新启动计时器。陵掘

这是我到目前为止的代码:

此代码是启动计时器的按钮的中断处理程序。我认为通过仔汪乱启用定时器是可能的,到目前为止它是有效的。

void EXTI0_1_IRQHandler(void)

{

if ((EXTI->PR &EXTI_PR_PR1) == EXTI_PR_PR1) /* Check line 1 has triggered the IT */

{

EXTI->PR = EXTI_PR_PR1/* Clear the pending bit */

NVIC_EnableIRQ(TIM7_IRQn)

}

}

此代码是停止计时器的按钮的中断处理程序。这段代码不起作用,计时器一直亮着。

void EXTI4_15_IRQHandler(void)

{

if ((EXTI->PR &EXTI_PR_PR4) == EXTI_PR_PR4) /* Check line 1 has triggered the IT */

{

EXTI->PR = EXTI_PR_PR4/* Clear the pending bit */

NVIC_DisableIRQ(TIM7_IRQn)

}

}

有没有人有一些提示或知道它必须是念档怎样的?

最佳答案

我认为“NVIC_DisableIRQ(TIM7_IRQn)”只需禁用计时器的中断但不停止计时器。

您可能需要:“TIM_Cmd(TIM7, DISABLE)”而不是“NVIC_DisableIRQ(TIM7_IRQn)”

单片机编程过程中经常用到延时函数,最常用的莫过于微秒级延时delay_us(

)和毫秒级delay_ms(

)。1.普通延时法这个比较简单,让单片机做一些无关紧要的工作来打发时间,经常用循环来实现,不过要做的比较精准还是要下一番功夫。下面的代码是在网上搜到的,经测试延时比较精准。//粗延时函数,微秒

void delay_us(u16 time)

{

u16 i=0

while(time--)

{

i=10//自己定义

while(i--)

}

}

//毫秒级的延时

void delay_ms(u16 time)

{

u16 i=0

while(time--)

{

i=12000//自己定义

while(i--)

}

}2.SysTick 定时器延时CM3 内核的处理器,内部包含了一个SysTick

定时器,SysTick 是一个24 位的倒计数定时器,当计到0 时,将从RELOAD

寄存器中自动重装载定时初值。只要不把它滚如在SysTick

控制及状态寄存器中的使能位清除,就永不停息。SysTick 在STM32

的参考手册里面介绍的很简单,大宏启其详细介绍,请参阅《Cortex-M3 权威指南》。

这里面也有两种方式实现:a.中断方式

如下,定义延时时间time_delay,SysTick_Config()定义中断时间段,在中断中递减time_delay,从而实现延时。

volatile unsigned long time_delay//

延时时间,注意定义为全局变量

//延时绝配n_ms

void delay_ms(volatile unsigned long nms)

{

//SYSTICK分频--1ms的系统时钟中断

if (SysTick_Config(SystemFrequency/1000))

{

while (1)

}

time_delay=nms//读取定时时间

while(time_delay)

SysTick->CTRL=0x00//关闭计数器

SysTick->VAL =0X00//清空计数器

}

//延时nus

void delay_us(volatile unsigned long nus)

{

//SYSTICK分频--1us的系统时钟中断

if (SysTick_Config(SystemFrequency/1000000))

{

while (1)

}

time_delay=nus//读取定时时间

while(time_delay)

SysTick->CTRL=0x00//关闭计数器

SysTick->VAL =0X00//清空计数器

} //在中断中将time_delay递减。实现延时void

SysTick_Handler(void)

{

if(time_delay)

time_delay--


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12450379.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-23
下一篇2023-05-23

发表评论

登录后才能评论

评论列表(0条)

    保存