• TI——BI
    了解作者
  • C51
    开发工具
  • 31KB
    文件大小
  • zip
    文件格式
  • 0
    收藏次数
  • 1 积分
    下载积分
  • 0
    下载次数
  • 2018-07-20 07:55
    上传日期
这个程序是基于DS18B20温度传感器的,它可以根据温度变化,可以给出不同的温度值。
温度测试.zip
  • 温度测试
  • obj
  • DS18B20
    11.1KB
  • Main.obj
    10.8KB
  • DS18B20.lnp
    78B
  • DS18B20.hex
    4.5KB
  • src
  • Main.c
    3.2KB
  • Main.lst
    7.7KB
  • DS18B20_uvopt.bak
    53.2KB
  • DS18B20.uvopt
    53.6KB
  • DS18B20.M51
    12KB
  • DS18B20.plg
    367B
  • DS18B20.uvproj
    13KB
  • DS18B20_uvproj.bak
    12.9KB
内容介绍
#include <STC15F2K60S2.H> #include "stdio.h" #include "intrins.h" #define uchar unsigned char sbit DQ=P3^6; //数据传输线接单片机的相应的引脚 unsigned char tempL=0; //设全局变量 unsigned char tempH=0; unsigned int sdata; //测量到的温度的整数部分 unsigned char xiaoshu1; //小数第一位 unsigned char xiaoshu2; //小数第二位 unsigned char xiaoshu; //两位小数 bit fg=1; void UartInit(void); //温度正负标志 void delay(unsigned char n) // 延时10微秒 { unsigned char i; while(n--){ i = 65; while (--i); } } void Init_DS18B20(void) { unsigned char x=0; DQ=1; //DQ先置高 delay(8); //稍延时 DQ=0; //发送复位脉冲 delay(80); //延时(>480us) DQ=1; //拉高数据线 delay(5); //等待(15~60us) x=DQ; //用X的值来判断初始化有没有成功,18B20存在的话X=0,否则X=1 delay(20); } //读一个字节 ReadOneChar(void) //主机数据线先从高拉至低电平1us以上,再使数据线升为高电平,从而产生读信号 { unsigned char i=0; //每个读周期最短的持续时间为60us,各个读周期之间必须有1us以上的高电平恢复期 unsigned char dat=0; for (i=8;i>0;i--) //一个字节有8位 { DQ=1; delay(1); DQ=0; dat>>=1; DQ=1; if(DQ) dat|=0x80; delay(4); } return(dat); } //写一个字节 void WriteOneChar(unsigned char dat) { unsigned char i=0; //数据线从高电平拉至低电平,产生写起始信号。15us之内将所需写的位送到数据线上, for(i=8;i>0;i--) //在15~60us之间对数据线进行采样,如果是高电平就写1,低写0发生。 { DQ=0; //在开始另一个写周期前必须有1us以上的高电平恢复期。 DQ=dat&0x01; delay(5); DQ=1; dat>>=1; } delay(4); } //读温度值(低位放tempL;高位放tempH;) void ReadTemperature(void) { Init_DS18B20(); //初始化 WriteOneChar(0xcc); //跳过读序列号的操作 WriteOneChar(0x44); //启动温度转换 delay(125); //转换需要一点时间,延时 Init_DS18B20(); //初始化 WriteOneChar(0xcc); //跳过读序列号的操作 WriteOneChar(0xbe); //读温度寄存器(头两个值分别为温度的低位和高位) tempL=ReadOneChar(); //读出温度的低位LSB tempH=ReadOneChar(); //读出温度的高位MSB if(tempH>0x7f) //最高位为1时温度是负 { tempL=~tempL; //补码转换,取反加一 tempH=~tempH+1; fg=0; //读取温度为负时fg=0 } sdata = tempL/16+tempH*16; //整数部分 xiaoshu1 = (tempL&0x0f)*10/16; //小数第一位 xiaoshu2 = (tempL&0x0f)*100/16%10; //小数第二位 xiaoshu=xiaoshu1*10+xiaoshu2; //小数两位 printf("temp: "); if(fg == 1) { printf("%d",sdata); printf("."); printf("%d\r\n",xiaoshu); } if(fg == 0) { printf("-"); printf("%d",sdata); printf("."); printf("%d\r\n",xiaoshu); } } main() { UartInit(); while(1) { ReadTemperature(); } } char putchar (char ch) { while(TI == 0); TI = 0; SBUF = ch; return ch; } void UartInit(void) //9600bps@27.000MHz { SCON = 0x50; //8位数据,可变波特率 AUXR &= 0xBF; //定时器1时钟为Fosc/12,即12T AUXR &= 0xFE; //串口1选择定时器1为波特率发生器 TMOD &= 0x0F; //设定定时器1为16位自动重装方式 TL1 = 0xC5; //设定定时初值 TH1 = 0xFF; //设定定时初值 ET1 = 0; //禁止定时器1中断 TR1 = 1; //启动定时器1 TI = 1; }
评论
    相关推荐