2021-10-12 51蛋骗鸡数码管前7位显示1-7第8位显示0-9

缘由 51单片机数码管问题-编程语言-CSDN问答

#include "REG52.h"
sbit K1 = P3^0;
sbit K2 = P3^1;
sbit K3 = P3^2;
sbit K4 = P3^3;
bit k=1,wk=0;
unsigned char code SmZiFu[]={63,6,91,79,102,109,125,7,127,111,128,255,64};//0-9.消隐-
unsigned char Js=0,miao=0,fen=0,shi=0,y=6,t=23,ls=0;//中断计时
unsigned int n=2021;
void smxs(unsigned char mz,unsigned char w,unsigned char d)
{unsigned char Xd=0;P1=~255;P1=~(255-(d==1?SmZiFu[mz]:(SmZiFu[mz]|0x80)));//小数点闪烁P2=~w;while(++Xd);
}
void sm(unsigned int n, unsigned char y, unsigned char t, unsigned char shi, unsigned char fen, unsigned char miao)
{smxs(k?miao%10:t%10,8,1);smxs(k?miao/10%10:t/10%10,4,1);smxs(k?255:y%10,2,0);smxs(k?fen%10:y/10%10,1,1);smxs(k?fen/10%10:n%10,128,k?1:0);smxs(k?255:n/10%10,64,k?0:1);smxs(k?shi%10:n/100%10,32,1);smxs(k?shi/10%10:n/1000,16,1);
}
unsigned char nyt(unsigned int n, unsigned char y)
{return (y == 2 ? (((!(n % 4) && n % 100) || !(n % 400)) ? 29 : 28) :(((y <= 7 && y % 2) || (y > 7 && !(y % 2))) ? 31 : 30));
}
void jw(unsigned int *n, unsigned char *y, unsigned char *t, unsigned char *shi, unsigned char *fen, unsigned char *miao)
{/*时间日期进位*/if(*miao>=60){*miao=0;++*fen;}if(*fen>=60){*fen=0;++*shi;}if(*shi>=24){*shi=0;++*t;}if(*t>nyt(*n,*y)){++*y;*t=1;}if(*y>12){++*n;*y=1;}
}
void JiShi(/*时间计算*/)
{if(Js>=20){Js=0;++miao;jw(&n, &y, &t, &shi, &fen, &miao);if(miao%5==0)k=~k;ls/=2;}
}
void wbzd(/*外部中断调用函数*/)
{unsigned char cs=10;unsigned int ys=0;wk=0;while(cs){if(++ys==0)--cs;if(cs%2==0)P1=1;else P1=128;}
}
void ZhongDuanSheZhi()
{TH0+=0X4c;/*定时器赋初值,定时50ms触发中断,自动补偿方式*/TL0+=0X00; TMOD=0X01;TR0=1;ET0=1; //开启定时器EA=1; //全局中断开关IT0 = 1;//下降沿触发EX0 = 1;//开外部中断
}
void main()
{unsigned char Xd=0,xz=0,cs=1,ss=0;unsigned int wei=0;P1=255;ZhongDuanSheZhi();while(1){if(++xz<8){smxs(xz,cs,1);//段数据,位数据,小数点选择cs*=2;//数码管位}else{smxs(ss,cs,1);xz=0;cs=1;if(++Xd==0&&++ss>9)ss=0;//第8位变动延时8*255*255}
//		if(++cs>9)cs=0;else;
//		if(K1==0&&++Xd==0){P1=0;while(K1==0);}
//		if(K2==0&&++Xd==0){P1=85;while(K2==0);}
//		if(K3==0&&++Xd==0){P1=15;while(K3==0);}
//		if(K4==0&&++Xd==0){P1=240;while(K4==0);}
//		if(K1==0&&++Xd==0)
//		{
//			k=~k;
//			if(xz>0)
//			{
//				TR0=1;
//				xz=0;
//			}
//			while(K1==0)smxs(xz,1,1);
//			Xd=240;
//		}//切换与确定
//		if(K2==0&&++Xd==0)
//		{
//			++xz;
//			while(K2==0)smxs(xz,1,1);
//			Xd=240;
//		}//xz值功能选择1年2月3天4时5分6秒7归零调节
//		if(xz)
//		{
//			TR0=0;
//			if(xz<4)
//				k=0;
//			else
//				k=1;
//			if(K3==0&&++Xd==0)
//			{
//				xz==1?++n:xz==2?++y:xz==3?++t:xz==4?++shi:xz==5?++fen:xz==6?++miao:0;
//				jw(&n, &y, &t, &shi, &fen, &miao);
//				while(K3==0);
//				Xd=240;
//			}
//			if(K4==0&&++Xd==0)
//			{
//				xz==1?--n:xz==2?--y:xz==3?--t:xz==4?--shi:xz==5?--fen:xz==6?--miao:0;
//				jw(&n, &y, &t, &shi, &fen, &miao);
//				while(K4==0);
//				Xd=240;
//			}
//			if(xz==1)
//				sm(n, 0, 0, 0, 0, 0);
//			else if(xz==2)
//				sm(0, y, 0, 0, 0, 0);
//			else if(xz==3)
//				sm(0, 0, t, 0, 0, 0);
//			else if(xz==4)
//				sm(0, 0, 0, shi, 0, 0);
//			else if(xz==5)
//				sm(0, 0, 0, 0, fen, 0);
//			else if(xz==6)
//				sm(0, 0, 0, 0, 0, miao);
//			if(xz==7)n=y=t=shi=fen=miao=0;
//			if(xz>7){xz=0;TR0=1;}
//		}
//		else
//			sm(n, y, t, shi, fen, miao);
//		P1=~ls;
//		if(ls==0){if(++cs<=5)ls=128;else {ls=0;cs=7;}}
//		if(wk)wbzd();
//		JiShi();}
}
void ZhongDuan() interrupt 1
{++Js;TH0+=0X4c;TL0+=0X00;        
}
void WaiBuZhongDuan0() interrupt 0//外部中断0=0,1=2,引脚P3.2,INT0
{wk=1; 
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构—基础知识:哈夫曼树

文章目录 数据结构—基础知识&#xff1a;哈夫曼树哈夫曼树的基本概念哈夫曼树的构造算法哈夫曼树的构造过程哈夫曼算法的实现算法&#xff1a;构造哈夫曼树 数据结构—基础知识&#xff1a;哈夫曼树 哈夫曼树的基本概念 哈夫曼&#xff08;Huffman&#xff09;树又称最优树&…

T06垃圾收集器G1ZGC

垃圾收集器G1&ZGC CMS用的增量更新&#xff0c;G1用的原始快照 G1收集器&#xff08;-XX:UseG1GC&#xff09; G1(Garbage-First)是一款面向服务器的垃圾收集器&#xff0c;主要针对配置多颗处理器及大容量内存的机器&#xff0c;以极高概率满足停顿时间的要求&#xff…

Springboot集成Javamelody

JavaMelody的目标是监视QA和生产环境中的Java或Java EE应用服务器。它不是模拟用户请求的工具&#xff0c;而是根据用户对应用程序的使用情况来衡量和计算应用程序实际操作的统计信息的工具。JavaMelody主要基于请求统计和演化图。 它允许改进QA和生产中的应用程序&#xff0c…

谷歌seo搜索引擎优化需要做什么?

当你要做谷歌seo&#xff0c;经手一个你之前没有接触过的网站&#xff0c;你首先要做的就是分析网站当前的流量数据&#xff0c;如果是新站自然不需要这一步&#xff0c;不过数据分析依旧是件很重要的事情&#xff0c;做seo不懂得分析数据相当于白做 再来就是你要了解网站所在的…

【机器学习300问】21、什么是激活函数?常见激活函数都有哪些?

在我写的上一篇文章中介绍了感知机&#xff08;单个神经元&#xff09;的构成&#xff0c;其中就谈到了神经元会计算传送过来的信号的总和&#xff0c;只有当这个总和超过了某个界限值时&#xff0c;才会输出值。这也称为“神经元被激活”。如果想对神经网络是什么有更多了解的…

使用css绘制小三角形

要使用CSS绘制小三角形&#xff0c;您可以使用border属性来设置边框样式。下面是一种常见的绘制小三角形的方法&#xff1a; <style>.box {width: 0;height: 0;/* border-top: 10px solid red; */border-bottom: 10px solid blue;border-left: 10px solid transparent;b…

CodeEase插件市场上线了

目录 怎么进入插件市场&#xff1f;插件市场有哪些功能&#xff1f;怎么上传自己的插件&#xff1f;怎么进入后台&#xff1f;结语 CodeEase生态的插件市场正式上线了&#xff01; 我们非常激动地宣布&#xff0c;CodeEase生态的插件市场已经正式上线&#xff01;这是一个为广…

Java开发工具 IntelliJ IDEA 2023中文

IntelliJ IDEA 2023是一款强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;适用于多种编程语言&#xff0c;包括Java、Python、Kotlin等。它提供了许多特色功能&#xff0c;以提高开发效率和代码质量。 Java开发工具 IntelliJ IDEA 2023中文 以下是一些IntelliJ ID…

MySQL数据库入门

MySQL数据库概述 1&#xff0c;为什么要使用数据库2&#xff0c;数据库的相关概念3&#xff0c;常见的数据库管理系统4&#xff0c;MySQL介绍5&#xff0c;关系型数据库和非关系型数据库6&#xff0c;关系型数据库的设计规则7&#xff0c;表的关联关系7.1&#xff0c;一对一7.2…

【c/python】GtkBox

一、GtkBox及C语言示例 GtkBox是一个容器部件&#xff0c;用于在GTK&#xff08;GIMP Toolkit&#xff09;应用程序中水平或垂直地排列多个子部件。以下是一个简单的例子&#xff0c;展示了如何在一个基本的GTK应用程序中使用GtkBox来垂直排列两个按钮&#xff1a; 首先&#…

网络安全全栈培训笔记(60-服务攻防-中间件安全CVE复现WeblogicJenkinsGlassFish)

第60天 服务攻防-中间件安全&CVE复现&Weblogic&Jenkins&GlassFish 知识点: 中间件及框架列表: lIS,Apache,Nginx,Tomcat,Docker,Weblogic,JBoos,WebSphere,Jenkins, GlassFish,Jira,Struts2,Laravel,Solr,Shiro,Thinkphp,Sprng,Flask,jQuery 1、中间件-Web…

Python 数据分析(PYDA)第三版(二)

原文&#xff1a;wesmckinney.com/book/ 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 四、NumPy 基础知识&#xff1a;数组和向量化计算 原文&#xff1a;wesmckinney.com/book/numpy-basics 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 此开放访问网络版…