STM32用标准库做定时器定时1秒更新OLED的计数值(Proteus仿真)

首先新建proteus工程,绘制电路图:

然后赋值我之前文章中提到的文件夹OLED屏幕显示:(没有的自己去那篇文章下载去)

然后进入文件夹:

新建两个文件在Mycode文件夹中:

文件关系如下:

新建的两个文件的具体内容如下,整个编程过程特意整理了一个功能框图,下次看着框图就能写程序了。不用在想应该用哪个函数了,都标记好了:

timer.h的代码:

#ifndef __TIMER_H
#define __TIMER_H

void timer_init(void);

int timer_Get(void);
	



#endif

timer.c的代码:

#include "stm32f10x.h"                  // Device header

extern int num;

/**
  * 函    数:定时中断初始化
  * 参    数:无
  * 返 回 值:无
初始化过程7步,背下来
  //1 RCC配置时钟
  //2 配置内部时钟源
  //3  时基单元初始化
  // 4 中断输出配置
  // 5 NVIC分组
  // 6 NVIC初始化
  // 7TIM 使能
  */
void timer_init(void)
{
	/*开启时钟*/
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);			//开启TIM2的时钟
	
	/*配置时钟源*/
	TIM_InternalClockConfig(TIM2);		//选择TIM2为内部时钟,若不调用此函数,TIM默认也为内部时钟
	
	/*时基单元初始化*/
	TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;				//定义结构体变量
	TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1;		//时钟分频,选择不分频,此参数用于配置滤波器时钟,不影响时基单元功能
	TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;	//计数器模式,选择向上计数
	
	//                计时时间 = 72MHz/(ARR+1)/(PSC+1)    72000 000 / 10000 / 7200  正好等于1  就是1秒
	TIM_TimeBaseInitStructure.TIM_Period = 1000 - 1;				//计数周期,即ARR的值(自动重装的值)
	TIM_TimeBaseInitStructure.TIM_Prescaler = 7200 - 1;				//预分频器,即PSC的值
	TIM_TimeBaseInitStructure.TIM_RepetitionCounter = 0;			//重复计数器,高级定时器才会用到
	
	TIM_TimeBaseInit(TIM2, &TIM_TimeBaseInitStructure);				//将结构体变量交给TIM_TimeBaseInit,配置TIM2的时基单元	
	
	/*中断输出配置*/
	TIM_ClearFlag(TIM2, TIM_FLAG_Update);						//清除定时器更新标志位
																//TIM_TimeBaseInit函数末尾,手动产生了更新事件
																//若不清除此标志位,则开启中断后,会立刻进入一次中断
																//如果不介意此问题,则不清除此标志位也可
	
	TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);					//开启TIM2的更新中断
	
	/*NVIC中断分组*/
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);				//配置NVIC为分组2
																//即抢占优先级范围:0~3,响应优先级范围:0~3
																//此分组配置在整个工程中仅需调用一次
																//若有多个中断,可以把此代码放在main函数内,while循环之前
																//若调用多次配置分组的代码,则后执行的配置会覆盖先执行的配置
	
	/*NVIC配置*/
	NVIC_InitTypeDef NVIC_InitStructure;						//定义结构体变量
	NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;				//选择配置NVIC的TIM2线
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;				//指定NVIC线路使能
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;	//指定NVIC线路的抢占优先级为2
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;			//指定NVIC线路的响应优先级为1
	
	NVIC_Init(&NVIC_InitStructure);								//将结构体变量交给NVIC_Init,配置NVIC外设
	
	/*TIM使能*/
	TIM_Cmd(TIM2, ENABLE);			//使能TIM2,定时器开始运行
}


//  定时器2的中断函数
void TIM2_IRQHandler(void)
{
	if(TIM_GetITStatus(TIM2, TIM_IT_Update) == SET)  //如果更新中断标志位为1
	{
		num++;
		TIM_ClearITPendingBit(TIM2,TIM_IT_Update);   // 清除更新中断标志位
	}
}


main函数的代码:

#include "stm32f10x.h"
#include "OLED.h"
#include "timer.h"

int num=0;   //声明变量 num

int main(void)
{
	OLED_Init();       //oled  屏幕初始化
	timer_init();     //定时器初始化
	
	OLED_ShowString(1,5, "Num:");  // 1行5列  显示Num
	OLED_ShowString(2,1, "Counter:");  // 2行1列显示 Counter:
	
	while(1)
	{
		OLED_ShowNum(1,9,num, 5);  // 显示num的值
		OLED_ShowNum(2,9,TIM_GetCounter(TIM2), 5);  //显示CNT计数的值(自动重装的值)
	}
}

剩下的就是编译导入proteus中仿真就好了,每隔1秒钟就会num自加1:

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尚久龙

你的鼓励是我最大的动力!谢谢!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值