mirror of
https://github.com/esphome/esphome-docs.git
synced 2025-01-12 20:10:50 +01:00
93 lines
3.5 KiB
ReStructuredText
93 lines
3.5 KiB
ReStructuredText
TM1621 LCD Display
|
|
========================
|
|
|
|
.. seo::
|
|
:description: Instructions for setting up TM1621 LCD Display.
|
|
:image: tm1621.jpg
|
|
|
|
The ``tm1621`` display platform allows you to use the popular TM1621 LCD display drivers with ESPHome, that can find in Sonoff device like THR316D, THR320D, POWR316D or POWR320D
|
|
|
|
.. figure:: images/tm1621-full.jpg
|
|
:align: center
|
|
:width: 75.0%
|
|
|
|
TM1621 LCD Display.
|
|
|
|
The LCD have four signal, ``cs`` for chip select, ``data`` for data signal, ``read`` for reading data dir and ``write`` for writing data dir
|
|
|
|
|
|
.. code-block:: yaml
|
|
|
|
# Example configuration entry
|
|
display:
|
|
platform: tm1621
|
|
id: tm1621_display
|
|
cs_pin: GPIO17
|
|
data_pin: GPIO5
|
|
read_pin: GPIO23
|
|
write_pin: GPIO18
|
|
lambda: |-
|
|
it.printf(0, "%.1f", id(my_sensor1).state);
|
|
it.display_celsius(true);
|
|
it.printf(1, "%.1f", id(my_sensor2).state);
|
|
it.display_humidity(true);
|
|
|
|
Configuration variables:
|
|
------------------------
|
|
|
|
- **cs_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The pin you have the CS line.
|
|
- **data_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The pin you have the DATA line.
|
|
- **read_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The pin you have the READ line.
|
|
- **write_pin** (**Required**, :ref:`Pin Schema <config-pin_schema>`): The pin you have the WRITE line.
|
|
- **lambda** (*Optional*, :ref:`lambda <config-lambda>`): The lambda to use for rendering the content on the TM1621.
|
|
See :ref:`display-tm1621_lambda` for more information.
|
|
- **update_interval** (*Optional*, :ref:`config-time`): The interval to re-draw the screen. Defaults to ``1s``.
|
|
- **id** (*Optional*, :ref:`config-id`): Manually specify the ID used for code generation.
|
|
|
|
.. _display-tm1621_lambda:
|
|
|
|
Rendering Lambda
|
|
----------------
|
|
|
|
The TM1621 has a similar API to the fully fledged :ref:`display-engine`, but it's only a subset as the TM1621
|
|
LCD displays don't have a concept of individual pixels. In the lambda you're passed a variable called ``it``
|
|
as with all other displays. In this case however, ``it`` is a TM1621 instance (see API Reference).
|
|
|
|
The most basic operation with the TM1621 is wiring a simple number to the screen as in the configuration example
|
|
at the top of this page. But even though you're passing in a string (here ``"0123"``), ESPHome converts it
|
|
into a representation that the TM1621 can understand.
|
|
|
|
Each of the three methods (``print`` and ``printf``) all optionally take a the line number (0 for first line and 1 for the second).
|
|
This argument is ``0`` by default.
|
|
|
|
Also note that the ``.`` (dot) character is special because when ESPHome encounters it in the string the dot
|
|
segment of the previous position will be enabled.
|
|
|
|
.. code-block:: yaml
|
|
|
|
display:
|
|
- platform: tm1621
|
|
# ...
|
|
lambda: |-
|
|
it.printf(0, "%.1f", id(my_sensor1).state);
|
|
it.display_celsius(true);
|
|
it.printf(1, "%.1f", id(my_sensor2).state);
|
|
it.display_humidity(true);
|
|
|
|
|
|
Please see :ref:`display-printf` for a quick introduction into the ``printf`` formatting rules.
|
|
|
|
Also we have five function to display or not some unites:
|
|
- °C on the first line : ``display_celsius(bool)``
|
|
- °F on the first line : ``display_fahrenheit(bool)``
|
|
- %HR on the second line : ``display_humidity(bool)``
|
|
- V on the first line and A on the second line : ``display_voltage(bool)``
|
|
- kW/h on the first line and W on the second line : ``display_kwh(bool)``
|
|
|
|
See Also
|
|
--------
|
|
|
|
- :doc:`index`
|
|
- :apiref:`tm1621/tm1621.h`
|
|
- :ghedit:`Edit`
|