From 8065e5c8b144b99f138388e030a93550eebce8e8 Mon Sep 17 00:00:00 2001 From: Clyde Stubbs <2366188+clydebarrow@users.noreply.github.com> Date: Wed, 29 Nov 2023 12:06:55 +1100 Subject: [PATCH] ili9xxx display component doc update (#3200) --- components/display/ili9xxx.rst | 64 ++++++++++++++++++++++++++++------ 1 file changed, 54 insertions(+), 10 deletions(-) diff --git a/components/display/ili9xxx.rst b/components/display/ili9xxx.rst index b7eb0ee4b..ecce42783 100644 --- a/components/display/ili9xxx.rst +++ b/components/display/ili9xxx.rst @@ -1,4 +1,3 @@ - ILI9xxx TFT LCD Series ====================== @@ -14,6 +13,7 @@ With this display driver you can control the following displays: - ILI9341 - ILI9342 - ILI9481 + - ILI9481-18 (ILI9481 in 18 bit, i.e. 262K color, mode) - ILI9486 - ILI9488 - ILI9488_A (alternative gamma configuration for ILI9488) @@ -21,6 +21,7 @@ With this display driver you can control the following displays: - S3BOX - S3BOX_LITE - ST7796 + - ST7789V - TFT 2.4 - TFT 2.4R @@ -36,7 +37,7 @@ ILI9341 (`datasheet `__, displays from the same chip family with ESPHome. As this is a somewhat higher resolution display and may require pins beyond the typical SPI connections, it is better suited for use with the ESP32. -**Note:** To use 16bit instead of 8bit colors use a esp32 with enough PSRAM the display. +**Note:** use of 16 bit colors requires double the amount of RAM as 8 bit, and may need PSRAM to be available. .. figure:: images/ili9341-full.jpg :align: center @@ -62,15 +63,13 @@ Configuration variables: - **model** (**Required**): The model of the display. Options are: - - ``M5STACK``, ``TFT 2.4``, ``TFT 2.4R``, ``S3BOX``, ``S3BOX_LITE`` - - ``ILI9341``, ``ILI9342``, ``ILI9481``, ``ILI9486``, ``ILI9488``, ``ILI9488_A`` (alternative gamma configuration for ILI9488), ``ST7796`` - -.. note:: According to its documentation, the ESP32 S3 Box Lite has an ST7789V display driver. We've found, however, that it works with the ILIxxxx component here, instead. This could change in the future. + - ``M5STACK``, ``TFT 2.4``, ``TFT 2.4R``, ``S3BOX``, ``S3BOX_LITE``, ``ST7789V`` + - ``ILI9341``, ``ILI9342``, ``ILI9486``, ``ILI9488``, ``ILI9488_A`` (alternative gamma configuration for ILI9488) + - ``ILI9481``, ``ILI9481-18`` (18 bit mode) + - ``ST7789V``, ``ST7796`` - **dc_pin** (**Required**, :ref:`Pin Schema `): The DC pin. - **reset_pin** (*Optional*, :ref:`Pin Schema `): The RESET pin. -- **rotation** (*Optional*): Set the rotation of the display. Everything drawn in the ``lambda:`` will be rotated - per this option. One of ``0°`` (default), ``90°``, ``180°``, or ``270°``. - **lambda** (*Optional*, :ref:`lambda `): The lambda to use for rendering the content on the display. See :ref:`display-engine` for more information. - **update_interval** (*Optional*, :ref:`config-time`): The interval to re-draw the screen. Defaults to ``5s``. @@ -83,10 +82,33 @@ Configuration variables: - ``NONE`` (default) - ``GRAYSCALE`` - ``IMAGE_ADAPTIVE`` + +- **color_order** (*Optional*): Should be one of ``bgr`` (default) or ``rgb``. - **color_palette_images** (*Optional*): A list of image files that will be used to generate the color pallet for the display. This should only be used in conjunction with ``-color_palette: IMAGE_ADAPTIVE`` above. The images will be analysed at compile time and a custom color pallet will be created based on the most commonly occuring colors. A typical setting would be a sample image that represented the fully populated display. This can significantly improve the quality of displayed images. Note that these images are not stored on the ESP device, just the 256byte color pallet created from them. -- **dimensions** (*Optional*): Dimensions of the screen with WIDTHxHEIGHT. Usually not needed since ``model:`` has good defaults. +- **dimensions** (*Optional*): Dimensions of the screen, specified either as *width* **x** *height* (e.g ``320x240``) or with separate config keys. If not provided the dimensions will be determined by the model selected. + + - **height** (**Required**, int): Specifies height of display in pixels. + - **width** (**Required**, int): Specifies width of display. + - **offset_width** (*Optional*, int): Specify an offset for the x-direction of the display, typically used when an LCD is smaller than the maximum supported by the driver chip. Default is 0 + - **offset_height** (*Optional*, int): Specify an offset for the y-direction of the display. Default is 0. + - **data_rate** (*Optional*): Set the data rate of the SPI interface to the display. One of ``80MHz``, ``40MHz`` (default), ``20MHz``, ``10MHz``, ``5MHz``, ``2MHz``, ``1MHz``, ``200kHz``, ``75kHz`` or ``1kHz``. If you have multiple ILI9xxx displays they must all use the same **data_rate**. -- **invert_display** (*Optional*): With this boolean option you can invert the some of the display colors manual. **Note** some of the displays have this option set automatically to true and can't be changed. +- **spi_mode** (*Optional*): Set the mode for the SPI interface to the display. Default is ``MODE0`` but some displays require ``MODE3``. +- **invert_colors** (*Optional*): With this boolean option you can invert the display colors. **Note** some of the displays have this option set automatically to true and can't be changed. +- **rotation** (*Optional*): Rotate the display presentation in software. Choose one of ``0°``, ``90°``, ``180°``, or ``270°``. This option cannot be used with ``transform``. +- **transform** (*Optional*): Transform the display presentation using hardware. All defaults are ``false``. This option cannot be used with ``rotation``. + + - **swap_xy** (*Optional*, boolean): If true, exchange the x and y axes. + - **mirror_x** (*Optional*, boolean): If true, mirror the x axis. + - **mirror_y** (*Optional*, boolean): If true, mirror the y axis. + + +**Note:** To rotate the display in hardware use one of the following combinations: + + - 90 degrees - use ``swap_xy`` with ``mirror_x`` + - 180 degrees - use ``mirror_x`` with ``mirror_y`` + - 270 degrees - use ``swap_xy`` with ``mirror_y`` + Configuration examples ********************** @@ -172,6 +194,28 @@ To configure an image adaptive color pallet to show greater than 8 bit color dep lambda: |- it.image(0, 0, id(myimage)); +Using the ``transform`` options to hardware rotate the display on a Lilygo T-Embed. This has an st7789v but only uses 170 pixels of the 240 width. +This config rotates the display into landscape mode using the driver chip. + +.. code-block:: yaml + + display: + - platform: ili9xxx + model: st7789v + height: 170 + width: 320 + offset_height: 35 + offset_width: 0 + transform: + swap_xy: true + mirror_x: false + mirror_y: true + color_order: bgr + data_rate: 80MHz + cs_pin: 10 + dc_pin: GPIO13 + reset_pin: GPIO9 + See Also --------