基于51单片机轮胎胎压监测系统—数码管显示

基于51单片机轮胎胎压监测系统

(仿真+程序+设计报告)

功能介绍

具体功能:

1.MPX4115压力传感器胎压检测;

2.ADC0832进行模数转换后,51单片机处理控制;

3.数码管显示胎压;

4.胎压过高蜂鸣器报警;

​演示视频:

基于51单片机气压监测系统—数码管显示

//ÏßÐÔÇø¼ä±ê¶È±ä»»¹«Ê½£º    y=(115-15)/(243-13)*X+15kpa   
#include <AT89X52.h> 
#include <intrins.h>
#include <stdio.h>#define R24C04ADD 0xA1
#define W24C04ADD 0xA0//ADC0832µÄÒý½Å
sbit ADCS =P2^2;  //ADC0832 chip seclect
sbit ADDI =P2^4;  //ADC0832 k in
sbit ADDO =P2^4;  //ADC0832 k out
sbit ADCLK =P2^3;  //ADC0832 clock signalsbit SDA = P2 ^ 1;	                        //Êý¾ÝÏß
sbit SCL = P2 ^ 0;	                        //ʱÖÓÏß
bit bAck;	                                  //Ó¦´ð±êÖ¾ µ±bbAck=1ÊÇΪÕýÈ·µÄÓ¦´ðunsigned char dispbitcode[8]={0xf7,0xfb,0xfd,0xfe,0xef,0xdf,0xbf,0x7f};  //λɨÃè
unsigned char dispcode[11]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xff};  //¹²ÑôÊýÂë¹Ü×Ö¶ÎÂë
unsigned char dispbuf[4];
unsigned int temp;
unsigned char getdata; //»ñÈ¡ADCת»»»ØÀ´µÄÖµvoid delay_1ms(void)  //12mhz delay 1.01ms
{unsigned char x,y;   x=3;while(x--) {y=40;while(y--);}
}
void display(void)  //ÊýÂë¹ÜÏÔʾº¯Êý
{char k;for(k=0;k<4;k++){P1 = dispbitcode[k];P0 = dispcode[dispbuf[k]];if(k==1)	  //¼ÓÉÏÊýÂë¹ÜµÄdpСÊýµãP0&=0x7f;delay_1ms();	  }
}/************
¶ÁADC0832º¯Êý
************///²É¼¯²¢·µ»Ø
unsigned int Adc0832(unsigned char channel)     //ADת»»£¬·µ»Ø½á¹û
{unsigned char i=0;unsigned char j;unsigned int dat=0;unsigned char ndat=0;if(channel==0)channel=2;if(channel==1)channel=3;ADDI=1;_nop_();_nop_();ADCS=0;//À­µÍCS¶Ë_nop_();_nop_();ADCLK=1;//À­¸ßCLK¶Ë_nop_();_nop_();ADCLK=0;//À­µÍCLK¶Ë,ÐγÉϽµÑØ1_nop_();_nop_();ADCLK=1;//À­¸ßCLK¶ËADDI=channel&0x1;_nop_();_nop_();ADCLK=0;//À­µÍCLK¶Ë,ÐγÉϽµÑØ2_nop_();_nop_();ADCLK=1;//À­¸ßCLK¶ËADDI=(channel>>1)&0x1;_nop_();_nop_();ADCLK=0;//À­µÍCLK¶Ë,ÐγÉϽµÑØ3ADDI=1;//¿ØÖÆÃüÁî½áÊø _nop_();_nop_();dat=0;for(i=0;i<8;i++){dat|=ADDO;//ÊÕÊý¾ÝADCLK=1;_nop_();_nop_();ADCLK=0;//ÐγÉÒ»´ÎʱÖÓÂö³å_nop_();_nop_();dat<<=1;if(i==7)dat|=ADDO;}  for(i=0;i<8;i++){j=0;j=j|ADDO;//ÊÕÊý¾ÝADCLK=1;_nop_();_nop_();ADCLK=0;//ÐγÉÒ»´ÎʱÖÓÂö³å_nop_();_nop_();j=j<<7;ndat=ndat|j;if(i<7)ndat>>=1;}ADCS=1;//À­µÍCS¶ËADCLK=0;//À­µÍCLK¶ËADDO=1;//À­¸ßÊý¾Ý¶Ë,»Øµ½³õʼ״̬dat<<=8;dat|=ndat;return(dat);            //return ad k
}//Æô¶¯I2C×ÜÏߣ¬¼´·¢ËÍÆðʼÌõ¼þ
void StartI2C()
{SDA = 1;	                      //·¢ËÍÆðʼÌõ¼þÊý¾ÝÐźÅ_nop_();SCL = 1;_nop_();		                    //Æðʼ½¨Á¢Ê±¼ä´óÓÚ4.7us_nop_();_nop_();_nop_();_nop_();SDA = 0;	                      //·¢ËÍÆðʼÐźÅ_nop_();_nop_();_nop_();_nop_();_nop_();SCL = 0;	                        //ʱÖÓ²Ù×÷_nop_();_nop_();
}
//½áÊøI2C×ÜÏߣ¬¼´·¢ËÍI2C½áÊøÌõ¼þ
void StopI2C()
{SDA = 0;	                        //·¢ËͽáÊøÌõ¼þµÄÊý¾ÝÐźÅ_nop_();		                      //·¢ËͽáÊøÌõ¼þµÄʱÖÓÐźÅSCL = 1;	                        //½áÊøÌõ¼þ½¨Á¢Ê±¼ä´óÓÚ4us_nop_();_nop_();_nop_();_nop_();_nop_();SDA = 1;	                        //·¢ËÍI2C×ÜÏß½áÊøÃüÁî_nop_();_nop_();_nop_();_nop_();_nop_();	
}
//·¢ËÍÒ»¸ö×Ö½ÚµÄÊý¾Ý
void	SendByte(unsigned char c)
{unsigned char BitCnt;for(BitCnt = 0;BitCnt < 8;BitCnt++)			          //Ò»¸ö×Ö½Ú{if((c << BitCnt)& 0x80) SDA = 1;	           //ÅжϷ¢ËÍλelse	SDA = 0;_nop_();SCL = 1;	                      //ʱÖÓÏßΪ¸ß£¬Í¨Öª´Ó»ú¿ªÊ¼½ÓÊÕÊý¾Ý_nop_();_nop_();_nop_();_nop_();_nop_();SCL = 0;}_nop_();_nop_();SDA = 1;	                                        //ÊÍ·ÅÊý¾ÝÏߣ¬×¼±¸½ÓÊÜÓ¦´ðλ_nop_();_nop_();SCL = 1;_nop_();_nop_();_nop_();if(SDA == 1) bAck =0;else bAck = 1;		                                //ÅжÏÊÇ·ñÊÕµ½Ó¦´ðÐźÅSCL = 0;_nop_();_nop_();
}
//½ÓÊÕÒ»¸ö×Ö½ÚµÄÊý¾Ý
unsigned char RevByte()
{unsigned char retc;unsigned char BitCnt;retc = 0;SDA = 1;for(BitCnt=0;BitCnt<8;BitCnt++){_nop_();SCL = 0;	                                    //ÖÃʱÖÓÏßΪµÍ£¬×¼±¸½ÓÊÕ_nop_();_nop_();_nop_();_nop_();_nop_();SCL = 1;	                                    //ÖÃʱÖÓÏßΪ¸ßʹµÃÊý¾ÝÓÐЧ_nop_();_nop_();retc = retc << 1;	                            //×óÒƲ¹Áãif (SDA == 1)retc = retc + 1;                             	//µ±Êý¾ÝΪ1ÔòÊÕµ½µÄÊý¾Ý+1_nop_();_nop_();}SCL = 0;_nop_();_nop_();return(retc);                                   //·µ»ØÊÕµ½µÄÊý¾Ý
}unsigned char WIICByte(unsigned char WChipAdd,unsigned char InterAdd,unsigned char WIICData)
{StartI2C();										      //Æô¶¯×ÜÏßSendByte(WChipAdd);							//·¢ËÍÆ÷¼þµØÖ·ÒÔ¼°ÃüÁîif (bAck==1)											  //ÊÕµ½Ó¦´ð{SendByte(InterAdd);								//·¢ËÍÄÚ²¿×ÓµØÖ·if (bAck ==1){SendByte(WIICData);							//·¢ËÍÊý¾Ýif(bAck == 1){StopI2C();                    //Í£Ö¹×ÜÏßreturn(0xff);}else{return(0x03);}			}else{return(0x02);}}return(0x01);
}
//¶ÁÈ¡Ö¸¶¨Æ÷¼þµÄÄÚ²¿Ö¸¶¨µØÖ·Ò»¸ö×Ö½ÚÊý¾Ý
unsigned char RIICByte(unsigned char WChipAdd,unsigned char RChipAdd,unsigned char InterDataAdd)
{unsigned char TempData;	TempData = 0;StartI2C();								        //Æô¶¯SendByte(WChipAdd);					    	//·¢ËÍÆ÷¼þµØÖ·ÒÔ¼°¶ÁÃüÁîif (bAck==1)								    	//ÊÕµ½Ó¦´ð{SendByte(InterDataAdd);					//·¢ËÍÄÚ²¿×ÓµØÖ·if (bAck ==1){StartI2C();SendByte(RChipAdd);	if(bAck == 1){TempData = RevByte();       //½ÓÊÕÊý¾ÝStopI2C();                  //Í£Ö¹I2C×ÜÏßreturn(TempData);           //·µ»ØÊý¾Ý}else{return(0x03);}	}else{return(0x02);}}else{return(0x01);}
}

硬件设计

使用元器件:

单片机:AC89C52;

(注意:单片机是通用的,无论51还是52、无论stc还是at都一样,引脚功能都一样。程序也是一样的。)

设计资料

01 仿真图

本设计使用proteus7.8和proteus8.9两个版本设计,向下兼容,无需担心!具体如图!

02 程序

本设计使用软件keil4和keil5两个版本编程设计,无需担心!具体如图

03 设计报告

一千字设计报告,具体如下!

04 设计资料

        资料获取请关注同名公众号,全部资料包括仿真源文件 、程序(含注释)、设计报告、仿真视频等。具体内容如下,全网最全! !

资料获取请观看前面演示视频!

点赞分享一起学习成长。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/802940.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

想要品牌传播有效,先清楚这三个本质问题

在互联网时代&#xff0c;企业想要提高市场竞争力就需要做好品牌传播。然而有许多企业在做品牌传播时都会踩坑&#xff0c;原因是因为忽视了这三点&#xff0c;接下来就让媒介盒子和大家分享&#xff1a; 一、 文案本质是“购买理由” 在文案技巧中经常会出现一些词&#xff…

uniapp 表单使用Uview校验 包括城市选择器

<view><!-- 注意&#xff0c;如果需要兼容微信小程序&#xff0c;最好通过setRules方法设置rules规则 --><u--form labelPosition"left" :model"model1" :rules"rules" ref"uForm" labelWidth"174"><u…

Python中csr_matrix的两种初始化方法

本文以csr_matrix为例来说明sparse矩阵的使用方法&#xff0c;其他类型的sparse矩阵可以参考https://docs.scipy.org/doc/scipy/reference/sparse.html csr_matrix是Compressed Sparse Row matrix的缩写组合&#xff0c;下面介绍其两种初始化方法 csr_matrix((data, (row_ind…

【操作系统】-寄存器-具有记忆功能的元器件

为什么要使用寄存器 现代电子计算机用二进制来表示数字&#xff0c;人类发明了触发器&#xff0c;每个触发器可以保存1比特&#xff0c;为了保存一个较大的二进制数&#xff0c;组合一起就是新的元器件&#xff0c;称为寄存器&#xff08;register&#xff09;&#xff0c;或者…

MySQL-7.mysql约束

约束用于确保数据库中的数据满足特定的商业规则。 MySQL约束包含五种&#xff1a;not null、unique、primary key、foreign key、check 7.1 primary key 主键 字段名 字段类型 primary key 用于唯一的标识表的行数据&#xff0c;当定义主键约束后&#xff0c;该列不能重复。 pr…

第十课 Excel

最上方标题栏&#xff1a; 显示共工作薄名称&#xff0c;如果显示兼容模式是没有办法使用高级功能的。分辨高版本和低版本可以通过后缀名进行分辨&#xff1b;显示xlsx就是高版本工作薄&#xff0c;如果显示xls的话就是低版本工作薄了。如果同事老板都使用的是低版本的话我们发…

VM-UNet: Vision Mamba UNet for Medical Image Segmentation

VM-UNet: Vision Mamba UNet for Medical Image Segmentation VM-UNet&#xff1a;基于视觉Mamba UNet架构的医学图像分割 论文链接&#xff1a;http://arxiv.org/abs/2402.02491 代码链接&#xff1a;https://github.com/JCruan519/VM-UNet 1、摘要 文中利用状态空间模型SS…

【攻防世界】Confusion1

php的标志是大象&#xff0c;Python的标志是蛇 。Python 的 Flask 框架( Flask 使用 Jinja2 作为模板引擎 ) 点进register.php 输入{{3*4}} 输入 {{config}} 也有回显&#xff0c;ssti 判断是否存在ssti注入&#xff1a; 1. {{8*8}} 2. {{config}} 过滤了关键字&#xff0…

人工智能前沿成科技竞争新高地

以下文章来源&#xff1a;经济参考报 近日&#xff0c;首届中国具身智能大会&#xff08;CEAI 2024&#xff09;在上海举行。作为人工智能领域的前沿热点&#xff0c;具身智能正逐步走进现实&#xff0c;成为当前全球科技竞争的新高地、未来产业的新赛道、经济发展的新引擎。 “…

vue3中项目优化(Web Worker的使用)

1.Web Worker的作用 本人的理解&#xff1a;js是单线程执行代码&#xff0c;也就是代码需要从上往下执行&#xff0c;而使用Web Worker后相当于分了一条线程出来执行代码&#xff0c;那么两条线程肯定是比一条线程执行的快。 2.新建Web Worker文件 在public文件夹下新建work…

Linux:gcc

Linux&#xff1a;gcc gcc概述语言发展史gcc的编译过程预处理编译汇编 gcc的链接过程动态库与静态库 gcc概述 GCC&#xff08;英文全拼&#xff1a;GNU Compiler Collection&#xff09;是 GNU 工具链的主要组成部分&#xff0c;是一套以 GPL 和 LGPL 许可证发布的程序语言编译…

SpringBoot整合RabbitMQ-应答模式

一、应答模式 RabbitMQ 中的消息应答模式主要包括两种&#xff1a;自动应答&#xff08;Automatic Acknowledgement&#xff09;和手动应答&#xff08;Manual Acknowledgement&#xff09;。&#xff08;一般交换机发送消息&#xff0c;RabbitMQ只有在接收到消费者的确认后才…

LeetCode-139. 单词拆分【字典树 记忆化搜索 数组 哈希表 字符串 动态规划】

LeetCode-139. 单词拆分【字典树 记忆化搜索 数组 哈希表 字符串 动态规划】 题目描述&#xff1a;解题思路一&#xff1a;Python动态规划五部曲&#xff1a;定推初遍举【先遍历背包 后遍历物品】必须是排列解题思路二&#xff1a;Python动态规划版本二解题思路三&#xff1a;回…

C++——优先级队列

前言&#xff1a;这篇文章我们继续来分享一个c的容器——优先级队列。 一.理解优先级 何为优先级一说&#xff1f;实际上就是有顺序的意思。 优先级队列&#xff0c;即有顺序的队列&#xff0c;是一个无需我们自己进行排序操作&#xff0c;在数据传入时就会由容器自己排好序的…

冒泡排序解读

在信息爆炸的时代&#xff0c;数据无处不在&#xff0c;而如何有效地管理和处理这些数据&#xff0c;成为了现代计算机科学的一个重要课题。排序算法&#xff0c;作为数据处理的基本工具之一&#xff0c;对于数据的组织、搜索和分析起着至关重要的作用。今天&#xff0c;我们就…

在家学机器人技术指南

机器人技术是一个跨学科的领域&#xff0c;涉及计算机科学、电子工程、机械工程、人工智能等多个方面。在家自学机器人技术是完全可能的&#xff0c;但需要有计划和系统的学习路径&#xff0c;以及对相关领域的基础知识有一定的了解。 以下是一些建议&#xff0c;可以帮助你在家…

[C++][算法基础]合并集合(并查集)

一共有 n 个数&#xff0c;编号是 1∼n&#xff0c;最开始每个数各自在一个集合中。 现在要进行 m 个操作&#xff0c;操作共有两种&#xff1a; M a b&#xff0c;将编号为 a 和 b 的两个数所在的集合合并&#xff0c;如果两个数已经在同一个集合中&#xff0c;则忽略这个操…

力扣刷题Days33-209. 长度最小的子数组(js)

目录 1&#xff0c;题目-滑动窗口 2&#xff0c;代码 滑动窗口 3&#xff0c;学习与总结 1&#xff0c;题目-滑动窗口 给定一个含有 n 个正整数的数组和一个正整数 target 。找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl1, ..., numsr-1,…

动态路由-基于vue-admin-template

基于 vue-admin-template的动态路由 1. 拆分静态路由与动态路由 静态路由----所有人都可以访问—首页/登录/404 动态路由–有权限的人才可以访问—组织/角色/员工/权限 2. 根据用户权限添加动态路由 获取对应的权限标识(vuex中actions中把用户资料通过return 进行返回&…

代码算法训练营day14 | 理论基础、递归遍历

day14&#xff1a; 理论基础二叉树的分类&#xff1a;二叉树的种类&#xff1a;满二叉树完全二叉树二叉搜索树平衡二叉搜索树 二叉树的存储方式&#xff1a;链式存储顺序存储 二叉树的遍历方式&#xff1a;深度优先和广度优先遍历实现方式 二叉树的定义&#xff1a; 递归遍历递…