单片机万年历c语言程序设计,基于AT89C51单片机的多功能电子万年历的设计(附程序)...

时间: 2023-06-19 10:03:45 浏览: 85
以下是一个基于AT89C51单片机的多功能电子万年历的C语言程序设计示例: ```c #include <reg51.h> #include <stdio.h> #include <string.h> #define uchar unsigned char #define uint unsigned int // 定义数码管显示的段码 uchar code led_seg[] = { 0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x98, 0xff, 0x88, 0x83, 0xc6, 0xa1, 0x86 }; // 定义数码管显示的位码 uchar code led_bit[] = { 0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf }; // 定义当前时间的全局变量 uchar g_year, g_month, g_day, g_week, g_hour, g_minute, g_second; // 定义当前时间的字符串数组 uchar g_time_str[20]; // 定义当前闹钟的小时和分钟 uchar g_alarm_hour, g_alarm_minute; // 定义当前闹钟是否已开启的标志 uchar g_alarm_enabled; // 定义当前模式的枚举类型 enum ModeType { MODE_TIME, MODE_ALARM_HOUR, MODE_ALARM_MINUTE, MODE_ALARM_ENABLED }; // 定义当前模式的全局变量 enum ModeType g_mode; // 定义按键扫描函数 uchar key_scan() { uchar key_value = 0xff; uchar i; // 扫描按键1~4,如果有按键按下,则返回对应的键值 for (i = 0; i < 4; i++) { P1 = ~(1 << i); if (P1 != 0xf0) { key_value = P1; while (P1 != 0xf0); break; } } // 扫描按键5,如果有按键按下,则返回对应的键值 P1 = 0x0f; if (P1 != 0x0f) { key_value = P1; while (P1 != 0x0f); } return key_value; } // 定义数码管显示函数 void led_display(uchar bit_value, uchar seg_value) { P2 = led_seg[seg_value]; P0 = led_bit[bit_value]; } // 定义更新时间函数 void update_time() { // 获取当前时间,并保存到全局变量中 // 这里需要根据实际硬件情况来实现 g_year = get_year(); g_month = get_month(); g_day = get_day(); g_week = get_week(); g_hour = get_hour(); g_minute = get_minute(); g_second = get_second(); // 根据当前模式更新数码管显示 switch (g_mode) { case MODE_TIME: sprintf(g_time_str, "%02d-%02d-%02d %02d:%02d:%02d", g_year, g_month, g_day, g_hour, g_minute, g_second); led_display(0, g_hour / 10); led_display(1, g_hour % 10); led_display(2, g_minute / 10); led_display(3, g_minute % 10); led_display(4, g_second / 10); led_display(5, g_second % 10); break; case MODE_ALARM_HOUR: led_display(0, g_alarm_hour / 10); led_display(1, g_alarm_hour % 10); led_display(2, 10); led_display(3, 10); led_display(4, 10); led_display(5, 10); break; case MODE_ALARM_MINUTE: led_display(0, g_alarm_minute / 10); led_display(1, g_alarm_minute % 10); led_display(2, 10); led_display(3, 10); led_display(4, 10); led_display(5, 10); break; case MODE_ALARM_ENABLED: led_display(0, g_alarm_enabled ? 11 : 12); led_display(1, 10); led_display(2, 10); led_display(3, 10); led_display(4, 10); led_display(5, 10); break; } } // 定义主函数 void main() { // 初始化全局变量 g_year = 0; g_month = 0; g_day = 0; g_week = 0; g_hour = 0; g_minute = 0; g_second = 0; g_alarm_hour = 0; g_alarm_minute = 0; g_alarm_enabled = 0; g_mode = MODE_TIME; // 初始化按键扫描需要的IO口 P1 = 0xf0; // 循环处理 while (1) { uchar key_value = key_scan(); // 根据当前模式处理按键事件 switch (g_mode) { case MODE_TIME: if (key_value == 0x7e) { // 按键1 g_mode = MODE_ALARM_HOUR; } else if (key_value == 0xbe) { // 按键2 g_mode = MODE_ALARM_MINUTE; } else if (key_value == 0xde) { // 按键3 g_mode = MODE_ALARM_ENABLED; } break; case MODE_ALARM_HOUR: if (key_value == 0x7e) { // 按键1 g_alarm_hour++; if (g_alarm_hour >= 24) { g_alarm_hour = 0; } } else if (key_value == 0xbe) { // 按键2 g_mode = MODE_ALARM_MINUTE; } else if (key_value == 0xde) { // 按键3 g_mode = MODE_TIME; } break; case MODE_ALARM_MINUTE: if (key_value == 0x7e) { // 按键1 g_alarm_minute++; if (g_alarm_minute >= 60) { g_alarm_minute = 0; } } else if (key_value == 0xbe) { // 按键2 g_mode = MODE_ALARM_ENABLED; } else if (key_value == 0xde) { // 按键3 g_mode = MODE_ALARM_HOUR; } break; case MODE_ALARM_ENABLED: if (key_value == 0x7e || key_value == 0xbe) { // 按键1或按键2 g_alarm_enabled = !g_alarm_enabled; } else if (key_value == 0xde) { // 按键3 g_mode = MODE_TIME; } break; } // 更新时间,并根据当前模式显示数码管 update_time(); // 检查闹钟是否已经响了 if (g_alarm_enabled && g_hour == g_alarm_hour && g_minute == g_alarm_minute) { // 这里需要根据实际硬件情况来实现 ring_alarm(); } } } ``` 注意,这只是一个示例程序,实际实现中需要根据实际硬件情况进行相应的修改。

相关推荐

最新推荐

recommend-type

基于AT89C51单片机的十进制计算器系统设计

本设计是基于AT89C51 单片机进行的十进制计算器系统设计,可以完成计算器的键盘输入,进行加、减、乘、除4 位无符号数字的简单四则运算,并在LED 上相应的显示结果。硬件方面从功能考虑,首先选择内部存储资源丰富的...
recommend-type

基于AT89C51单片机的交通灯控制系统设计与仿真

系统除基本交通灯功能外,还具有通行时间手动设置、可倒计时显示、急车强行通过、交通特殊情况处理等相关功能,实验采用AT89C51单片机为控制芯片,采用"Proteus+KeilμVision2"对交通灯控制系统进行了仿真.
recommend-type

基于AT89C51单片机的LED汉字显示屏设计方案

研究了基于AT89C51单片机16×16 LED汉字滚动显示屏的设计与运用Proteus软件的仿真实现。主要介绍了LED汉字显示屏的硬件电路、汇编程序设计与调试、Proteus软件仿真等方面的内容,本显示屏的设计具有体积小、硬件少、...
recommend-type

基于AT89C51单片机简易计算器的设计.doc

设计的是简单的计算器,可以进行四则运算(+、-、×、÷),C语言编程,PROTUES仿真,实验报告 单片机课程设计
recommend-type

基于AT89C51单片机的交通灯控制系统的设计.docx

基于AT89C51单片机的交通灯控制系统的设计(包括kei、Protuesl文件、课程设计报告论文、讲解视频)
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

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

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