实例介绍
【实例简介】
【实例截图】
【实例截图】
【核心代码】
#include<reg52.h>! //8051单片机头文件 #include<intrins.h> //数字计算头文件 #define LCD_BUS P0 //定义lcd显示总线 sbit ECHO=P1^1; //echo端口 sbit TRIG=P1^3; //trig端口 sbit lcden=P2^0; //定义1602液晶使能端 sbit lcdrs=P2^2; //定义1602液晶数据命令选择端 sbit lcdrw=P2^1; //1602液晶读写选择端 void delay_ms(unsigned int t); //延时函数生声明 void lcd_write_com(unsigned char com);//写命令函数声明 void lcd_write_dat(unsigned char dat);//写数据函数声明 void init_1602lcd(void); //液晶初始化函数声明 void start(void); //启动模块函数声明 void conut(void); //距离计算函数声明 unsigned char code lcd1[]="Text distance: ";// unsigned char code lcd2[]="0123456789.-MS=";// unsigned char code lcd3[]="error!";// unsigned int time; //定义计数值 unsigned long range; //定义距离值 bit flag=0; //定义溢出标志位 unsigned char disbuff[4]={0,0,0,0,};//定义中间值数组 /************************主函数*********************/ void main() { unsigned char x; //定义循环变量 init_1602lcd(); //初始化1602液晶 lcd_write_com(0x80 0x00);//从DDRAM显存00H地址处写入 for(x=0;x<16;x ) { lcd_write_dat(lcd1[x]);//显示数组1cd1的字符 } delay_ms(5); //延时 TMOD=0x01; //设T0为工作方式1 TH0=0; TL0=0; ET0=1; //开启T0中断 EA=1; //开启总中断 while(1) { start(); //启动没模块 while(!ECHO); //当echo为0时等待 TR0=1; //开启计数器 while(ECHO); //当echo为1等待计数完毕 TR0=0; //关闭计数器 conut(); //计算距离值 delay_ms(80); //延时 } } /**********************延时函数********************/ void delay_ms(unsigned int t) { unsigned int x,y; for(x=t;x>0;x--) { for(y=110;y>0;y--) { } } } /********************写命令函数*********************/ void lcd_write_com(unsigned char com) { lcdrs=0; //将数据命令选择端置低(写命令) lcden=0; //将读写选择端置低 LCD_BUS=com; //将输入的命令值赋给数据总线 delay_ms(2); //延时 lcden=1; //将使能端1cden拉高 delay_ms(2); //延时 lcden=0; //将1cden拉低,数据写入1602液晶 } /*******************写数据函数**********************/ void lcd_write_dat(unsigned char dat) { lcdrs=1; //数据命令的选择端拉高 (写数据) lcden=0; //使能端拉低 LCD_BUS=dat; //将输入的数据赋值给数据总线 delay_ms(2); //延时 lcden=1; //拉高使能端 delay_ms(2); //拉高使能端 lcden=0; //将1cden拉低,数据写入1602中 } /*****************1602液晶初始化函数*****************/ void init_1602lcd() { lcden=0; lcdrs=0; lcdrw=0; lcd_write_com(0x38);//写指令38H(8位数据线,两行字符) lcd_write_com(0x0c);//写指令0CH(显示功能开,无光标) lcd_write_com(0x06);//写指令06H(写入新数据光标右移,显示屏不移动) lcd_write_com(0x01);//写指令01H(清屏) delay_ms(5); //延时(清屏需要时间至少1.64ms) } /**********************距离计算函数********************/ void conut(void) { time=TH0*256 TL0; TH0=0; TL0=0; range=(time*1.75)/100; //计算出距离cm if((range>=400)||range<=2||flag==1)//超出测量范围 { flag=0; lcd_write_com(0x80 0x40 0x07);//从DDRAM显存40H地址处写入 lcd_write_dat('e'); lcd_write_com(0x80 0x40 0x08); lcd_write_dat('r'); lcd_write_com(0x80 0x40 0x09); lcd_write_dat('r'); lcd_write_com(0x80 0x40 0x0a); lcd_write_dat('o'); lcd_write_com(0x80 0x40 0x0b); lcd_write_dat('r'); lcd_write_com(0x80 0x40 0x0c); lcd_write_dat('!'); lcd_write_com(0x80 0x40 0x0d); lcd_write_dat('!'); } else //在测量范围中 { disbuff[0]=range%1000/100; disbuff[1]=range%100/10; disbuff[2]=range%10; lcd_write_com(0x80 0x40 0x07); //从DDRAM显存40H地址处写入 lcd_write_dat(lcd2[13]); lcd_write_com(0x80 0x40 0x08); lcd_write_dat(lcd2[14]); lcd_write_com(0x80 0x40 0x09); lcd_write_dat(lcd2[ disbuff[0] ]);//显示数组1cd2的字符 lcd_write_com(0x80 0x40 0x0a); lcd_write_dat(lcd2[10]); lcd_write_com(0x80 0x40 0x0b); lcd_write_dat(lcd2[ disbuff[1] ]);//显示数组1cd2的字符 lcd_write_com(0x80 0x40 0x0c); lcd_write_dat(lcd2[ disbuff[2] ]); lcd_write_com(0x80 0x40 0x0d); lcd_write_dat(lcd2[12]); } } /**********************模块启动函数*********************/ void start(void) { TRIG=1; //开始发射超声波 _nop_();_nop_();_nop_();_nop_(); _nop_();_nop_();_nop_();_nop_(); _nop_();_nop_();_nop_();_nop_(); _nop_();_nop_();_nop_();_nop_(); _nop_();_nop_();_nop_();_nop_(); _nop_(); TRIG=0; } /******************定时器0中断服务函数*****************/ void overflow() interrupt 1 { flag=1; //T0溢出,表示超出测距范围,置位溢出标志 } /******************结束**************/
好例子网口号:伸出你的我的手 — 分享!
相关软件
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论