单片机课设-基于DA18B20的数字温度计

在这里插入图片描述main.c

/**************************************************************************************
*		              DS18B20温度传感器实验												  *
实现现象:下载程序后,在温度传感器接口处,按照丝印方向插好温度传感器,数码管就会显示
			检测的温度值,
注意事项:																				  
***************************************************************************************/
#include "reg51.h"			 //此文件中定义了单片机的一些特殊功能寄存器
#include"temp.h"	

typedef unsigned int u16;	  //对数据类型进行声明定义
typedef unsigned char u8;
#define jzkey P1	 	//矩阵按键的连接端口	
#define light P0
/*独立按键4作为阈值设定还是阈值显示*/
sbit dlkey4=P3^3;//模式
/*独立按键1作为模式(测温还是设置阈值)切换开关*/
sbit dlkey1=P3^1;
/*独立按键4作为阈值设定的确认按键,将矩阵按键的数字存在everybit中*/
sbit dlkey3=P3^2;//确认按键

/*检测是设置阈值状态还是显示阈值状态*/
sbit led1=P2^7;
/*矩阵按键输入的数字*/
uchar KeyValue = 0;
/*阈值的每一位*/
uchar everybit[8]={
   0x40,0x00,0x00,0x00,
					0x00,0x00,0x00,0x00};//每一位的值
uchar max_temp;
uchar min_temp ;

/*数码管*/
sbit LSA=P2^2;
sbit LSB=P2^3;
sbit LSC=P2^4;
sbit beep=P1^5;	 
bit k1_demo;
bit k4_demo;
uchar code smgduan[]={
   0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};

//char num=0;
u8 DisplayData[8];

/*******************************************************************************
* 函 数 名         : delay
* 函数功能		   : 延时函数,i=1时,大约延时10us
*******************************************************************************/
void delay(u16 i)
{
   
	while(i--);	
}


//温度读取处理转换函数
void datapros(int temp) 	 
{
   
   	float tp;  
	if(temp< 0)				//当温度值为负数
  	{
   
		DisplayData[0] = 0x40; 	  //   -
		//因为读取的温度是实际温度的补码,所以减1,再取反求出原码
		temp=temp-1;
		temp=~temp;
		tp=temp;
		temp=tp*0.0625*1000+0.5;	
		//留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
		//后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
		//算加上0.5,还是在小数点后面。
 
  	}
 	else
  	{
   			
		DisplayData[0] = 0x00;
		tp=temp;//因为数据处理有小数点所以将温度赋给一个浮点型变量
		//如果温度是正的那么,那么正数的原码就是补码它本身
		temp=tp*0.0625*1000+0.5;	
		//留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
		//后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
		//算加上0.5,还是在小数点后面。
	}
	DisplayData[1] = smgduan[temp / 100000];
	DisplayData[2] = smgduan[temp % 100000 / 10000];
	DisplayData[3] = smgduan[temp % 10000 / 1000] | 0x80;
	DisplayData[4] = smgduan[temp % 1000 / 100
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值