51单片机如何读取并打印SHT30温湿度数据

3星 · 超过75%的资源 需积分: 5 89 下载量 15 浏览量 更新于2024-11-15 7 收藏 83KB RAR 举报
资源摘要信息:"51单片机读取SHT30温湿度传感器程序" 知识点概述: 1. 51单片机:51单片机是指基于Intel 8051微控制器架构的一系列单片机。它们通常用于各种嵌入式系统和微控制器学习项目。这类单片机拥有不同的型号,但共同特点是有8位处理器、一定数量的RAM、ROM、多个并行输入输出端口、定时器和串行通信接口等。 2. SHT30温湿度传感器:SHT30是Sensirion公司生产的一款具有数字输出的温湿度传感器。它具有高精度、低功耗的特点,适合用于检测空气中的温度和湿度。SHT30通过I2C通信协议与微控制器交换数据,因此与51单片机连接时需要实现I2C协议。 3. I2C通信协议:I2C(Inter-Integrated Circuit)是一种由Philips开发的多主机串行计算机总线,它允许在同一总线上连接多个从设备和一个或多个主设备。I2C使用两条线进行通信,一条是串行数据线(SDA),另一条是串行时钟线(SCL)。 4. 串口打印输出:串口通信是计算机和其它设备之间进行串行数据交换的一种方式。在嵌入式系统中,串口打印输出指的是通过微控制器的串口将数据发送到连接的电脑上,通常用于调试和数据显示。 具体知识点: - 51单片机的基本工作原理,包括其内部结构、工作时钟、内存映射、输入输出端口操作等。 - SHT30传感器的特性,如测量精度、电源电压范围、测量范围、通信协议等。 - I2C总线的基本知识,例如起始和停止条件、地址字节、读写位、应答与非应答信号、时钟伸缩等。 - 如何在51单片机上实现I2C通信协议,包括编写I2C的启动、停止、发送字节、接收字节、应答和非应答等函数。 - 串口通信协议在51单片机上的实现,包括串口初始化、发送数据、接收数据等。 - 温湿度数据的采集流程,包括如何发送命令给SHT30传感器,如何读取传感器返回的数据,以及数据解析和转换。 - 串口打印输出的实现,包括如何将读取到的数据通过串口发送到电脑的串口监视器进行查看和调试。 实践中需要掌握的内容: - 如何设置和配置51单片机的硬件环境,比如晶振的选择、电源管理、外围电路等。 - 编写和调试I2C通信程序,确保能够正确地与SHT30传感器进行数据交换。 - 实现数据的解析算法,将从传感器接收到的数据转换为用户可读的温度和湿度值。 - 通过串口通信将数据发送到电脑,并使用诸如PuTTY或超级终端等工具进行数据监控和验证。 - 对程序进行必要的错误处理和异常管理,确保程序的稳定运行和准确读数。 以上知识点是编写和理解“51单片机读取SHT30温湿度传感器程序”的基础。这些知识能够帮助开发者在遇到类似问题时进行有效的故障排查和系统优化。
2019-04-13 上传
sht30的基于c51单片机驱动程序:#include #include #include "I2C.h" #include "SHT30.h" #define uint unsigned int #define uchar unsigned char void display(); unsigned char code tableduan[]= { 0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71 }; uchar data DIS_ROME[6]= {0,0,0,0,0,0}; //显示缓存区(4) uchar DISP=0;//缓存区指针 uchar SCANF=0xDF;//扫描指针 sbit LED1=P1^0; sbit LED2=P1^1; sbit LED3=P1^2; sbit LED4=P1^3; sbit VOC_A=P3^5; sbit VOC_B=P3^6; sbit dula=P2^6; //IO口定义 sbit wela=P2^7; sbit key=P3^4; sbit beep_dr=P2^3; uint pm1 = 0; uint pm2 = 0; uint pm10 = 0; uchar vr=0; uint intrcnt=0; bit F_1HZ; uint voice_time_cnt; uchar Uart_Buf; uchar Rec_Addr=0; uchar mode=0; uchar Rec_Uart=0; uchar Recive_Buf[30]= {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; #define key P34 #define const_key_time1 50 unsigned char ucKeySec=0; //被触发的按键编号 unsigned int uiKeyTimeCnt1=0; //按键去抖动延时计数器 unsigned char ucKeyLock1=0; //按键触发后自锁的变量标志 unsigned char displaycnt=0; void keyscan() { if(key==1)//IO是高电平,说明按键没有被按下,这时要及时清零一些标志位 { ucKeyLock1=0; //按键自锁标志清零 uiKeyTimeCnt1=0;//按键去抖动延时计数器清零,此行非常巧妙,是我实战中摸索出来的。 } else if(ucKeyLock1==0)//有按键按下,且是第一次被按下 { uiKeyTimeCnt1++; //累加定时中断次数 if(uiKeyTimeCnt1>const_key_time1) { uiKeyTimeCnt1=0; ucKeyLock1=1; //自锁按键置位,避免一直触发 ucKeySec=1; //触发1号键 } } } void keyservice() { if(ucKeySec) { displaycnt=!displaycnt; } ucKeySec=0; } void UartInit(void) //9600bps@12.000MHz { TMOD=0x01; //设置定时器0为工作方式1 TH0=0xf8; //重装初始值(65535-500)=65035=0xfe0b TL0=0x2f; SCON=0x50; TMOD=0X21; IP =0x10; //把串口中断设置为最高优先级, EA=1; ES=1; ET0=1; TR0=1; } void T0_time(void) interrupt 1 //定时中断 { TF0=0; //清除中断标志 TR0=0; //关中断 keyscan(); keyservice(); display(); if(++intrcnt==1000) { intrcnt=0; } TH0=0xf8; TL0=0x2f; TR0=1; //开中断 } void display() //LED扫描 { if(displaycnt==1) { DIS_ROME[0]=0; DIS_ROME[1]=Hum_num[4]; DIS_ROME[2]=Hum_num[3]; DIS_ROME[3]=Hum_num[2]; DIS_ROME[4]=Hum_num[1]; DIS_ROME[5]=Hum_num[0]; } else { DIS_ROME[0]=0; DIS_ROME[1]=TEMP_num[4]; DIS_ROME[2]=TEMP_num[3]; DIS_ROME[3]=TEMP_num[2]; DIS_ROME[4]=TEMP_num[1]; DIS_ROME[5]=TEMP_num[0]; } wela=1; P0=SCANF; wela=0; dula=1; P0=tableduan[DIS_ROME[DISP]];//数据端口送数据 dula=0; DISP++;//缓存指针加1 SCANF=_cror_(SCANF,1);//扫描切换 if(DISP==7)//缓存指针到尾 { DISP=0;//计数归零 SCANF=0xDF;//扫完四个数码管,扫描复位 } // delay(5); } void main(void) //主函数 { UartInit(); I2C_inita(); while(1) { Getdat_SHT30(); SHT30_DATEChange(); } }