基于单片机的液位水温控制(4)

2019-04-14 12:20

*****************************************************************************/ void lcd_print(uchar p,uchar *s,uint low) { }

void HC05_Init() { // }

/***************************************************************************** * 函 数 名 : distance_convert * 函数功能

: 距离装换

Tx=1;

//触发脉冲

uint num; set_lcd_pos(p);

for(num=0;num

lcd_write_data(s[num]); Delay1ms(1);

NOP();NOP();NOP();NOP(); Tx=0;

distance=0.17*t;

//距离计算 //水深

distance=L-distance;

* 输 入 : Ldat * 输 出 : 无

*****************************************************************************/ void distance_convert(long int Ldat) { }

temp_dis[9]=cache[0]+'0'; temp_dis[10]=cache[1]+'0'; temp_dis[11]=cache[2]+'0'; temp_dis[13]=cache[3]+'0'; cache[0]=Ldat/1000; cache[1]=Ldat/100; cache[2]=Ldat/10; cache[3]=Ldat;

/***************************************************************************** * 函 数 名 : Ds18b20Init * 函数功能

: 初始化DS18b20

* 输 入 : 无 * 输 出 : 无

*****************************************************************************/ uchar Ds18b20Init() { }

/***************************************************************************** * 函 数 名 : Ds18b20WriteByte * 函数功能

: 向18B20写入一个字节

uchar i; DSPORT = 0; i = 70;

//将总线拉低480us~960us

while(i--); //延时642us DSPORT = 1; i = 0;

while(DSPORT) //等待DS18B20拉低总线 { }

return 1;//初始化成功

i++;

if(i>5)//等待>5MS { }

Delay1ms(1);

return 0;//初始化失败

//然后拉高总线,如果DS18B20做出反应会将在15us~60us后总线拉低

* 输 入 : Tdat

* 输 出 : 无

//***************************************************************************/ void Ds18b20WriteByte(uchar Tdat) { }

/****************************************************************************** * 函 数 名 : Ds18b20ReadByte * 函数功能

: 读取一个字节

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

DSPORT = 0; i++;

DSPORT = Tdat & 0x01; //然后写入一个数据,从最低位开始 i=6;

while(i--); //延时68us,持续时间最少60us DSPORT = 1; Tdat >>= 1;

//然后释放总线,至少1us给总线恢复时间才能接着写入第二个数值

//每写入一位数据之前先把总线拉低1us

uint i, j;

* 输 入 : 无 * 输 出 : 无

******************************************************************************/ uchar Ds18b20ReadByte() {

uchar byte, bi; uint i, j; {

DSPORT = 0;//先将总线拉低1us i++;

DSPORT = 1;//然后释放总线 i++;

for(j=8; j>0; j--)

}

}

i++;//延时6us等待数据稳定

bi = DSPORT; //读取数据,从最低位开始读取

/*将byte左移一位,然后与上右移7位后的bi,注意移动之后移掉那位补0。*/ byte = (byte >> 1) | (bi << 7); i = 4; while(i--);

//读取完之后等待48us再接着读取下一个数

return byte;

/******************************************************************************* * 函 数 名 : Ds18b20ChangTemp * 函数功能

: 让18b20开始转换温度

* 输 入 : 无 * 输 出 : 无

******************************************************************************/

void Ds18b20ChangTemp() { }

/****************************************************************************** * 函 数 名 : Ds18b20ReadTempCom * 函数功能

: 发送读取温度命令

Ds18b20Init(); Delay1ms(1);

Ds18b20WriteByte(0xcc);

//跳过ROM操作命令

Ds18b20WriteByte(0x44); //温度转换命令

Delay1ms(100); //等待转换成功,而如果你是一直刷着的话,就不用这个延时了

* 输 入 : 无 * 输 出 : 无

*****************************************************************************/ void Ds18b20ReadTempCom() { }

/****************************************************************************** * 函 数 名 : Ds18b20ReadTemp * 函数功能

: 读取温度

Ds18b20Init(); Delay1ms(1);

Ds18b20WriteByte(0xcc); //跳过ROM操作命令 Ds18b20WriteByte(0xbe); //发送读取温度命令

* 输 入 : 无 * 输 出 : 无

******************************************************************************/ int Ds18b20ReadTemp() { }

/**************************************************************************** * 函 数 名 : Ds1820Disp

return temp;

//

temp=temp*0.625; uchar tmh, tml;

uchar datas[3] = { 0,0,0}; //定义数组 Ds18b20ChangTemp();

//先写入转换命令

Ds18b20ReadTempCom(); tml = Ds18b20ReadByte(); tmh = Ds18b20ReadByte(); temp = tmh; temp <<= 8; temp |= tml;

//然后等待转换完后发送读取温度命令

//读取温度值共16位,先读低字节 //再读高字节


基于单片机的液位水温控制(4).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:异步电动机动态数学模型仿真 - 图文

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: