# Example for `sht3x` driver ## What it does This example demonstrates how to configure and interact with an `SHT3x` sensor using the ESP-IDF framework. - High-Level Mode `(CONFIG_EXAMPLE_SHT3X_DEMO_HL)`: When this mode is enabled, the example creates a task that triggers a temperature and humidity measurement every 5 seconds. For power efficiency, the sensor operates in single-shot mode. In this mode, the high-level function sht3x_read_temperature_humidity() is used to perform a complete measurement in a single step during each cycle. - Low-Level Mode `(CONFIG_EXAMPLE_SHT3X_DEMO_LL)`: When this mode is enabled, the example creates a task that also triggers a measurement every 5 seconds using single-shot mode for power efficiency. However, in this mode, the process is split into lower-level operations: the measurement is initiated, a delay is applied for the sensor to collect data, and the results are fetched using separate functions. To choose the desired mode, navigate to Example Configuration in `menuconfig` and select either `CONFIG_EXAMPLE_SHT3X_DEMO_HL` or `CONFIG_EXAMPLE_SHT3X_DEMO_LL`. By default, `CONFIG_EXAMPLE_SHT3X_DEMO_HL` is enabled. ## Wiring Connect `SCL` and `SDA` pins to the following pins with appropriate pull-up resistors. | Name | Description | Defaults | | ------------------------------- | --------------------- | -------------------------------------------------------------------------------- | | `CONFIG_EXAMPLE_I2C_MASTER_SCL` | GPIO number for `SCL` | "5" for `esp8266`, "6" for `esp32c3`, "19" for `esp32`, `esp32s2`, and `esp32s3` | | `CONFIG_EXAMPLE_I2C_MASTER_SDA` | GPIO number for `SDA` | "4" for `esp8266`, "5" for `esp32c3`, "18" for `esp32`, `esp32s2`, and `esp32s3` | <br> <img style="float: right;" src="https://github.com/AchimPieters/ESP32-SmartPlug/blob/main/images/MIT%7C%20SOFTWARE%20WHITE.svg" width="150"> ## Include the Library in Your Code In your project's source code, include the SHT3x library headers: #include "sht3x.h" ## Initialize the SHT3x Sensor Configure and initialize the SHT3x sensor using its APIs in your app_main.c file. Example Code: #include "sht3x.h" #include <driver/i2c.h> #include <stdio.h> #define I2C_MASTER_SCL_IO CONFIG_I2C_MASTER_SCL // GPIO number for I2C master clock #define I2C_MASTER_SDA_IO CONFIG_I2C_MASTER_SDA // GPIO number for I2C master data #define I2C_MASTER_FREQ_HZ 100000 // I2C master clock frequency #define I2C_MASTER_TX_BUF_DISABLE 0 // I2C master doesn't need buffer #define I2C_MASTER_RX_BUF_DISABLE 0 // I2C master doesn't need buffer void i2c_master_init(void) { i2c_config_t conf = { .mode = I2C_MODE_MASTER, .sda_io_num = I2C_MASTER_SDA_IO, .sda_pullup_en = GPIO_PULLUP_ENABLE, .scl_io_num = I2C_MASTER_SCL_IO, .scl_pullup_en = GPIO_PULLUP_ENABLE, .master.clk_speed = I2C_MASTER_FREQ_HZ, }; i2c_param_config(SHT3X_I2C_PORT, &conf); i2c_driver_install(SHT3X_I2C_PORT, conf.mode, I2C_MASTER_RX_BUF_DISABLE, I2C_MASTER_TX_BUF_DISABLE, 0); } void app_main(void) { uint8_t sht3x_address = CONFIG_SHT3X_I2C_ADDRESS; float temperature = 0.0f, humidity = 0.0f; // Initialize I2C i2c_master_init(); // Initialize SHT3X sensor if (sht3x_init(sht3x_address) == ESP_OK) { printf("SHT3X sensor initialized successfully\n"); } else { printf("Failed to initialize SHT3X sensor\n"); return; } // Read temperature and humidity while (1) { if (sht3x_read_temperature_humidity(sht3x_address, &temperature, &humidity) == ESP_OK) { printf("Temperature: %.2f C, Humidity: %.2f %%RH\n", temperature, humidity); } else { printf("Failed to read data from SHT3X sensor\n"); } vTaskDelay(2000 / portTICK_PERIOD_MS); } } StudioPieters® | Innovation and Learning Labs | <https://www.studiopieters.nl>
idf.py add-dependency "achimpieters/esp32-sht3x^1.0.6"