mirror of
https://github.com/esphome/esphome-docs.git
synced 2025-01-25 22:11:29 +01:00
ili9xxx display component doc update (#3200)
This commit is contained in:
parent
06d33db20e
commit
8065e5c8b1
@ -1,4 +1,3 @@
|
|||||||
|
|
||||||
ILI9xxx TFT LCD Series
|
ILI9xxx TFT LCD Series
|
||||||
======================
|
======================
|
||||||
|
|
||||||
@ -14,6 +13,7 @@ With this display driver you can control the following displays:
|
|||||||
- ILI9341
|
- ILI9341
|
||||||
- ILI9342
|
- ILI9342
|
||||||
- ILI9481
|
- ILI9481
|
||||||
|
- ILI9481-18 (ILI9481 in 18 bit, i.e. 262K color, mode)
|
||||||
- ILI9486
|
- ILI9486
|
||||||
- ILI9488
|
- ILI9488
|
||||||
- ILI9488_A (alternative gamma configuration for ILI9488)
|
- ILI9488_A (alternative gamma configuration for ILI9488)
|
||||||
@ -21,6 +21,7 @@ With this display driver you can control the following displays:
|
|||||||
- S3BOX
|
- S3BOX
|
||||||
- S3BOX_LITE
|
- S3BOX_LITE
|
||||||
- ST7796
|
- ST7796
|
||||||
|
- ST7789V
|
||||||
- TFT 2.4
|
- TFT 2.4
|
||||||
- TFT 2.4R
|
- TFT 2.4R
|
||||||
|
|
||||||
@ -36,7 +37,7 @@ ILI9341 (`datasheet <https://cdn-shop.adafruit.com/datasheets/ILI9341.pdf>`__,
|
|||||||
displays from the same chip family with ESPHome. As this is a somewhat higher resolution display and may require pins
|
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.
|
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
|
.. figure:: images/ili9341-full.jpg
|
||||||
:align: center
|
:align: center
|
||||||
@ -62,15 +63,13 @@ Configuration variables:
|
|||||||
|
|
||||||
- **model** (**Required**): The model of the display. Options are:
|
- **model** (**Required**): The model of the display. Options are:
|
||||||
|
|
||||||
- ``M5STACK``, ``TFT 2.4``, ``TFT 2.4R``, ``S3BOX``, ``S3BOX_LITE``
|
- ``M5STACK``, ``TFT 2.4``, ``TFT 2.4R``, ``S3BOX``, ``S3BOX_LITE``, ``ST7789V``
|
||||||
- ``ILI9341``, ``ILI9342``, ``ILI9481``, ``ILI9486``, ``ILI9488``, ``ILI9488_A`` (alternative gamma configuration for ILI9488), ``ST7796``
|
- ``ILI9341``, ``ILI9342``, ``ILI9486``, ``ILI9488``, ``ILI9488_A`` (alternative gamma configuration for ILI9488)
|
||||||
|
- ``ILI9481``, ``ILI9481-18`` (18 bit mode)
|
||||||
.. 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.
|
- ``ST7789V``, ``ST7796``
|
||||||
|
|
||||||
- **dc_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The DC pin.
|
- **dc_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The DC pin.
|
||||||
- **reset_pin** (*Optional*, :ref:`Pin Schema <config-pin_schema>`): The RESET pin.
|
- **reset_pin** (*Optional*, :ref:`Pin Schema <config-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 <config-lambda>`): The lambda to use for rendering the content on the display.
|
- **lambda** (*Optional*, :ref:`lambda <config-lambda>`): The lambda to use for rendering the content on the display.
|
||||||
See :ref:`display-engine` for more information.
|
See :ref:`display-engine` for more information.
|
||||||
- **update_interval** (*Optional*, :ref:`config-time`): The interval to re-draw the screen. Defaults to ``5s``.
|
- **update_interval** (*Optional*, :ref:`config-time`): The interval to re-draw the screen. Defaults to ``5s``.
|
||||||
@ -83,10 +82,33 @@ Configuration variables:
|
|||||||
- ``NONE`` (default)
|
- ``NONE`` (default)
|
||||||
- ``GRAYSCALE``
|
- ``GRAYSCALE``
|
||||||
- ``IMAGE_ADAPTIVE``
|
- ``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.
|
- **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**.
|
- **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
|
Configuration examples
|
||||||
**********************
|
**********************
|
||||||
@ -172,6 +194,28 @@ To configure an image adaptive color pallet to show greater than 8 bit color dep
|
|||||||
lambda: |-
|
lambda: |-
|
||||||
it.image(0, 0, id(myimage));
|
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
|
See Also
|
||||||
--------
|
--------
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user