2018-10-17 20:44:37 +02:00
|
|
|
Text Sensor Component
|
|
|
|
=====================
|
|
|
|
|
2018-11-14 22:12:27 +01:00
|
|
|
.. seo::
|
|
|
|
:description: Instructions for setting up text sensors that represent their state as a string of text.
|
2018-11-19 18:32:16 +01:00
|
|
|
:image: folder-open.png
|
2018-11-14 22:12:27 +01:00
|
|
|
|
2018-10-17 20:44:37 +02:00
|
|
|
Text sensors are a lot like normal :doc:`sensors </esphomeyaml/components/sensor/index>`.
|
|
|
|
But where the "normal" sensors only represent sensors that output **numbers**, this
|
|
|
|
component can represent any *text*.
|
|
|
|
|
|
|
|
.. _config-text_sensor:
|
|
|
|
|
|
|
|
Base Text Sensor Configuration
|
|
|
|
------------------------------
|
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: yaml
|
2018-10-17 20:44:37 +02:00
|
|
|
|
|
|
|
# Example sensor configuration
|
|
|
|
name: Livingroom Temperature
|
|
|
|
|
|
|
|
# Optional variables:
|
|
|
|
icon: "mdi:water-percent"
|
|
|
|
|
|
|
|
Configuration variables:
|
|
|
|
|
|
|
|
- **name** (**Required**, string): The name for the sensor.
|
|
|
|
- **icon** (*Optional*, icon): Manually set the icon to use for the sensor in the frontend.
|
|
|
|
|
|
|
|
Automations:
|
|
|
|
|
|
|
|
- **on_value** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
|
|
|
when a new value is published. See :ref:`text_sensor-on_value`.
|
|
|
|
|
|
|
|
Text Sensor Automation
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
You can access the most recent state of the sensor in :ref:`lambdas <config-lambda>` using
|
2019-01-13 15:49:06 +01:00
|
|
|
``id(sensor_id).state``.
|
2018-10-17 20:44:37 +02:00
|
|
|
|
|
|
|
.. _text_sensor-on_value:
|
|
|
|
|
|
|
|
``on_value``
|
|
|
|
************
|
|
|
|
|
|
|
|
This automation will be triggered when a new value is published.
|
|
|
|
In :ref:`Lambdas <config-lambda>` you can get the value from the trigger with ``x``.
|
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: yaml
|
2018-10-17 20:44:37 +02:00
|
|
|
|
|
|
|
text_sensor:
|
|
|
|
- platform: version
|
|
|
|
# ...
|
|
|
|
on_value:
|
|
|
|
then:
|
|
|
|
- lambda: |-
|
|
|
|
ESP_LOGD("main", "The current version is %s", x.c_str());
|
|
|
|
|
|
|
|
Configuration variables: See :ref:`Automation <automation>`.
|
|
|
|
|
|
|
|
lambda calls
|
|
|
|
************
|
|
|
|
|
|
|
|
From :ref:`lambdas <config-lambda>`, you can call several methods on all text sensors to do some
|
|
|
|
advanced stuff (see the full :doc:`API Reference </api/sensor/index>` for more info).
|
|
|
|
|
2018-10-26 22:27:01 +02:00
|
|
|
- ``publish_state()``: Manually cause the sensor to push out a value.
|
2018-10-17 20:44:37 +02:00
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: cpp
|
2018-10-17 20:44:37 +02:00
|
|
|
|
|
|
|
// Within lambda, push a value of "Hello World"
|
2018-10-26 22:27:01 +02:00
|
|
|
id(my_sensor).publish_state("Hello World");
|
2018-10-17 20:44:37 +02:00
|
|
|
|
2018-10-26 22:27:01 +02:00
|
|
|
- ``.state``: Retrieve the current value of the sensor as an ``std::string`` object.
|
2018-10-17 20:44:37 +02:00
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: cpp
|
2018-10-17 20:44:37 +02:00
|
|
|
|
|
|
|
// For example, create a custom log message when a value is received:
|
2018-10-26 22:27:01 +02:00
|
|
|
std::string val = id(my_sensor).state;
|
2018-10-17 20:44:37 +02:00
|
|
|
ESP_LOGI("main", "Value of my sensor: %s", val.c_str());
|
|
|
|
|
|
|
|
See Also
|
|
|
|
--------
|
|
|
|
|
|
|
|
- :doc:`API Reference </api/text_sensor/index>`
|
|
|
|
- `Edit this page on GitHub <https://github.com/OttoWinter/esphomedocs/blob/current/esphomeyaml/components/text_sensor/index.rst>`__
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 1
|
2018-12-05 10:19:48 +01:00
|
|
|
:glob:
|
2018-10-17 20:44:37 +02:00
|
|
|
|
2018-12-05 10:19:48 +01:00
|
|
|
*
|
2018-10-17 20:44:37 +02:00
|
|
|
|
|
|
|
.. disqus::
|