【单片机】数码管前三位品示一个跑 表,从000到999之间以1%秒速度 运行,当按下一个独立键盘时跑表停 止,松开手后跑表继续运行

时间: 2024-03-09 07:48:01 浏览: 21
好的,这是一个使用单片机控制数码管实现跑表功能的例子。以下是步骤: 1. 确定使用的单片机和数码管类型,并连接电路。这里以STM32F103C8T6单片机和共阳极4位数码管为例,数码管的接口为PA0-PA3。 2. 编写初始化程序,设置GPIO端口为输出模式,并将数码管的所有段熄灭。 3. 编写计数器程序,使用定时器中断计算时间,每隔1%秒更新计数器的值,同时将计数器的值转换为数码管的输出,显示在数码管上。 4. 编写中断程序,处理按键事件。当按下按键时,停止计数器的计数,同时将计数器的值保存下来。当松开按键时,恢复计数器的计数,并将计数器的值更新为保存的值,使得数码管从停止的地方继续运行。 以下是示例代码: ``` #include "stm32f10x.h" #define SEG_A GPIO_Pin_0 #define SEG_B GPIO_Pin_1 #define SEG_C GPIO_Pin_2 #define SEG_D GPIO_Pin_3 #define SEG_E GPIO_Pin_4 #define SEG_F GPIO_Pin_5 #define SEG_G GPIO_Pin_6 #define SEG_DP GPIO_Pin_7 #define DIGIT_0 GPIO_Pin_8 #define DIGIT_1 GPIO_Pin_9 #define DIGIT_2 GPIO_Pin_10 #define DIGIT_3 GPIO_Pin_11 #define KEY GPIO_Pin_12 int digitToSeg[] = {SEG_A|SEG_B|SEG_C|SEG_D|SEG_E|SEG_F, // 0 SEG_B|SEG_C, // 1 SEG_A|SEG_B|SEG_G|SEG_E|SEG_D, // 2 SEG_A|SEG_B|SEG_C|SEG_D|SEG_G, // 3 SEG_F|SEG_G|SEG_B|SEG_C, // 4 SEG_A|SEG_F|SEG_G|SEG_C|SEG_D, // 5 SEG_A|SEG_F|SEG_E|SEG_D|SEG_C|SEG_G, // 6 SEG_A|SEG_B|SEG_C, // 7 SEG_A|SEG_B|SEG_C|SEG_D|SEG_E|SEG_F|SEG_G,// 8 SEG_A|SEG_B|SEG_C|SEG_D|SEG_F|SEG_G}; // 9 volatile uint32_t counter = 0; volatile uint32_t savedCounter = 0; volatile int stopFlag = 0; void initGpio(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); GPIO_InitStructure.GPIO_Pin = SEG_A | SEG_B | SEG_C | SEG_D | SEG_E | SEG_F | SEG_G | SEG_DP | DIGIT_0 | DIGIT_1 | DIGIT_2 | DIGIT_3 | KEY; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); } void initTimer(void) { TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; NVIC_InitTypeDef NVIC_InitStructure; RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); TIM_TimeBaseStructure.TIM_Period = 9999; TIM_TimeBaseStructure.TIM_Prescaler = 7199; TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_ClearFlag(TIM2, TIM_FLAG_Update); TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); TIM_Cmd(TIM2, ENABLE); } void displayDigit(int digit, int dp, int digitIndex) { uint16_t seg = digitToSeg[digit]; if (dp) { seg |= SEG_DP; } switch (digitIndex) { case 0: GPIO_SetBits(GPIOA, DIGIT_0); GPIO_ResetBits(GPIOA, DIGIT_1 | DIGIT_2 | DIGIT_3); break; case 1: GPIO_SetBits(GPIOA, DIGIT_1); GPIO_ResetBits(GPIOA, DIGIT_0 | DIGIT_2 | DIGIT_3); break; case 2: GPIO_SetBits(GPIOA, DIGIT_2); GPIO_ResetBits(GPIOA, DIGIT_0 | DIGIT_1 | DIGIT_3); break; case 3: GPIO_SetBits(GPIOA, DIGIT_3); GPIO_ResetBits(GPIOA, DIGIT_0 | DIGIT_1 | DIGIT_2); break; } GPIO_Write(GPIOA, seg); } void displayCounter(uint32_t counter) { if (counter > 999) { counter = 999; } int d1 = counter / 100; int d2 = counter / 10 % 10; int d3 = counter % 10; displayDigit(d1, 0, 0); displayDigit(d2, 1, 1); displayDigit(d3, 0, 2); } void TIM2_IRQHandler(void) { if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { TIM_ClearITPendingBit(TIM2, TIM_IT_Update); if (!stopFlag) { counter++; displayCounter(counter); } } } void EXTI15_10_IRQHandler(void) { if (EXTI_GetITStatus(EXTI_Line12) != RESET) { EXTI_ClearITPendingBit(EXTI_Line12); if (stopFlag) { stopFlag = 0; counter = savedCounter; } else { stopFlag = 1; savedCounter = counter; } } } int main(void) { initGpio(); initTimer(); GPIO_SetBits(GPIOA, KEY); EXTI_InitTypeDef EXTI_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE); GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource12); EXTI_InitStructure.EXTI_Line = EXTI_Line12; EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt; EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling; EXTI_InitStructure.EXTI_LineCmd = ENABLE; EXTI_Init(&EXTI_InitStructure); NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); while (1) { } return 0; } ``` 在该示例代码中,按下KEY键时,跑表会暂停,再次按下KEY键可以恢复跑表。

相关推荐

最新推荐

recommend-type

单片机控制的电动机_Y_三角形_启动电路设计_李静.pdf

动时间为 秒 由按键设置电动机 运行停止等功能为智能控制和精确控制电动机启动提供了有效的解决方案是一个典型的弱电控 制强电的设计本文对系统各模块进行了详细设计重点论述了系统各模块的硬件电路设计对软件设计和...
recommend-type

ARM 实验指导书第一册UCOS-II.doc

据统计数字表明,2002年32位嵌入式微处理器市场销售额排在前3位的公司分别是ARM,Motorola和MIPS,其中ARM公司的芯片销售量达1.5亿个,市场份额超过70%。 ARM是一类处理器的名字,同时也是一个公司的名字。ARM公司...
recommend-type

setuptools-58.0.3.tar.gz

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用matlab绘制高斯色噪声情况下的频率估计CRLB,其中w(n)是零均值高斯色噪声,w(n)=0.8*w(n-1)+e(n),e(n)服从零均值方差为se的高斯分布

以下是用matlab绘制高斯色噪声情况下频率估计CRLB的代码: ```matlab % 参数设置 N = 100; % 信号长度 se = 0.5; % 噪声方差 w = zeros(N,1); % 高斯色噪声 w(1) = randn(1)*sqrt(se); for n = 2:N w(n) = 0.8*w(n-1) + randn(1)*sqrt(se); end % 计算频率估计CRLB fs = 1; % 采样频率 df = 0.01; % 频率分辨率 f = 0:df:fs/2; % 频率范围 M = length(f); CRLB = zeros(M,1); for
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这