专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
51单片机
求一个STC12C5A60S2超声波HC-SR04测距模块的程序!非常感谢,我试过网上下载的一些程序LCD没显示!谢谢了
2019-07-15 16:24
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
973
3
1789
求一个STC12C5A60S2超声波HC-SR04测距模块的程序!非常感谢,我试过网上下载的一些程序LCD没显示!谢谢了
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
3条回答
wenjie5450
2019-07-15 16:31
#include <reg52.h>
#define uchar unsigned char
#define uint unsigned int
uchar code table1[]="The distance is :";
uchar code table2[]="0123456789 ";
uchar code table3[]=" CM";
double distance;
sbit lcden=P2^6;
sbit lcdrs=P2^4;
sbit rw= P2^5;
sbit Trig=P2^0;
sbit Echo=P3^3;
bit succeed_flag=0;
void delay(uint z)
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void delay_20us()
{
uchar a ;
for(a=0;a<20;a++);
}
//***************************************************************
//显示数据转换程序
void write_com(uchar com)
{
lcdrs=0;
P0=com;
delay(5);
lcden=1;
delay(5);
lcden=0;
}
void write_date(uchar date)
{
lcdrs=1;
P0=date;
delay(5);
lcden=1;
delay(5);
lcden=0;
}
void LCD_init()
{
uchar num;
lcden=0;rw=0;
write_com(0x38);
write_com(0x0c);
write_com(0x06);
write_com(0x01);
write_com(0x80);
for(num=0;num<17;num++){
write_date(table1[num]);
delay(2);
}
write_com(0x80+0x43);
for(num=0;num<3;num++)
{
write_date(table3[num]);
delay(2);
}
}
void LCD_show( int m)
{
write_com(0x80+0x40);
{
uchar num2;
num2=m/100%10;
write_date(table2[num2]);
delay(2);
num2=m/10%10;
write_date(table2[num2]);
delay(2);
num2=m%10;
write_date(table2[num2]);
delay(2);
}
}
//***************************************************************
//主程序
void main()
{
LCD_init();
Trig=0; //首先拉低脉冲输入引脚
TMOD=0x10; //定时器1,16位工作方式
while(1)
{
EA=0; //关总中断
IT1=1;
Trig=1;//超声波输入端
delay_20us(); //延时20us
Trig=0; //产生一个20us的脉冲
while(Echo==0); //等待Echo回波引脚变高电平
succeed_flag=0; //清测量成功标志
EA=1;
EX1=1;
TR1=1; //启动定时器1
delay(20); //等待测量的结果
if(succeed_flag==1)
LCD_show(distance);
if(succeed_flag==0)
{ distance=0; //没有回波则清零
LCD_show(distance);
}
}
}
//***************************************************************
//外部中断0,用做判断回波电平
void exter() interrupt 2 // 外部中断1是2号
{
TR1=0;
EX1=0;
distance=(TH1*256+TL1+59)*0.0172; //厘米
succeed_flag=1;//至成功测量的标志
TH1=0; //定时器1清零
TL1=0; //关闭外部中断1
}
加载中...
查看其它3个回答
一周热门
更多
>
相关问题
【东软载波ESF0654 PDS开发板活动】开箱
1 个回答
东软载波ESF0654 PDS开发板外部中断
1 个回答
东软载波ESF0654 PDS开发板高级控制定时器AD16C4T
1 个回答
用串口调试助手为什么只能在hex模式接收发送而在文本模式不行
9 个回答
触摸芯片SC02B/SC04B在地砖灯的设计方案
1 个回答
相关文章
51单片机与蓝牙模块连接
0个评论
51单片机的硬件结构
0个评论
基于51单片机的无线遥控器制作
0个评论
51单片机 AD转换
0个评论
51单片机数码管递增显示
0个评论
如何实现对单片机寄存器的访问
0个评论
基于51单片机的指纹密码锁
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
51单片机
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#define uchar unsigned char
#define uint unsigned int
uchar code table1[]="The distance is :";
uchar code table2[]="0123456789 ";
uchar code table3[]=" CM";
double distance;
sbit lcden=P2^6;
sbit lcdrs=P2^4;
sbit rw= P2^5;
sbit Trig=P2^0;
sbit Echo=P3^3;
bit succeed_flag=0;
void delay(uint z)
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void delay_20us()
{
uchar a ;
for(a=0;a<20;a++);
}
//***************************************************************
//显示数据转换程序
void write_com(uchar com)
{
lcdrs=0;
P0=com;
delay(5);
lcden=1;
delay(5);
lcden=0;
}
void write_date(uchar date)
{
lcdrs=1;
P0=date;
delay(5);
lcden=1;
delay(5);
lcden=0;
}
void LCD_init()
{
uchar num;
lcden=0;rw=0;
write_com(0x38);
write_com(0x0c);
write_com(0x06);
write_com(0x01);
write_com(0x80);
for(num=0;num<17;num++){
write_date(table1[num]);
delay(2);
}
write_com(0x80+0x43);
for(num=0;num<3;num++)
{
write_date(table3[num]);
delay(2);
}
}
void LCD_show( int m)
{
write_com(0x80+0x40);
{
uchar num2;
num2=m/100%10;
write_date(table2[num2]);
delay(2);
num2=m/10%10;
write_date(table2[num2]);
delay(2);
num2=m%10;
write_date(table2[num2]);
delay(2);
}
}
//***************************************************************
//主程序
void main()
{
LCD_init();
Trig=0; //首先拉低脉冲输入引脚
TMOD=0x10; //定时器1,16位工作方式
while(1)
{
EA=0; //关总中断
IT1=1;
Trig=1;//超声波输入端
delay_20us(); //延时20us
Trig=0; //产生一个20us的脉冲
while(Echo==0); //等待Echo回波引脚变高电平
succeed_flag=0; //清测量成功标志
EA=1;
EX1=1;
TR1=1; //启动定时器1
delay(20); //等待测量的结果
if(succeed_flag==1)
LCD_show(distance);
if(succeed_flag==0)
{ distance=0; //没有回波则清零
LCD_show(distance);
}
}
}
//***************************************************************
//外部中断0,用做判断回波电平
void exter() interrupt 2 // 外部中断1是2号
{
TR1=0;
EX1=0;
distance=(TH1*256+TL1+59)*0.0172; //厘米
succeed_flag=1;//至成功测量的标志
TH1=0; //定时器1清零
TL1=0; //关闭外部中断1
}
一周热门 更多>