温度传感器-51单片机

原创
2019/11/27 17:27
阅读数 43

C语言

#include <reg51.h>
#define uchar unsigned char
sbit DQ =P3^7; //18B20 数据线引脚
//数码管显示的段码表
uchar code table[] = {0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};
// 0 1 2 3 4 5 6 7 8 9
uchar code table_d[]= {0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};
// 0 1 2 3 4 5 6 7 8 9
uchar dispbuf[4]; //显示缓冲区
uchar temper[2];//存放温度的数组
void seg_scan();
/*****************************延时函数**************************/
void delay (unsigned int us)
{
    while(us--);
}
void reset(void) //复位
{
    uchar x=0;
    DQ = 1;
    delay(8); //稍做延时
    DQ = 0;
    delay(80); //精确延时 大于 480us
    DQ = 1; //拉高总线
    delay(14);
    x=DQ;
    delay(20);
}
/**********************从 DS18B20 读一字节***************/
uchar readbyte(void) //读 1 字节
{
    uchar i=0;
    uchar dat=0;
    for (i=8; i>0; i--)
    {
        DQ = 0;
        dat>>=1;
        DQ = 1;
        if(DQ)
            dat|=0x80;
        delay(4);
    }
    return(dat);
}
/***********************向 DS18B20 写一字节***********************/
void writebyte(unsigned char dat) //写 1 字节
{
    uchar i=0;
    for (i=8; i>0; i--)
    {
        DQ = 0;
        DQ = dat&0x01;
        delay(5);
        DQ = 1;
        dat>>=1;
    }
    delay(4);
}
/***********************CPU 读取温度值***************************/
void readtemp(void) //读取温度
{
    uchar a=0,b=0;
    reset();
    seg_scan();
    writebyte(0xCC); // 跳过序列号
    writebyte(0x44); // 启动温度转换
    reset();
    seg_scan();
    writebyte(0xCC);
    writebyte(0xBE); //读 9 个寄存器,前两个为温度
    seg_scan();
    a=readbyte(); //低位
    b=readbyte(); //高位
    seg_scan();
    temper[0]=a&0x0f;
    a=a>>4; //低位右移 4 位,舍弃小数部分
    temper[1]=b<<4; //高位左移 4 位,舍弃符号位
    temper[1]=temper[1]|a;
}
/******************************显示*************************/
void seg_scan()
{
    int i,j=0xFE;
    int dispdata;
    for(i=0; i<4; i++)
    {
        P2=j;
        dispdata=dispbuf[i];
        if(i==1)
            P0=table_d[dispdata];
        else
            P0=table[dispdata];
        delay(500);
        j=(j<<1)|0x01;
        if(j==0xEF)
            j=0xFE;
    }
}
/*******************************主函数***********************/
void main()
{
    uchar i;
    uchar temp;
    float backbit;
    for(i=0; i<4; i++)
        dispbuf[i] = 0;
    while(1)
    {
        readtemp();//读 18B20
        backbit = temper[0];//换成浮点数
        backbit = backbit * 6.25;//乘以 0.0625*100
        temp = backbit;//取低 2 位整数部分
        dispbuf[3] = temp%10 ;
        temp = temp/10;
        dispbuf[2] = temp%10 ;
        temp = temper[1];//取整数部分
        dispbuf[1] = temp%10;
        temp = temp/10;
        dispbuf[0]= temp%10;
        seg_scan(); //显示扫描
    }
}
/********************************结束************************/
展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部