admin 发表于 2020-8-20 10:41:00

DS18B20处理

<p>很多工厂采购朋友在工作的时候会遇到一些问题,其中就包括DS18B20处理的问题,那么搜索网络小编来给您来解答一下您现在困惑的问题吧。</p><p>DS18B20处理</p><center><img alt="DS18B20处理:DS18B20温度数据处理函数" style="max-width: 100%;" src="data/attachment/forum/20200820/1597891260-file0001.png" /></center><h2>DS18B20处理:DS18B20温度数据处理函数</h2><#include <reg52.h><br>#include <intrins.h><br>#define uchar unsigned char<br>#define uint unsigned int<br>sbit DQ = P2^2; //数据口define interface<br>sbitla = P2^6; //数 码管段 选<br>sbit wela = P2^7; //数码管位选<br>uint temp; //温度值 variable of temperature<br>//不带小数点<br>unsigned char code table[] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,<br>0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};<br>//带小数点<br>unsigned char code table1[] = {0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef};<br>/**精确延时函数**/<br>void delay(unsigned char i)while(--i);/**<br>此延时函数针对的是12Mhz的晶振<br>delay(0):延时518us 误差:518-2*256=6<br>delay(1):延时7us (原帖写"5us"是错的)<br>delay(10):延时25us 误差:25-20=5<br>delay(20):延时45us 误差:45-40=5<br>delay(100):延时205us 误差:205-200=5<br>delay(200):延时405us 误差:405-400=5<br>**/<br>/**DS18B20**/<br>void Init_Ds18b20(void) //DS18B20初始化send reset and commandDQ = 1; //DQ复位,不要也可行。<br>delay(1); //稍做延时<br>DQ = 0; //单片机拉低总线<br>delay(250); //精确延时,维持至少480us<br>DQ = 1; //释放总线,即拉高了总线<br>delay(100); //此处延时有足够,确保能让DS18B20发出存在脉冲。uchar Read_One_Byte() //读取一个字节的数据read a byte date<br>//读数据时,数据以字节的最低有效位先从总线移出uchar i = 0;<br>uchar dat = 0;<br>for(i=8;i>0;i--)DQ = 0; //将总线拉低,要在1us之后释放总线<br>//单片机要在此下降沿后的15us内读数据才会有效。<br>_nop_(); //至少维持了1us,表示读时序开始<br>dat >= 1; //让从总线上读到的位数据,依次从高位移动到低位。<br>DQ = 1; //释放总线,此后DS18B20会控制总线,把数据传输到总线上<br>delay(1); //延时7us,此处参照推荐的读时序图,尽量把控制器采样时间放到读时序后的15us内的最后部分<br>if(DQ) //控制器进行采样dat |= 0x80; //若总线为1,即DQ为1,那就把dat的最高位置1;若为0,则不进行处理,保持为0delay(10); //此延时不能少,确保读时序的长度60us。return (dat);void Write_One_Byte(uchar dat)uchar i = 0;<br>for(i=8;i>0;i--)DQ = 0; //拉低总线<br>_nop_(); //至少维持了1us,表示写时序(包括写0时序或写1时序)开始<br>DQ = dat&0x01; //从字节的最低位开始传输<br>//指令dat的最低位赋予给总线,必须在拉低总线后的15us内,<br>//因为15us后DS18B20会对总线采样。<br>delay(10); //必须让写时序持续至少60us<br>DQ = 1; //写完后,必须释放总线,<br>dat >= 1;<br>delay(1);uint Get_Tmp() //获取温度get the tt;<br>uchar a,b;<br>Init_Ds18b20(); //初始化<br>Write_One_Byte(0xcc); //忽略ROM指令<br>Write_One_Byte(0x44); //温度转换指令<br>Init_Ds18b20(); //初始化<br>Write_One_Byte(0xcc); //忽略ROM指令<br>Write_One_Byte(0xbe); //读暂存器指令<br>a = Read_One_Byte(); //读取到的第一个字节为温度LSB<br>b = Read_One_Byte(); //读取到的第一个字节为温度MSB<br>temp = b; //先把高八位有效数据赋于temp<br>temp <= 8; //把以上8位数据从temp低八位移到高八位<br>temp = temp|a; //两字节合成一个整型变量<br>tt = temp*0.0625; //得到真实十进制温度值<br>//因为DS18B20可以精确到0.0625度<br>//所以读回数据的最低位代表的是0.0625度<br>temp = tt*10+0.5; //放大十倍<br>//这样做的目的将小数点后第一位也转换为可显示数字<br>//同时进行一个四舍五入操作。<br>return temp;/**数码码动态显示函数**/<br>void Display(uint temp) //显示程序uchar A1,A2,A3;<br>A1 = temp/100; //百位<br>A2 = temp%100/10; //十位<br>A3 = temp%10; //个位<br>la = 0;<br>P0 = table; //显示百位<br>la = 1; //打开段选,对应74573的锁存位,高电平不锁存<br>la = 0;<br>wela = 0;<br>P0 = 0x7e;<br>wela = 1; //打开位选<br>wela = 0;<br>delay(0);<br>la = 0;<br>P0 = table1; //显示十位,使用的是有小数点的数组(因为temp值扩大了10倍,虽然是十位,实际为个位)<br>la = 1;<br>la = 0;<br>wela = 0;<br>P0 = 0x7d;<br>wela = 1;<br>wela = 0;<br>delay(0);<br>P0 = table; //显示个位<br>la = 1;<br>la = 0;<br>P0 = 0x7b;<br>wela = 1;<br>wela = 0;<br>delay(0);void main()while(1)Display(Get_Tmp());<br> <p>以上就是关于DS18B20处理的文章内容,如果您有DS18B20处理的意向,就请联系我们,很高兴为您服务!</p>
页: [1]
查看完整版本: DS18B20处理