- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
超声波测距离ds18b201602显示6wrlztt6
#includereg52.h
#include intrins.h
#define D 2
#define T 30
typedef unsigned char uchar;
typedef unsigned int uint;
sbit rs=P3^5;
sbit rw=P3^6;
sbit lcden=P3^7;
sbit led = P1^3;
sbit beep = P1^5;
sbit Trig=P1^0; //超声波测速模块
sbit Echo=P3^2;
sbit DQ = P1^1;//DS18B20管脚
uchar *ch = Hello world!;
uchar *message = Welcom!!!;
uchar *tishi = Distance: m;
uchar *tishi1 = Temperture:;
uchar *num = 0123456789.;
uchar succeed_flag,timeL,timeH,distance;
uchar A1,A2,A3,A4,c;
uint time;
uchar a,b;//用于装载DS18b20数值
void LedInit(void);
void write_com(uchar com);
void write_date(uchar date);
void Disp1Char(uchar x,uchar y,uchar ch);
void DispNChar(uchar x,uchar y,uchar n,uchar *p);
void LocateXY(uchar x,uchar y);
void num_display(uint temp);
void distance_display();
void temp_display();
void delay(uint num);
void delay1(uint z);
void delay_20us();
void Init();
void write(uchar com);
uchar read();
void read_tu();
void main()
{
LedInit();
Init();
// led = 0;
Trig=0;//首先拉低脉冲输入引脚
EA=1;//打开总中断0??
TMOD=0x10;//定时器1,16位工作方式
DispNChar(1,1,9,tishi);
DispNChar(0,2,11,tishi1);
// DispNChar(3,2,12,ch);
while(1)
{
temp_display();
distance_display();
}
}
void LedInit(void)
{
lcden=0;
rw = 0;
write_com(0x38);
write_com(0x0c);
write_com(0x06);
write_com(0x01);
write_com(0x80);
}
void write_com(uchar com)
{
rs=0;
lcden=0;
P0=com;
delay1(5);
lcden=1;
delay1(5);
lcden=0;
}
void write_date(uchar date)
{
rs=1;
lcden=0;
P0=date;
delay1(5);
lcden=1;
delay1(5);
lcden=0;
}
void LocateXY(uchar x,uchar y)
{
uchar temp;
temp = x 0x0f;
if(y == 2)
temp |= 0x40;
temp |= 0x80;
write_com(temp);
}
void Disp1Char(uchar x,uchar y,uchar ch)
{
LocateXY(x,y);
write_date(ch);
}
void DispNChar(uchar x,uchar y,uchar n,uchar *p)
{
uchar i;
for(i=0;in;i++)
{
Disp1Char(x++,y,p[i]);
if(x == 0x0f)
{
x = 0;
y += 1;
}
}
}
void num_display(uint temp)
{
uchar a,b,c;
a = temp
文档评论(0)