单片机温度控制c语言程序,单片机控制的温度传感器C语言程序.doc

.

.

#include

#define DO P3_7

#define SEG P0 //数码管自左至右依次为1234位

#define MS2L 0x18 //1ms的延时参数

#define MS2H 0xfc

#define uchar unsigned char

#define uint unsigned int

uchar code comm[4] = {0x01,0x02,0x04,0x08};

uchar code seg[10] = {0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};

uchar code seg_add_dicimal[10] = {0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};

uchar code seg_dicimal[2] ={0xc0, 0x92};

uchar k = 0;

uchar temp_l = 0;

uchar temp_h = 0;

uchar tempsign = 0;

uchar hundreds = 0;

uchar tens = 0;

uchar ones = 0;

uchar low_four = 0;

/*延时以ms为单位的t时间*/

void Delay(uint t)

{

uint i;

while(t--)

{

for(i=0; i<125; i++)

{ }

}

}

/*us级延时,延时时间约4+2*i*/

void Delayus(uchar i)

{

while(--i);

}

/*产生复位脉冲,等待应答信号*/

void Resetpaulse()

{

DO = 0; //拉低约600us

Delayus(150);

Delayus(150);

DO = 1;//产生上升沿,延时约15~60us

Delayus(30);

while(~DO); //等待应答信号

}

/*读取数据一位*/

bit Readbit()

{

uint i = 0;

bit b = 0;

DO = 0; //产生读时隙

i++; //维持低电平至少1us

DO = 1; //1us以上后拉高

Delayus(2); //延时8us,DO下降沿15内ds18b20输出的数据才有效

b = DO; //读取数据

Delayus(40); //每个读时隙至少持续60us

return(b);

}

/*读取一个字节*/

uchar Readbyte()

{

uchar byte_read = 0;

uchar i, j;

for(i=0; i<8; i++)

{

j = Readbit();

byte_read = (j<

}

return(byte_read);

}

/*写一个字节*/

void Writebyte(uchar byte_to_write)

{

uchar i = 0;

uchar j = 0;

bit write_bit = 0;

for(j=0; j<8; j++)

{

write_bit = (byte_to_write & 0x01);

if(write_bit == 1) //写1

{

DO = 0; //产生写时隙

Delayus(3); //延时15us

DO = 1; //写1

Delayus(40); //延时,写时隙不得低于60us

}

else

{

DO = 0; //产生写时隙

Delayus(50); //延时,保持低约60us~120us

DO = 1;

i++;

}

byte_to_write = byte_to_write >> 1;

}

}

/*配置ds18b20,9位分辨率 */

void Configurate()

{

EA = 0;

Resetpaulse(); //发出复位脉冲,每次操作都从复位开始

Delay(1);

Writebyte(0xcc); //skip room命令

Writebyte(0x4e);

Writebyte(0x7f);

Writebyte(0x80);

Writebyte(0x1f);

EA = 1;

}

/*启动温度转换*/

void StartConvert(

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#include #define uchar unsigned char #define uint unsigned int sbit led=P2^5; sbit wei=P2^7; sbit duan=P2^6; sbit DQ=P2^2; uchar mazhi_duan[]={0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71,0x00}; uchar mazhi_wei[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xff}; void delayl(uint n) { uint i,j; for(i=n;i>0;i--) for(j=114;j>0;j--); } void delays(uchar i) { while(i--); } bit init_DS18B20() //DS8B20初始化 { bit x; DQ=1; //DQ复位 delays(8); DQ=0; //单片机将DQ拉低 delays(75); DQ=1; //拉高总线 delays(15); x=DQ; //延时过后 若x=0则初始化成功 若x=1则初始化失败 delays(5); return x; } void write_data(uchar dat) { uchar i,temp; temp=dat; DQ=1; for(i=0;i>=1; } } uchar read_data() { uchar i,dat; DQ=1; for(i=0;i>=1; DQ=1;//配置为输入 if(DQ) dat|=0x80; delays(4); } return dat; } uint readtemp() { uchar temph,templ; uint temp; float wendu; init_DS18B20(); write_data(0xcc);//跳过ROM write_data(0x44);//启动温度转换 //delayl(100); init_DS18B20(); write_data(0xcc);//跳过ROM write_data(0xBE);//读温度 //以下读温度,低八位在前 //高8位在后 templ=read_data(); temph=read_data(); temp = (temph<<8)|templ; wendu = temp*0.625+0.5;//温度扩大10倍,四舍五入 temp = wendu;//10倍温度 return temp; } void STC_init() { P1=0x00;//关闭led led=0; //锁存 wei=0; duan=0; } void display(uchar weil,uchar duanl,bit dp) { wei=1; P0=mazhi_wei[weil-1]; wei=0; duan=1; if(dp==1) P0=(mazhi_duan[duanl]|0x80); else P0=mazhi_duan[duanl]; duan=0; } void main() { uchar i; uint wendu; STC_init(); wendu=readtemp(); delayl(500); wendu=readtemp(); delayl(500); while(1) { wendu=readtemp(); for(i=0;i<80;i++) { display(1,wendu/100,0); delayl(3); display(2,wendu0/10,1); delayl(3); display(3,wendu,0); delayl(3); } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值