STM32、C51驱动中科银河芯GXHT30温湿度芯片,可PIN TO PIN软硬件兼容SHT30 SHT31_gxht30驱动程序(2)

| — | — |
| 产品型号 | GXHT30 |
| 通信方式 | IIC-bus |
| 分辨率 | 16bit ADC |
| 封装大小 | 2.5mm × 2.5mm x 0.9mm (DFN-8) |
| 工作电压 | 2.5~5.5V |
| 工作范围 | -45~130℃ |
| 温度精度(典型) | ±0.3°C (-40°C ~ 90°C) |
| 湿度精度(典型) |  ±3% (10% ~ 90%) |
| IIC地址 | 0x44、0x45可选 |
| 平均功耗 | 2uA(@3.3V) |
| 空闲状态 | 0.2uA(@3.3V) |
| 抗静电能力 | 8KV(HBM),850V(CDM) |

三、参考驱动

通信时序

驱动实例
1、STM32F103 + GXHT30/GXHT31温湿度芯片驱动实例
STM32 GXHT30.h文件
#ifndef _GXHT30_H
#define _GXHT30_H

#include "stm32f10x.h"
#include "string.h"
#include "stdio.h"

extern float GXHT30_temp;

//如果移植程序时只要改一下三个地方就行了
#define GXHT30_SCL GPIO_Pin_5	                    //SCL-PA5
#define GXHT30_SDA GPIO_Pin_6	                    //SDA-PA6
#define GPIO_GXHT30 GPIOA

#define GXHT30_SCL_H GPIO_SetBits(GPIO_GXHT30,GXHT30_SCL)
#define GXHT30_SCL_L GPIO_ResetBits(GPIO_GXHT30,GXHT30_SCL)

#define GXHT30_SDA_H GPIO_SetBits(GPIO_GXHT30,GXHT30_SDA)
#define GXHT30_SDA_L GPIO_ResetBits(GPIO_GXHT30,GXHT30_SDA)

/* 声明全局函数 */
void GXHT30_INIT(void);
void GXHT30_SDA_OUT(void);
void GXHT30_SDA_IN(void);
void GXHT30_SDA_in(void);
void GXHT30_StarT(void);
void GXHT30_StoP(void);
void GXHT30_Ack(void);
void GXHT30_NAck(void);
u8   GXHT30_Wait_Ack(void);
void GXHT30_Send_Byte(u8 txd);
u8   GXHT30_Read_Byte(u8 ack);
void GXHT30_read_result(u8 addr);

void al_get_gxth30_temp(void);

#endif
STM32 GXHT30.c文件
#include "GXHT30.h"
#include "delay.h"

#define write 0
#define read  1

//定义全局变量
float GXHT30_temp,GXHT30_humi,GXHT30_Temperature,GXHT30_Humidity;

/*
* @name   CRC_8
* @brief  CRC-8校验
* @param  Crc_ptr   -> 校验数据首地址
		L  EN       -> 校验数据长度
* @retval CRC_Value -> 校验值      
*/
static uint8_t CRC_8(uint8_t *Crc_ptr,uint8_t LEN)
{
	uint8_t CRC_Value = 0xFF;
	uint8_t i = 0,j = 0;

	for(i=0;i<LEN;i++)
	{
		CRC_Value ^= *(Crc_ptr+i);
		for(j=0;j<8;j++)
		{
			if(CRC_Value & 0x80)
				CRC_Value = (CRC_Value << 1) ^ 0x31;
			else
				CRC_Value = (CRC_Value << 1);
		}
	}
	return CRC_Value;
}

/****************************************************************************
* Function Name  : GXHT30_INIT
* Description    : 初始化GPIO.
****************************************************************************/
void GXHT30_INIT()
{	
	GPIO_InitTypeDef GPIO_InitStructure;	
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
	GPIO_InitStructure.GPIO_Pin=GXHT30_SDA;
	GPIO_InitStructure.GPIO_Speed=GPIO_Speed
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(); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值