- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PIC16F877万年历
/*******************************************
* 标题:DS18B20测温
* 日期:2008年1月13日
* 说明:使用DS18B20芯片测温
******************************************/
# define DQ RA3 //定义18B20数据端口
# define DQ_DIR TRISC3 //定义18B20D口方向寄存器
uchar Temp;
float f_temp;
void delay_18b20(uint i)
{
while(i--);
}
void init_DS18B20() //系统初始化函数
{
uchar x=0;
ADCON1=0X07; //设置A口为普通数字口
TRISA=0X00; //设置A口方向为输出
TRISC3=0;
DQ = 1; //DQ复位
delay_18b20(8); //稍做延时
DQ = 0; //单片机将DQ拉低
delay_18b20(80); //精确延时 大于 480us--900us
DQ = 1; //拉高总线
delay_18b20(14); //拉高36us
x=DQ; //稍做延时后 如果x=0则初始化成功 x=1则初始化失败
delay_18b20(20); //设置C口方向为输出
}
reset_DS18B20(void) //复位DS18B20函数
{
char presence=1;
while(presence)
{
DQ=0 ; //主机拉至低电平
delay(2,90); //延时503us
DQ=1; //释放总线等电阻拉高总线,并保持15~60us
delay(2,8); //延时70us
if(DQ==1) presence=1; //没有接收到应答信号,继续复位
else presence=0; //接收到应答信号
delay(2,70); //延时430us
}
}
void Wait_DS18B20() //等待程序,等待 ds18b20 应答
{
uchar i;
while(DQ);
while(!DQ);
i=6;
while(i0)i--;
}
void write_byte(uchar dat) //写18b20写字节函数
{
uchar i,j;
bit temp1;
for(j=8;j0;j--)
{
temp1=dat0x01; //最低位移出
dat=dat1 //从高拉至低电平,产生写时间隙
if(temp1)
{
DQ=0;
i++;i++;i++;i++;
DQ=1;
i=13;
while(i0) i--;
DQ=1; //如果写1,拉高电平
i++,i++,i++,i++; //延时63us
}
else
{
DQ=0;
i=13;
while(i0) i--;
DQ=1;
i++;i++;i++;i++;
}
}
}
bit read_temp_bit() //读取18b20一位数据函数
{
uchar i;
bit dat;
DQ=0;i++;
DQ=1;i++;i++;
dat=DQ;
i=8;
while(i0) i--;
return (dat);
}
uch read_temp_byte(void) //读取18b20读一字节函数
{
uchar i,j,value=0;
for(i=8;i0;i--)
{
j=read_temp_bit();
value=(j7)|(dat1);
}
return(value);
}
void temp_Convert(void) //开始转换
{
Reset_DS18B20();
Wait_DS18B20(); //等待应答脉冲
文档评论(0)