基于STM32的多功能秒表

基于STM32的多功能秒表

当上电运行后,按下KEY1,秒表开始正计时,再次按下KEY1秒表停止计时,按下KEY2秒表清零,按下KEY3,手动调节秒表时间递增,按下KEY4手动调节秒表时间递减,按下KEY5秒表倒计时,倒计时到0时蜂鸣器响起来。

#include "stm32f10x.h"
#include "sys.h"
#define FM PBout(10)
#define uint unsigned int
#define KEY1 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_11)
#define KEY2 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_12)
#define KEY3 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_13)
#define KEY4 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_14)
#define KEY5 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_15)
void Smg_Init(void);
void Key_Init(void);
void FM_Init(void);  //蜂鸣器初始化
void Delay(void);
void TIM3_Init(u16 arr,u16 psc);
void TIM2_Init(u16 arr,u16 psc);
uint arr1[]={
   
   0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//没有小数点数码管
uint arr2[]={
   
   0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef};//小数点数码管
uint disp1[2],disp2[2];
uint ID=0;
uint b=0;
uint a,temp1,temp2,flag=0;
int main(void)
{
   
   
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); //设置2位抢占优先级2位响应优先级
    Smg_Init();
    Key_Init();
    FM_Init();
    TIM3_Init(220,7199);   //时钟参数配置
    TIM2_Init(220,7199);
    while(1)
    {
   
   
        if(KEY1==0)
        
### STM32实现秒表功能的代码示例 以下是一个基于STM32秒表功能实现代码示例,使用了SysTick定时器来完成定时操作,并通过数码管动态扫描显示时间。 ```c #include "stm32f10x.h" #define DIGIT1 GPIO_Pin_8 #define DIGIT2 GPIO_Pin_9 #define DIGIT3 GPIO_Pin_10 #define DIGIT4 GPIO_Pin_11 #define SEGMENT_PORT GPIOC #define DIGIT_PORT GPIOA u8 code table[] = {0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8, 0x80, 0x90}; // 数码管段码 u8 second = 0; // 秒计数器 u8 minute = 0; // 分钟计数器 u8 display_buf[4] = {0}; // 显示缓冲区 void delay_ms(u16 ms) { while (ms--) { for (volatile u16 i = 0; i < 1200; i++); } } void setDigit(u8 digit, u8 value) { u8 digits[4] = {DIGIT1, DIGIT2, DIGIT3, DIGIT4}; for (u8 i = 0; i < 4; i++) { if (i == digit - 1) { GPIO_ResetBits(DIGIT_PORT, digits[i]); SEGMENT_PORT->ODR = table[value]; } else { GPIO_SetBits(DIGIT_PORT, digits[i]); } delay_ms(2); } } void SysTick_Init() { SysTick->LOAD = 72000 - 1; // 设置重装载值,假设系统时钟为72MHz SysTick->VAL = 0; // 清空当前计数值 SysTick->CTRL = 5; // 使能SysTick中断和计数器 } void SysTick_Handler() { static u8 count = 0; count++; if (count >= 1000) { // 每秒触发一次 count = 0; second++; // 秒计数器加1 if (second >= 60) { // 满60秒后分钟加1 second = 0; minute++; if (minute >= 60) minute = 0; // 满60分钟后归零 } // 更新显示缓冲区 display_buf[0] = minute / 10; // 十分钟位 display_buf[1] = minute % 10; // 分钟位 display_buf[2] = second / 10; // 十秒位 display_buf[3] = second % 10; // 秒位 } } int main(void) { RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOC, ENABLE); GPIO_InitTypeDef GPIO_InitStructure; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 初始化数码管段选口 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_All; GPIO_Init(GPIOC, &GPIO_InitStructure); // 初始化数码管位选口 GPIO_InitStructure.GPIO_Pin = DIGIT1 | DIGIT2 | DIGIT3 | DIGIT4; GPIO_Init(GPIOA, &GPIO_InitStructure); SysTick_Init(); // 初始化SysTick定时器 while (1) { for (u8 i = 0; i < 4; i++) { setDigit(i + 1, display_buf[i]); // 动态扫描显示 } } } ``` #### 说明 上述代码实现了基于STM32秒表功能,具体包括以下内容[^2]: - 使用SysTick定时器进行定时操作,每毫秒产生一次中断。 - 在中断服务程序中累积计数器,当累积到1000次(即1秒)时更新秒和分钟计数器。 - 动态扫描数码管显示时间,通过`setDigit`函数控制段码和位码输出。 - 支持分钟和秒的显示,并在每个数码管位置上依次刷新以实现动态效果。 #### 注意事项 在实际应用中,需要根据具体的硬件连接调整端口定义和初始化配置。例如,如果数码管是共阳极类型,则需要对段码表中的值取反[^2]。
评论 38
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值