# ESP LCD ILI9342 [](https://components.espressif.com/components/jbrilha/esp_lcd_ili9342) This component prvides an implementation of the ILI9342(C) LCD driver using the `esp_lcd` component API, adapted from Espressif's own [ILI9341 component](https://components.espressif.com/components/espressif/esp_lcd_ili9341). | LCD controller | Communication interface | Component name | Link to datasheet | | :------------: | :---------------------: | :-------------: | :-------------------------------------------------------------------------------------: | | ILI9342 | SPI (half-duplex)\* | esp_lcd_ili9342 | [Specification](https://www.displayfuture.com/Display/datasheet/controller/ILI9342.pdf) | ## Usage in a project 1. As an ESP-IDF component, via `idf.py add-dependency`: ```bash idf.py add-dependency "jbrilha/esp_lcd_ili9342^1.0.0" ``` 2. Or including in it `idf_component.yml` - As a dependency: ```bash dependencies: jbrilha/esp_lcd_ili9342: "^1.0.0" ``` - As a direct repository ```bash dependencies: esp_lcd_ili9342: git: https://github.com/jbrilha/esp_lcd_ili9342.git ``` ## \*Important note regarding SPI This display driver uses half-duplex communication, so instead of the usual MOSI/MISO separation, it uses a single SDA line. This means that SPI does not require a MISO pin, like below: ```c void init_lcd_spi() { spi_bus_config_t bus_cfg = { .sclk_io_num = LCD_CLK_PIN, .mosi_io_num = LCD_MOSI_PIN, .miso_io_num = -1, // set to -1 .quadwp_io_num = -1, .quadhd_io_num = -1, .max_transfer_sz = 0; ESP_ERROR_CHECK(spi_bus_initialize(LCD_HOST, &bus_cfg, SPI_DMA_CH_AUTO)); } ``` If you intend to use other devices that require MISO in the same SPI bus, the bus config should it include it normally. ## Supported devices Only tested on an M5Stack Core Basic (v2.7) as it is its embedded display, but should work with other ESP32 variants as well ## Examples An example is present in the `examples` directory, using LVGL
4838fdc01265f02f6a8732c470ab3deae1b7b291
idf.py add-dependency "jbrilha/esp_lcd_ili9342^1.0.3"