想求一个基于单片机51的DS18B20温度控制在MG12864模块上显示的程序

2024-11-26 22:59:31
推荐回答(4个)
回答1:

http://58.251.57.206/down?cid=BE41265A3848AE9B0E4B4AF461BF2ED85C31FB9E&t=2&fmt=&usrinput=单片机 12864&dt=1002004&ps=0_0&rt=0kbs&plt=0

回答2:

提示:把时序和编码方式搞清楚就可以推断出算法。

回答3:

要求好多啊!
楼上的都是好人

回答4:

/*---------------------------------------------------------------------------------------------------

====================================================================================================*/

#include"reg52.h"
#define uchar unsigned char
#define uint unsigned int
const uchar table[]={0x30,0x31,0x32,0x33,
0x34,0x35,0x36,0x37,
0x38,0x39,0x41,0x42,
0x43,0x44,0x45,0x46};

sbit DQ =P2^7; //定义通信端口
sbit lcden=P3^2;
sbit lcdrs=P3^0;
sbit lcdrw=P3^1;

uchar busy,coder;
uchar *dptr;
uint wendu=0;

void delay(uint z)
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void w_com(uchar com)
{
lcdrs=0;
lcdrw=0;
P0=com;
delay(5);
lcden=1;
delay(5);
lcden=0;

}
void w_date(uchar date)
{
lcdrs=1;
lcdrw=0;
P0=date;
delay(5);
lcden=1;
delay(5);
lcden=0;

}
void init()
{
lcden=0;
w_com(0x38);
w_com(0x0c);
w_com(0x06);
w_com(0x01);
w_com(0x80);

}

//延时函数

void de0(unsigned int i)
{
while(i--);
}

//初始化函数
Init_DS18B20(void)
{
unsigned char x=0;
DQ = 1; //DQ复位
de0(8); //稍做延时
DQ = 0; //单片机将DQ拉低
de0(80); //精确延时 大于 480us
DQ = 1; //拉高总线
de0(14);
x=DQ; //稍做延时后 如果x=0则初始化成功 x=1则初始化失败
de0(20);
}

//读一个字节
ReadOneChar(void)
{
unsigned char i=0;
unsigned char dat = 0;
for (i=8;i>0;i--)
{
DQ = 0; // 给脉冲信号
dat>>=1;
DQ = 1; // 给脉冲信号
if(DQ)
dat|=0x80;
de0(4);
}
return(dat);
}

//写一个字节
WriteOneChar(unsigned char dat)
{
unsigned char i=0;
for (i=8; i>0; i--)
{
DQ = 0;
DQ = dat&0x01;
de0(5);
DQ = 1;
dat>>=1;
}
delay(4);
}

//读取温度
t_em(void)
{
unsigned char a=0;
unsigned char b=0;
unsigned int t=0;
float tt=0;
Init_DS18B20();
WriteOneChar(0xCC); // 跳过读序号列号的操作
WriteOneChar(0x44); // 启动温度转换
Init_DS18B20();
WriteOneChar(0xCC); //跳过读序号列号的操作
WriteOneChar(0xBE); //读取温度寄存器等(共可读9个寄存器) 前两个就是温度
a=ReadOneChar();
b=ReadOneChar();
t=b;
t<<=8;
t=t|a;
tt=t*0.0625;
t= tt*100+0.05; //放大10倍输出并四舍五入---此行没用
return(t);
}

main()
{
init();
while(1)
{

w_com(0xC0);
wendu=t_em();//读温度
w_com(0x80);
w_date('T');
w_date(':');
w_date(' ' );
w_date(table[wendu/1000]);
w_date(table[wendu%1000/100]);
w_date('.');
w_date(table[wendu%100/10]);
w_date(table[wendu%10]);
w_date(0xdf);
w_com(0x02);
delay(500);
DQ = 0;
}
}