# HDC302X
**Repository Path**: libdriver/hdc302x
## Basic Information
- **Project Name**: HDC302X
- **Description**: 适用于通用MCU和Linux系统的HDC302X(HDC3020, HDC3021, HDC3022)全功能驱动
- **Primary Language**: Unknown
- **License**: MIT
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2025-11-30
- **Last Updated**: 2025-11-30
## Categories & Tags
**Categories**: Uncategorized
**Tags**: IIC, 温度, 湿度
## README
[English](/README.md) | [ 简体中文](/README_zh-Hans.md) | [繁體中文](/README_zh-Hant.md) | [日本語](/README_ja.md) | [Deutsch](/README_de.md) | [한국어](/README_ko.md)
## LibDriver HDC302X
[](/misra/README.md) [](https://www.libdriver.com/docs/hdc302x/index.html) [](/LICENSE)
HDC302x 是一款基于集成式电容的相对湿度 (RH) 和温度传感器。它能够在宽电源电压范围(1.62V 至 5.5V)内提供高测量精度,并能以 2.5mm × 2.5mm 的小巧封装尺寸实现超低功耗。温度传感器和湿度传感器在量产阶段均经过 100% 测试和修正,可通过 NIST 进行追溯,且使用经 ISO/IEC 17025 标准校准的设备进行了验证。偏移误差校正功能可减少 RH 传感器因老化、暴露于极端工作条件和污染物环境所产生的偏移,使器件恢复到精度规格内。 在电池供电的物联网应用中,自动测量模式和警报功能可通过更大程度减少 MCU 睡眠时间来降低系统功耗。有四种不同 I 2C 地址支持高达 1MHz 的速度。加热元件用于消散冷凝和湿气。HDC3020 采用不带保护套的空腔封装。以下两个器件型号提供保护套选项,以保护空腔 RH 传感器:HDC3021 和 HDC3022。HDC3021 具有可拆卸保护胶带,可用于保形涂层和 PCB 清洗。HDC3022 配有可靠的 IP67 滤膜,可防尘防水并免于 PCB 清洗。
LibDriver HDC302X是LibDriver推出的HDC302X全功能驱动,该驱动提供温度、相对湿度读取和中断等功能并且它符合MISRA标准。
### 目录
- [说明](#说明)
- [安装](#安装)
- [使用](#使用)
- [example basic](#example-basic)
- [example shot](#example-shot)
- [example interrupt](#example-interrupt)
- [文档](#文档)
- [贡献](#贡献)
- [版权](#版权)
- [联系我们](#联系我们)
### 说明
/src目录包含了LibDriver HDC302X的源文件。
/interface目录包含了LibDriver HDC302X与平台无关的IIC总线模板。
/test目录包含了LibDriver HDC302X驱动测试程序,该程序可以简单的测试芯片必要功能。
/example目录包含了LibDriver HDC302X编程范例。
/doc目录包含了LibDriver HDC302X离线文档。
/datasheet目录包含了HDC302X数据手册。
/project目录包含了常用Linux与单片机开发板的工程样例。所有工程均采用shell脚本作为调试方法,详细内容可参考每个工程里面的README.md。
/misra目录包含了LibDriver MISRA代码扫描结果。
### 安装
参考/interface目录下与平台无关的IIC总线模板,完成指定平台的IIC总线驱动。
将/src目录,您使用平台的接口驱动和您开发的驱动加入工程,如果您想要使用默认的范例驱动,可以将/example目录加入您的工程。
### 使用
您可以参考/example目录下的编程范例完成适合您的驱动,如果您想要使用默认的编程范例,以下是它们的使用方法。
#### example basic
```C
#include "driver_hdc302x_basic.h"
uint8_t res;
uint8_t id[6];
uint32_t i;
float temperature;
float humidity;
/* basic init */
res = hdc302x_basic_init(HDC302X_ADDRESS_00);
if (res != 0)
{
return 1;
}
...
/* get nist id */
res = hdc302x_basic_get_nist_id(id);
if (res != 0)
{
(void)hdc302x_basic_deinit();
return 1;
}
/* output */
hdc302x_interface_debug_print("hdc302x: nist id is 0x%02X 0x%02X 0x%02X 0x%02X 0x%02X 0x%02X.\n",
id[0], id[1], id[2], id[3], id[4], id[5]);
...
/* loop */
for (i = 0; i < 3; i++)
{
/* delay 1000ms */
hdc302x_interface_delay_ms(1000);
/* read data */
res = hdc302x_basic_read((float *)&temperature, (float *)&humidity);
if (res != 0)
{
(void)hdc302x_basic_deinit();
return 1;
}
/* output */
hdc302x_interface_debug_print("hdc302x: %d/%d.\n", (uint32_t)(i + 1), (uint32_t)3);
hdc302x_interface_debug_print("hdc302x: temperature is %0.2fC.\n", temperature);
hdc302x_interface_debug_print("hdc302x: humidity is %0.2f%%.\n", humidity);
/* read humidity min */
res = hdc302x_basic_read_humidity_min(&humidity);
if (res != 0)
{
(void)hdc302x_basic_deinit();
return 1;
}
hdc302x_interface_debug_print("hdc302x: humidity min is %0.2f%%.\n", humidity);
/* read humidity max */
res = hdc302x_basic_read_humidity_max(&humidity);
if (res != 0)
{
(void)hdc302x_basic_deinit();
return 1;
}
hdc302x_interface_debug_print("hdc302x: humidity max is %0.2f%%.\n", humidity);
/* read temperature min */
res = hdc302x_basic_read_temperature_min(&temperature);
if (res != 0)
{
(void)hdc302x_basic_deinit();
return 1;
}
hdc302x_interface_debug_print("hdc302x: temperature min is %0.2fC.\n", temperature);
/* read temperature max */
res = hdc302x_basic_read_temperature_max(&temperature);
if (res != 0)
{
(void)hdc302x_basic_deinit();
return 1;
}
hdc302x_interface_debug_print("hdc302x: temperature max is %0.2fC.\n", temperature);
...
}
...
/* basic deinit */
(void)hdc302x_basic_deinit();
return 0;
```
#### example shot
```C
#include "driver_hdc302x_shot.h"
uint8_t res;
uint32_t i;
float temperature;
float humidity;
/* shot init */
res = hdc302x_shot_init(HDC302X_ADDRESS_00);
if (res != 0)
{
return 1;
}
...
/* read data */
res = hdc302x_shot_read((float *)&temperature, (float *)&humidity);
if (res != 0)
{
(void)hdc302x_shot_deinit();
return 1;
}
/* loop */
for (i = 0; i < 3; i++)
{
/* delay 1000ms */
hdc302x_interface_delay_ms(1000);
/* read data */
res = hdc302x_shot_read((float *)&temperature, (float *)&humidity);
if (res != 0)
{
(void)hdc302x_shot_deinit();
return 1;
}
/* output */
hdc302x_interface_debug_print("hdc302x: %d/%d.\n", (uint32_t)(i + 1), (uint32_t)3);
hdc302x_interface_debug_print("hdc302x: temperature is %0.2fC.\n", temperature);
hdc302x_interface_debug_print("hdc302x: humidity is %0.2f%%.\n", humidity);
...
}
...
/* shot deinit */
(void)hdc302x_shot_deinit();
return 0;
```
#### example interrupt
```C
#include "driver_hdc302x_interrupt.h"
uint8_t res;
uint32_t i;
float humidity_high = 50.0f;
float humidity_low = 30.0f;
float temperature_high = 30.0f;
float temperature_low = 20.0f;
float temperature;
float humidity;
static void a_callback(uint16_t type)
{
switch (type)
{
case HDC302X_STATUS_OVERALL_ALERT :
{
hdc302x_interface_debug_print("hdc302x: irq overall alert.\n");
break;
}
case HDC302X_STATUS_HEATER :
{
hdc302x_interface_debug_print("hdc302x: irq heater.\n");
break;
}
case HDC302X_STATUS_RH_TRACKING_ALERT :
{
hdc302x_interface_debug_print("hdc302x: irq rh tracking alert.\n");
break;
}
case HDC302X_STATUS_T_TRACKING_ALERT :
{
hdc302x_interface_debug_print("hdc302x: irq t tracking alert.\n");
break;
}
case HDC302X_STATUS_RH_HIGH_TRACKING_ALERT :
{
hdc302x_interface_debug_print("hdc302x: irq rh high tracking alert.\n");
break;
}
case HDC302X_STATUS_RH_LOW_TRACKING_ALERT :
{
hdc302x_interface_debug_print("hdc302x: irq rh low tracking alert.\n");
break;
}
case HDC302X_STATUS_T_HIGH_TRACKING_ALERT :
{
hdc302x_interface_debug_print("hdc302x: irq t high tracking alert.\n");
break;
}
case HDC302X_STATUS_T_LOW_TRACKING_ALERT :
{
hdc302x_interface_debug_print("hdc302x: irq t low tracking alert.\n");
break;
}
case HDC302X_STATUS_DEVICE_RESET_DETECTED :
{
hdc302x_interface_debug_print("hdc302x: irq device reset detected.\n");
break;
}
case HDC302X_STATUS_CHECKSUM_VERY :
{
hdc302x_interface_debug_print("hdc302x: irq checksum.\n");
break;
}
default :
{
hdc302x_interface_debug_print("hdc302x: unknown code.\n");
break;
}
}
}
/* interrupt init */
res = hdc302x_interrupt_init(HDC302X_ADDRESS_00, temperature_low, temperature_high,
humidity_low, humidity_high, a_callback);
if (res != 0)
{
return 1;
}
...
/* loop */
for (i = 0; i < 3; i++)
{
/* delay 1000ms */
hdc302x_interface_delay_ms(1000);
/* read data */
res = hdc302x_interrupt_read((float *)&temperature, (float *)&humidity);
if (res != 0)
{
(void)hdc302x_interrupt_deinit();
return 1;
}
/* output */
hdc302x_interface_debug_print("hdc302x: %d/%d.\n", (uint32_t)(i + 1), (uint32_t)3);
hdc302x_interface_debug_print("hdc302x: temperature is %0.2fC.\n", temperature);
hdc302x_interface_debug_print("hdc302x: humidity is %0.2f%%.\n", humidity);
/* run irq */
hdc302x_interrupt_irq_handler();
...
}
...
/* interrupt deinit */
(void)hdc302x_interrupt_deinit();
return 0;
```
### 文档
在线文档: [https://www.libdriver.com/docs/hdc302x/index.html](https://www.libdriver.com/docs/hdc302x/index.html)。
离线文档: /doc/html/index.html。
### 贡献
请参考CONTRIBUTING.md。
### 版权
版权 (c) 2015 - 现在 LibDriver 版权所有
MIT 许可证(MIT)
特此免费授予任何获得本软件副本和相关文档文件(下称“软件”)的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、转授许可和/或出售该软件副本,以及再授权被配发了本软件的人如上的权利,须在下列条件下:
上述版权声明和本许可声明应包含在该软件的所有副本或实质成分中。
本软件是“如此”提供的,没有任何形式的明示或暗示的保证,包括但不限于对适销性、特定用途的适用性和不侵权的保证。在任何情况下,作者或版权持有人都不对任何索赔、损害或其他责任负责,无论这些追责来自合同、侵权或其它行为中,还是产生于、源于或有关于本软件以及本软件的使用或其它处置。
### 联系我们
请联系lishifenging@outlook.com。