十四届蓝桥杯单片机模拟赛第二套题 自撸程序

2023-11-13

#include <STC15F2K60S2.H>
#include <onewire.H>
#include <stdio.H>
#include <iic.H>
sbit R1=P3^0;
sbit R2=P3^1;
sbit R3=P3^2;
sbit R4=P3^3;
sbit C1=P4^4;
sbit C2=P4^2;
sbit C3=P3^5;
sbit C4=P3^4;
unsigned char F_SMG=1; //数码管标志位 1温度界面 2电压读取界面
unsigned char command; //获取下位机命令
unsigned int SMG_vlot;  //数码管电压显示参数
unsigned int SMG_T;     //数码管温度显示参数
unsigned int adc_value; //电压处理参数
unsigned char count_t;  //T0 定时50ms 中断计数
float adc_vlot;					//电压实际值
float b20_temp;					//温度实际值
unsigned char code Nodat[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
unsigned char code Isdat[10]={0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};


//=============================控制函数====================================
void SelctHC573(unsigned char n)										//P2控制位HC573
{
	switch(n)
	{
		case 0: P2=(P2 & 0x1f) |0x00; break; 
		case 4: P2=(P2 & 0x1f) |0x80; break; 
		case 5: P2=(P2 & 0x1f) |0xa0; break; 
		case 6: P2=(P2 & 0x1f) |0xc0; break; 
		case 7: P2=(P2 & 0x1f) |0xe0; break; 
	}
}
//========= P0输出控制位
void Output_P0(unsigned char pos,unsigned char value)  
{
	SelctHC573(pos);
	P0=value;				        //控制完成后,取消位选,P0赋值为0x00
	SelctHC573(0);   																
	P0=0x00;
}
//======== 数码管专用延时 1-3ms
void Delay2ms()		
{
	unsigned char i, j;
	i= 24;
	j = 85;
	do
	{
		while (--j);
	} while (--i);
}
//======== 单个数码控制
void SMGBit(unsigned char pos,unsigned char value)  
{
 
	Output_P0(6,0x01<<pos);  //位选————段选赋值————延时—————位选输出---—关闭数码管 												
	Output_P0(7,value);
	Delay2ms();
	Output_P0(6,0x01<<pos);
	Output_P0(7,0xff);
}
//======== 全部数码管控制
void SMGALL(unsigned char value)  								
{
	Output_P0(6,0xff);
	Output_P0(7,value);
}
//=============================显示函数====================================
void DisplaySMG()
{
	switch(F_SMG)
	{
	case 1 :  						//温度界面
	Output_P0(4,~0x01);   //点亮L1灯
	SMGBit(0,0xc1);				//U
	SMGBit(1,Nodat[1]);   //界面1 or 2
	SMGBit(2,0xff); 	
	SMGBit(3,0xff);  
	SMGBit(4,0xff);  
	SMGBit(5, Nodat[SMG_T/100]   );   // SMG_T=212  实际温度21.2扩大10倍 
	SMGBit(6, Isdat[(SMG_T/10)%10] ); //十位
	SMGBit(7, Nodat[SMG_T%10]   );    // 各位
	SMGALL(0xff);										  // 全部数码管静止显示
	break;
	case 2 :
	Output_P0(4,~0x02);
	
	SMGBit(0,0xc1);
	SMGBit(1,Nodat[2]); 
	SMGBit(2,0xff); 	
	SMGBit(3,0xff);  
	SMGBit(4,0xff);  
	SMGBit(5, Isdat[SMG_vlot/100]   ); // SMG_vlot=129  实际电压1.29.扩大100倍 
	SMGBit(6, Nodat[(SMG_vlot/10)%10] );
	SMGBit(7, Nodat[SMG_vlot%10]   );
	SMGALL(0xff);
		break;
}
	}
//======== 刷新数码管的延时函数  
void Delay1ms(unsigned char t)		
{
 while(t--)
 {
	DisplaySMG();											//总延时==8*数码专用延时*T ms
}
 }
//=============================初始化函数====================================
void Initsystem()
{
	Output_P0(4,0xff);              //关闭LED灯、蜂鸣器、继电器
	Output_P0(5,0x00);							//打开串行中断允许位
	ES=1;
}
//======== Uart1初始化
void IintUart()
{
	SCON = 0x50;		//8位数据,可变波特率
	AUXR &= 0xBF;		//定时器1时钟为Fosc/12,即12T
	AUXR &= 0xFE;		//串口1选择定时器1为波特率发生器
	TMOD &= 0x0F;		//设定定时器1为16位自动重装方式
	TL1 = 0xE6;		//设定定时初值
	TH1 = 0xFF;		//设定定时初值
	ET1 = 0;		//禁止定时器1中断
	TR1 = 1;		//启动定时器1
	EA = 1;         //打开总中断 ******自己添加***
}
//======== T0初始化
void Timer0Init()		//50毫秒@12.000MHz
{
	AUXR &= 0x7F;		//定时器时钟12T模式
	TMOD &= 0xF0;		//设置定时器模式
	TMOD |= 0x01;		//设置定时器模式
	TL0 = 0xB0;		//设置定时初值
	TH0 = 0x3C;		//设置定时初值
	TF0 = 0;		//清除TF0标志
	TR0 = 1;		//定时器0开始计时
	EA=1;    		//********EA   ET0 自己添加********
	ET0=1;
}
//=============================中断请求函数====================================
void ServiceTimber0() interrupt 1
{
	TL0 = 0xB0;		//设置定时初值
	TH0 = 0x3C;		//设置定时初值
	 count_t++;
	if(count_t==2)
	{
		count_t=0;							// 定时到0.1s 判断串行口是否关闭
		if(ES==0)   
		{
		Output_P0(4,~0x04);			// L3点亮
		}	}
}
//======== Uart中断
void ServiceUart()  interrupt 4
{
	if(RI==1)
	{
		command=SBUF;					//下位机命令读取
		RI=0;
	}
}

//=============================printf函数初始化====================================
//======== 发送一个字节数据
void sendByte(unsigned char dat){
   SBUF = dat;     //写入发送缓冲寄存器
   while(!TI);    //等待发送完成,TI发送溢出标志位 置1
   TI = 0;      //对溢出标志位清零	
}
//======== 输出重定向到串口
char putchar(char c)
{
	sendByte(c);
	return c;  //返回给函数的调用者printf
}

//=============================下位机命令处理====================================
void Command_mange ()
{
    if(command=='A')
	  {
			F_SMG=1; command='\0';
      }

    if(command=='B')
	  {
			F_SMG=2; command='\0';
      }
}
//=============================温度电压数据读取====================================
//======== 温度读取
unsigned int Read_temp ()
{
	unsigned int medium;
	unsigned char LSB,MSB;
	init_ds18b20();
  Write_DS18B20(0xcc);
	Write_DS18B20(0x44);

	Delay1ms(31);  //****750ms*******
	
	init_ds18b20();
  Write_DS18B20(0xcc);
	Write_DS18B20(0xbe);
	
	LSB=Read_DS18B20();
	MSB=Read_DS18B20();
	
	medium=MSB;
	medium <<=8;
	medium |= LSB;
	
   if((medium & 0xf800)==0x0000)
	{
		
		medium=medium>>4;
		medium=medium*10;
		medium=(medium+(LSB&0x0f)*0.625);
	}
	return medium;  //返回值  为实际温度的10倍
}

//======== 电压读取
unsigned char Read_AD()
{
	 unsigned char medium;
	 IIC_Start();
	 IIC_SendByte(0x90); 
	 IIC_WaitAck(); 
    
	 IIC_SendByte(0x03);	
	 IIC_WaitAck(); 
	 IIC_Stop(); 
	
	 DisplaySMG(); //****几毫秒足够*******
	
	 IIC_Start();
	 IIC_SendByte(0x91); 
	 IIC_WaitAck(); 

	 medium=IIC_RecByte(); 
	 IIC_SendAck(1);
	 IIC_Stop();
	 return medium;   //返回值  为未处理的AD值
}
//=============================温度电压数据处理====================================
	void Date_mange()
{
	 char i;
	 SMG_T=Read_temp();
	
	
	 adc_value=0;
	 for(i=0;i<3;i++)
	{
	adc_value +=Read_AD();  
	}
	 adc_value=adc_value/3;					//三次采样取平均的电压值
	 adc_vlot=adc_value*(5.0/255);  //实际电压值
	 SMG_vlot=adc_vlot*100;         //数码管电压值
	
//======== 温度电压判断	
	if(SMG_T>=240) 					
	{
		Output_P0(5,(P0&0x40)|0x10);  // 温度电压判断
		DisplaySMG();
	}
	if(adc_vlot>=3.6)
	{
		Output_P0(5,(P0&0x10)|0x40);
	}
  else{Output_P0(5,0x00);}
}
//=============================键盘扫描====================================
void Scankey()
{
	  R4 = 0;
    R2 = R3 = R1 = 1;
    C1 = C2 = C3 = C4 = 1;
    if(C1 == 0) //S4
{
		   Delay1ms(1);
		if(C1 == 0)
			 {
			 ES = 0; //关闭串行中断
		   }
		while(C1==0)
	  {
		 DisplaySMG();
		}
}

	 else if(C3 == 0) //S12
{
			Delay1ms(1);
	 if(C3 == 0)
		{
		 if(F_SMG==1)					 //判断当前界面是
		  {
		   b20_temp=SMG_T*0.1; //实际温度
			 printf("TEMP: %.1f℃ \r\n",b20_temp);
		   }
		 if(F_SMG==2)
			 {
				printf("Vlotage:%.2fV\r\n",adc_vlot);
			 }
		}
	 while(C3==0)
	{
		DisplaySMG();
	}
}
	  R3 = 0;
    R4 = R2 = R1 = 1;
    C1 = C2 = C3 = C4 = 1;
    if(C1 == 0) //S4
    {
		   Delay1ms(1);
		if(C1 == 0)
			 {
			 ES = 1;  //打开串行中断
		   }
		while(C1==0)
	  {
		 DisplaySMG();
		}
}
}
//=============================主函数====================================

void main()
{
 Initsystem();
 Timer0Init();
 IintUart();
	while(1)
	{
		 Command_mange ();
		 Scankey();
		 Date_mange();
     DisplaySMG();
	}
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

十四届蓝桥杯单片机模拟赛第二套题 自撸程序 的相关文章

随机推荐

  • std::true_type和std::false_type

    一 认识std true type和std false type std true type和std false type实际上是类型别名 源码如下 template
  • @vue/cli4.5.8搭建项目的坑

    先说下我使用脚手架4 5遇到的问题 使用GUI面板配置项目 脚手架版本4 5 8 安装好Element ui 运行结果如图所示 测试了很多次 还是有问题 最终的解决方案 卸载当前脚手架版本 npm uninstall g vue cli 安
  • 开发项目curl发起https请求,cURL error 60: SSL certificate problem: unable to get local issuer cert提示找不到本地证书错误

    个人开发的时候 在新建的环境 使用curl发起https请求 基本都是错误 需要专门配置 配置完成之后 经常会跟随一个小问题 cURL error 60 SSL certificate problem unable to get local
  • Python3----Numpy总结

    Python Numpy 1 导包 import numpy as np 2 创建一个数组Array 不同于List array1 np array 1 2 3 4 5 数组当中存储相同的数据类型 不同于一般的列表 print array1
  • 面向对象设计的重要原则:SOLID

    SOLID是面向对象设计5大重要原则的首字母缩写 1 单一职责原则 SRP 2 开放封闭原则 OCP 3 里氏替换原则 LSP 4 接口隔离原则 ISP 5 依赖倒置原则 DIP 下面具体解释一下每个原则 1 单一职责原则 SRP 表明一个
  • Python生成器详解

    生成器本质上也是迭代器 不过它比较特殊 以 list 容器为例 在使用该容器迭代一组数据时 必须事先将所有数据存储到容器中 才能开始迭代 而生成器却不同 它可以实现在迭代的同时生成元素 也就是说 对于可以用某种算法推算得到的多个数据 生成器
  • 交换机端口镜像详解

    交换机端口镜像是一种网络监控技术 它允许将一个或多个交换机端口的网络流量复制并重定向到另一个端口上 以便进行流量监测 分析和记录 通过端口镜像 管理员可以实时查看特定端口上的流量 以进行网络故障排查 安全审计和性能优化 以下是关于交换机端口
  • Mybatis设置sql超时时间

    开始搭建项目框架的时候 忽略了sql执行超时时间的问题 原本使用 net开发是 默认的超时时间是30s 这个时间一般一般sql是用不到的 但也不排除一些比较复杂或数据量较大的sql 而java中 如果不指定 默认超时时间是不做限制的 默认值
  • 安装完成centos8后,下载元数据失败解决方法:配置阿里yum源

    进入需要配置源的目录下 cd etc yum repos d ls 查看 1 编辑AppStream repo文件 一定要区分大小写 vim CentOS AppStream repo mirrorlist注释 列开头加一个 baseurl
  • latex升级包

    1 windows start menu update MikTeX 2 Selecting packages amslatex 3 在cmd 输入mpm 就会看到有amsmath amscls包 然后安装 安装完后 多编译几次就可以了 此
  • 新安装的系统的配置

    每次新安装了一个系统之后需要做一些配置 具体如下 0 Vim 主要是为了用secureCRT连接进去能够高亮显示 只需要修改即可 然后vimrc里添加 set nu CRT 注意这样配置之后 其实不生效 重新用软件连接进去就可以了 1 网络
  • 高等数学上第一章函数,极限,连续 复习

    高等数学上第一章函数 极限 连续复习 题目来源 猴博士 极限 求极限 frac infty infty 型 解题技巧 找到无穷大项 找出各无穷大项的指数 分子和分母都只保留指数最大的无穷大项 去掉其他项
  • 博弈论战略式表述和扩展式表述

    博弈论战略式表述和扩展式表述 战略式表述 包括 1 博弈的参与人的集合 2 每个参与人的战略空间 3 每个参与的支付函数 例 寡头产量博弈中 企业是参与人 产量是战略空间 利润是支付函数 图表示 扩展式表述 包括 1 参与人的集合 2 参与
  • React Native 获取屏幕的尺寸

    学习React Native的过程就是不断的研究的过程 接下来说一下两种获取屏幕的尺寸的两种方式 第一种 引入 const Dimensionsss require Dimensions const width height scale D
  • Python Numpy 一维时序数据按比例扩充、插值、压缩、重采样

    利用Numpy插值来线性缩放一维数据 如下 import numpy as np a np array 1 2 3 4 5 10 9 8 7 6 a np interp np arange 0 len a 0 5 np arange 0 l
  • Linux如何挂载创建于Windows中的共享文件夹? (**)

    Linux如何挂载创建于Windows中的共享文件夹 Linux系统挂载Windows的共享文件夹 Linux上挂载Windows下的网络共享文件夹 Linux如何挂载创建于Windows中的共享文件夹 https blog csdn ne
  • 【TVM帮助文档学习】使用张量表达式处理算子

    本文翻译自Working with Operators Using Tensor Expression tvm 0 9 dev0 documentation 在本教程中 我们将把注意力转向TVM如何使用张量表达式 TE 定义张量计算和实现循
  • sqlserver单表备份语句

    select into to FltPsgInfo 20210115 from to FltPsgInfo to FltPsgInfo 20210115 新的表名
  • 【计算机网络】【湖科大MOOC】网络层IP数据报发送和转发过程 默认网关 静态路由配置 默认路由 路由环路

    目录 网络层 4 IP数据报的发送和转发过程 4 1 直接交付 vs 间接交付 4 2 源主机如何知道目的主机是否与自己在同一个网络中 4 3 主机C如何知道路由器R的存在 4 4 路由器收到IP数据包后如何转发 5 静态路由配置 5 1
  • 十四届蓝桥杯单片机模拟赛第二套题 自撸程序

    include