蓝桥杯单片机省赛——第八届“基于单片机的电子钟程序设计与调试”程序部分

往期回顾

第三届蓝桥杯单片机省赛
第四届蓝桥杯单片机省赛
第五届蓝桥杯单片机省赛
第六届蓝桥杯单片机省赛
第七届蓝桥杯单片机省赛

文章目录

  • 往期回顾
  • 一、前期准备
  • 二、代码详情
    • 1.基础代码
      • 蜂鸣器/继电器/led/定时器之类的代码
    • 2.按键详解
      • 按键写法讲解
    • 3.驱动的处理
      • 驱动写法讲解
    • 4.温度/数码管部分处理
    • 5.DS1302部分处理
    • 6.总代码



在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

一、前期准备

1:本文使用的头文件是由stc生成
在这里插入图片描述
点击保存文件之后,保存至自己文件目录下方即可
在这里插入图片描述
2:本文使用的都是官方提供的底层驱动代码
在这里插入图片描述

二、代码详情

1.基础代码

蜂鸣器/继电器/led/定时器之类的代码

参考之前写的文章
第四届蓝桥杯代码讲解

2.按键详解

按键写法讲解

直接跳转以前的文章即可
多种蓝桥杯/51按键写法详解

3.驱动的处理

驱动写法讲解

直接跳转以前的文章即可
蓝桥杯驱动处理

4.温度/数码管部分处理

直接跳转以前的文章即可
蓝桥杯温度部分处理

5.DS1302部分处理

DS1302部分详解

6.总代码

#include<stc15f2k.h>
#include<ds1302.h>
#include<onewire.h>
sbit s7=P3^0;
sbit s6=P3^1;
sbit s5=P3^2;
sbit s4=P3^3;
char ds1302_write[]={0x80,0x82,0x84};
char ds1302_read[]={0x81,0x83,0x85};
char time[]={50,59,23};
char time_1[]={0,0,0};
char clock[]={0,0,0};
char dula[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf,0xff,0xc6};
char disdula[]={0,0,0,0,0,0,0,0};

int diswela,key,ms,wei=9,sign,con;
int temp;
bit flag,light,light_1;
void renwu_2();
void buzz(bit on)
{
	P2=((P2&0X1F)|0XA0);
	if(on)
		P0=0X40;
	else
		P0=0X00;
	P2&=0X1F;
}

void led(int i)
{
	P2=((P2&0X1F)|0X80);
	P0=i;
	P2&=0X1F;
}

void delay(int x)
{
	int i;
	while(x--)
		for(i=0;i<5*123;i++);
}

void din()
{
	TMOD=0X10;
	TH1=(65536-11059/12)/256;
	TL1=(65536-11059/12)%256;
	EA=1;
	TR1=1;
	ET1=1;
}

void display()
{
	if(diswela==wei&&ms>=1000)
		diswela=diswela+2;
	
	P2=((P2&0X1F)|0XE0);
	P0=0xff;
	P2&=0X1F;
	
	P2=((P2&0X1F)|0Xc0);
	P0=1<<diswela;
	P2&=0X1F;
	
	P2=((P2&0X1F)|0Xe0);
	P0=dula[disdula[diswela]];
	P2&=0X1F;
	
	if(++diswela>=8)diswela=0;
}

void display_ds1302()
{
	disdula[0]=time[2]/16;
	disdula[1]=time[2]%16;
	disdula[2]=10;
	disdula[3]=time[1]/16;
	disdula[4]=time[1]%16;
	disdula[5]=10;
	disdula[6]=time[0]/16;
	disdula[7]=time[0]%16;
}

void bcddce(bit on)
{
	int i;
	for(i=0;i<3;i++)
	{
		if(on)
			time_1[i]=((time[i]/10)<<4)|(time[i]%10);
		else
			time[i]=((time_1[i]/16)*10)+time_1[i]%16;
	}
}

void ds_write()
{
	int i;
	bcddce(1);
	Write_Ds1302_Byte(0x8e,0x00);
	for(i=0;i<3;i++)
	{
		Write_Ds1302_Byte(ds1302_write[i],time_1[i]);
	}
	Write_Ds1302_Byte(0x8e,0x80);
}

void ds_read()
{
	int i;
	for(i=0;i<3;i++)
	{
		time[i]=Read_Ds1302_Byte(ds1302_read[i]);
	}
}

char anjian()
{
	int keyscan=0;
	if(s4==0||s5==0||s6==0||s7==0)
	{
		delay(10);
		if(s4==0)keyscan=4;
		else if(s5==0)keyscan=5;
	  else if(s6==0)keyscan=6;
		else if(s7==0)keyscan=7;
	}while(s5==0||s6==0||s7==0);
	return keyscan;
}

void wendu()
{
	int LSB,MSB;
	Init_DS18B20();
	Write_DS18B20(0xcc);
	Write_DS18B20(0x44);
	delay(100);
	Init_DS18B20();
	Write_DS18B20(0xcc);
	Write_DS18B20(0xbe);
	LSB=Read_DS18B20();
	MSB=Read_DS18B20();
	Init_DS18B20();
	temp=MSB;
	temp=(temp<<8)|LSB;
	if((temp&0xf800)==0x0000)
	{
		temp>>=4;
		temp=temp*100;
		temp=temp+(LSB&0x0f)*6.25;
	}
}

void display_18b20()
{
	disdula[0]=11;
	disdula[1]=11;
	disdula[2]=11;
	disdula[3]=11;
	disdula[4]=11;
	disdula[5]=temp/1000%10;
	disdula[6]=temp/100%10;
	disdula[7]=12;
}

void display_clock()
{
	disdula[0]=clock[2]/10;
	disdula[1]=clock[2]%10;
	disdula[2]=10;
	disdula[3]=clock[1]/10;
	disdula[4]=clock[1]%10;
	disdula[5]=10;
	disdula[6]=clock[0]/10;
	disdula[7]=clock[0]%10;
}

void jia()
{
	if(wei==0)
	{
		clock[2]++;
		if(clock[2]>=24)clock[2]=0;
	}
	if(wei==3)
	{
		clock[1]++;
		if(clock[1]>=60)clock[1]=0;
	}
	if(wei==6)
	{
		clock[0]++;
		if(clock[0]>=60)clock[0]=0;
	}
}

void jian()
{

	if(wei==0)
	{
		clock[2]--;
		if(clock[2]<=-1)clock[2]=23;
	}
	if(wei==3)
	{
		clock[1]--;
		if(clock[1]<=-1)clock[1]=59;
	}
	if(wei==6)
	{
		clock[0]--;
		if(clock[0]<=-1)clock[0]=59;
	}
	while(!s4);
}

void renwu_6()
{
	char n=0;
	while(1)
	{
		display_clock();
		if(flag==1)
		{
			flag=0;
			key=anjian();
			switch(key)
			{
				case 4:jia();break;
				case 5:jian();break;
				case 6:
					renwu_2();
				  n++;
				break;
			}
		}
		if(n>=4)break;
	}
}

char bcdtodce(char on)
{

	on=((on/16)*10)+on%16;

	return on;
}

void ledrun()
{
	if(light_1==1)
	led(0xfe);
	if(light_1==0)
	led(0xff);
	if(light==0)
	led(0xff);
}

void renwu_1()
{
	while(1)
	{
		wendu();
		display_18b20();
		if(s4==1)
			break;
	}
}

void renwu_2()
{
	++sign;
	if(sign<=1)wei=0;
	if(sign==2)wei=3;
	if(sign==3)wei=6;
	if(sign==4)
	{
		wei=9;
		sign=0;
	}
}

void renwu_3()
{
	bcddce(0);
	if(wei==0)
	{
		time[2]++;
		if(time[2]>=24)time[2]=0;
	}
	if(wei==3)
	{
		time[1]++;
		if(time[1]>=60)time[1]=0;
	}
	if(wei==6)
	{
		time[0]++;
		if(time[0]>=60)time[0]=0;
	}
	ds_write();
}

void renwu_4()
{
	bcddce(0);
	if(wei==0)
	{
		time[2]--;
		if(time[2]<=-1)time[2]=23;
	}
	if(wei==3)
	{
		time[1]--;
		if(time[1]<=-1)time[1]=59;
	}
	if(wei==6)
	{
		time[0]--;
		if(time[0]<=-1)time[0]=59;
	}
	ds_write();
	while(!s4);
}

void main()
{
	int i;
	din();
	buzz(0);
	led(0xff);
	ds_write();
	while(1)
	{
		for(i=0;i<3;i++)
		{
			time_1[i]=time[i];
		}		
		if(light==1)ledrun();		
		display_ds1302();
		ds_read();		
		if(flag==1)
		{
			flag=0;
			key=anjian();
			switch(key)
			{
				case 4:
				if(wei==9)	
				renwu_1();
				else
				renwu_4();
				break;
				case 7:renwu_2();break;
				case 5:renwu_3();break;	
				case 6:renwu_6();break;					
			}
		}		
	}
}

void qa() interrupt 3
{
	TH1=(65536-11059/12)/256;
	TL1=(65536-11059/12)%256;
	ms++;
	if(!(ms%100))flag=1;
	if(ms==1500)ms=0;
	display();
	if(bcdtodce(time[2])==clock[2]&&bcdtodce(time[1])==clock[1]&&bcdtodce(time[0])==clock[0])
	light=1;	
	if(light==1)
		con++;
	if(con>=5000)
	{
		con=0;
		light=0;
		led(0xff);
}
	if(!(con%200))
	{
		if(light_1==0)light_1=1;
		else light_1=0;
	}
}


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/589241.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux学习笔记:进程间的通信.共享内存shm

共享内存shm 什么是共享内存shm共享内存的特点关键函数ftokshmgetshmatshmdtshmctl 代码示例 什么是共享内存shm 进程间通信的前提:必须让不同的进程看到同一份资源,并且这个资源是OS提供的 而共享内存(Share memory)就是在内核共享内存区找一块物理内存空间,并允许多个进程共…

远距离、高品质、低延迟、高保真——SA316无线音频模块带您探索新的音频体验

SA316系列产品分为发射端模块SA316S-TX,SA316F30和接收端模块SA316-RX&#xff0c;该系列方案采用了无线高品质的语音传输芯片来设计&#xff0c;它可以支持外部 PCM / IIS 双模数字音频接口&#xff0c;同时模块为客户提供了标准化的串行接口&#xff0c;使用者可通过串口指令…

使用QT完成如图的游戏登录界面 使用信号和槽完成密文明文密码转换,重置账号和密码,登录校验 详细代码在主页下载

头文件: #ifndef LOGINWIDGET_H #define LOGINWIDGET_H #include <QLineEdit> #include <QPushButton> #include <QWidget> class LoginWidget : public QWidget {Q_OBJECT public: LoginWidget(QWidget *parent = 0); ~LoginWidget(); public slots: …

全新神经网络架构KAN一夜爆火!200参数顶30万,MIT华人一作 | 最新快讯

白交衡宇发自凹非寺 量子位公众号 QbitAI 一种全新的神经网络架构 KAN&#xff0c;诞生了&#xff01; 与传统的 MLP 架构截然不同&#xff0c;且能用更少的参数在数学、物理问题上取得更高精度。 比如&#xff0c;200 个参数的 KANs&#xff0c;就能复现 DeepMind 用 30 万参数…

SpringCloud整合Gateway结合Nacos

目录 一、引入依赖 二、开启两个测试项目 2.1 order service ​编辑 2.2 user service 三、gateway项目 3.1 新建一个bootstrap.yml文件 3.2 将我们的的网关配置写道nacos里的配置里 3.3 测试&#xff1a;看能够根据网关路由到两个测试的项目 四、 优化 4.1 将项目打包…

低空经济+飞行汽车:eVTOL技术详解

低空经济是以各种有人驾驶和无人驾驶航空器的各类低空飞行活动为牵引&#xff0c;辐射带动相关领域融合发展的综合性经济形态。它广泛体现于第一、第二、第三产业之中&#xff0c;在促进经济发展、加强社会保障、服务国防事业等方面发挥着日益重要的作用。 飞行汽车&#xff0c…

## CSDN创作活动:缓解工作压力:程序员的健康之道

缓解工作压力&#xff1a;程序员的健康之道 在当今快节奏的社会中&#xff0c;程序员作为一个高度专业化和技术密集的群体&#xff0c;往往需要面对持续的工作压力和创新挑战。在如此高强度的工作环境下&#xff0c;如何有效缓解工作压力&#xff0c;保持工作效率和个人健康成…

7个AI工具助力产品管理提升

大家好&#xff0c;人工智能AI技术不断进步&#xff0c;AI在产品管理领域的应用也日益广泛。AI以辅助者的角色助力提升产品优化流程的效率&#xff0c;同时激发创新&#xff0c;是不可或缺的强大伙伴。本文将介绍七个AI工具&#xff0c;旨在自动化产品管理者的日常工作流程&…

Unity SteamVR入门

概述 VR项目现在在当前已经是非常热门的技术&#xff0c;可以给玩家身临其境的感觉&#xff0c;接下来让我们学习这部分的内容吧&#xff01; SteamVR Input SteamVR绑定流程&#xff0c;在Windows窗口的点击SteamVR-input&#xff0c;图1&#xff0c;在这里可以选择你需要绑定…

探秘Redis分布式锁:实战与注意事项

【更多精彩内容,欢迎关注小米的微信公众号“软件求生”】 大家好!我是小米,一个热爱分享技术的29岁技术达人。今天,我们来聊聊一个很有意思的主题——Redis分区容错之分布式锁。在分布式系统中,锁是一个非常重要的概念,它能确保系统中资源的并发访问不会出现问题。Redis…

如何使用Go语言进行基准测试(benchmark)?

文章目录 一、基准测试的基本概念二、编写基准测试函数三、运行基准测试四、优化代码性能五、注意事项总结 在Go语言中&#xff0c;基准测试&#xff08;benchmark&#xff09;是一种评估代码性能的有效方式。通过基准测试&#xff0c;我们可以测量代码执行的时间、内存使用情况…

【CANoe示例分析】TCP Chat(CAPL) with TLS encription

1、工程路径 C:\Users\Public\Documents\Vector\CANoe\Sample Configurations 15.3.89\Ethernet\Simulation\TLSSimChat 在CANoe软件上也可以打开此工程:File|Help|Sample Configurations|Ethernet - Simulation of Ethernet ECUs|Basic AUTOSAR Adaptive(SOA) 2、示例目…

快速掌握Element-Ul,构建高效网页应用【AI写作】

首先&#xff0c;这篇文章是基于笔尖AI写作进行文章创作的&#xff0c;喜欢的宝子&#xff0c;也可以去体验下&#xff0c;解放双手&#xff0c;上班直接摸鱼~ 按照惯例&#xff0c;先介绍下这款笔尖AI写作&#xff0c;宝子也可以直接下滑跳过看正文~ 笔尖Ai写作&#xff1a;…

并发编程之线程池的设计和原理

一、线程池 提前创建一系列的线程&#xff0c;保存在这个线程池中&#xff0c;有任务要执行的时候&#xff0c;从线程池中取出线程来执行。没有任务的时候&#xff0c;线程池放回去。 二、为什么要使用线程池 线程使用上的问题: 线程的频繁创建 和 销毁 线程的数量过多&…

注册表获取autoCAD安装位置

注意事项 注意&#xff1a;①64位操作系统注册表会重定向&#xff0c;RegOpenKeyEx第4个参数得加上KEY_WOW64_64KEY&#xff1b;②RegOpenKeyEx遍历子项时注意第2和第4参数&#xff0c;参考图&#xff1a; ③RegQueryValueEx同样得注意第6参数 完整代码 std::unordered_map…

Mybatis进阶(映射关系多对一 )

文章目录 1.需求分析2.应用实例&#xff08;xml配置&#xff09;1.数据表设计2.entity设计&#xff08;不要使用toString会栈溢出&#xff09;1.Pet.java2.User.java 3.编写Mapper1.PetMapper.java2.UserMapper.java 4.编写Mapper.xml1.UserMapper.xml2.PetMapper.xml 5.测试Us…

OPPO A72/A55/K7X/A53真我Q3S等手机ROOT刷机后广电卡没信号不读卡解决办法

目前运营商除了移动联通电信以外&#xff0c;还存在1个中国广电&#xff0c;广电属于第四大运营商&#xff0c;由于广电起步较晚&#xff0c;对于手机频段要求也自然不一样&#xff0c;导致目前市面上部分手机出厂没有信号或者不读卡等问题&#xff0c;特别在手机被用户自行刷机…

如何快速的追加文章的内容(在不知道内容的情况下)

首先&#xff0c;需要用到的这个工具&#xff1a; 度娘网盘 提取码&#xff1a;qwu2 蓝奏云 提取码&#xff1a;2r1z 1、打开工具&#xff0c;切换到文章模块下&#xff0c;快捷键&#xff1a;Ctrl1 2、新建一个文章做演示&#xff0c;001 3、添加一个内容&#xff0c;就随…

蚂蚁面试:Springcloud核心组件的底层原理,你知道多少?

尼恩说在前面 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;最近有小伙伴拿到了一线互联网企业如得物、阿里、滴滴、极兔、有赞、希音、百度、网易、美团、蚂蚁、得物的面试资格&#xff0c;遇到很多很重要的相关面试题&#xff1a; 说说&#xff1a;蚂蚁面试&#xff1…

【Java】HOT100 贪心算法

目录 理论基础 一、简单贪心 LeetCode455&#xff1a;分发饼干 二、中等贪心 2.1 序列问题 LeetCode376&#xff1a;摆动序列 2.2 贪心股票问题 LeetCode121&#xff1a;买卖股票的最佳时机 LeetCode121&#xff1a;买卖股票的最佳时机ii 2.3 两个维度权衡问题 LeetCode135&…
最新文章