2
Doxygen
@ -38,7 +38,7 @@ PROJECT_NAME = "ESPHome"
|
|||||||
# could be handy for archiving the generated documentation or if some version
|
# could be handy for archiving the generated documentation or if some version
|
||||||
# control system is used.
|
# control system is used.
|
||||||
|
|
||||||
PROJECT_NUMBER = 2022.10.2
|
PROJECT_NUMBER = 2022.11.0b1
|
||||||
|
|
||||||
# Using the PROJECT_BRIEF tag one can provide an optional one line description
|
# Using the PROJECT_BRIEF tag one can provide an optional one line description
|
||||||
# for a project that appears at the top of each page and should give viewer a
|
# for a project that appears at the top of each page and should give viewer a
|
||||||
|
2
Makefile
@ -1,5 +1,5 @@
|
|||||||
ESPHOME_PATH = ../esphome
|
ESPHOME_PATH = ../esphome
|
||||||
ESPHOME_REF = 2022.10.2
|
ESPHOME_REF = 2022.11.0b1
|
||||||
|
|
||||||
.PHONY: html html-strict cleanhtml deploy help live-html Makefile netlify netlify-api api netlify-dependencies svg2png copy-svg2png minify
|
.PHONY: html html-strict cleanhtml deploy help live-html Makefile netlify netlify-api api netlify-dependencies svg2png copy-svg2png minify
|
||||||
|
|
||||||
|
@ -4,3 +4,5 @@
|
|||||||
# e.g: /components/sensors/abc.html /components/sensors/xyz.html 301
|
# e.g: /components/sensors/abc.html /components/sensors/xyz.html 301
|
||||||
/components/sensor/sgp40.html /components/sensor/sgp4x.html 301
|
/components/sensor/sgp40.html /components/sensor/sgp4x.html 301
|
||||||
/components/binary_sensor/xpt2046.html /components/touchscreen/xpt2046.html 301
|
/components/binary_sensor/xpt2046.html /components/touchscreen/xpt2046.html 301
|
||||||
|
/devices/esp8266.html /components/esp8266.html
|
||||||
|
/devices/esp32.html /components/esp32.html
|
||||||
|
@ -1 +1 @@
|
|||||||
2022.10.2
|
2022.11.0b1
|
@ -23,7 +23,7 @@ source.addEventListener('log', function (e) {
|
|||||||
log.innerHTML += '<span class="' + klass + '">' + e.data.substr(7, e.data.length - 11) + "</span>\n";
|
log.innerHTML += '<span class="' + klass + '">' + e.data.substr(7, e.data.length - 11) + "</span>\n";
|
||||||
});
|
});
|
||||||
|
|
||||||
actions = [
|
const actions = [
|
||||||
["switch", ["toggle"]],
|
["switch", ["toggle"]],
|
||||||
["light", ["toggle"]],
|
["light", ["toggle"]],
|
||||||
["fan", ["toggle"]],
|
["fan", ["toggle"]],
|
||||||
@ -31,7 +31,7 @@ actions = [
|
|||||||
["button", ["press"]],
|
["button", ["press"]],
|
||||||
["lock", ["lock", "unlock", "open"]],
|
["lock", ["lock", "unlock", "open"]],
|
||||||
];
|
];
|
||||||
multi_actions = [
|
const multi_actions = [
|
||||||
["select", "option"],
|
["select", "option"],
|
||||||
["number", "value"],
|
["number", "value"],
|
||||||
];
|
];
|
||||||
|
2
_static/webserver-v1.min.js
vendored
@ -1 +1 @@
|
|||||||
const source=new EventSource("/events");source.addEventListener("log",function(t){const e=document.getElementById("log");let n=[["[1;31m","e"],["[0;33m","w"],["[0;32m","i"],["[0;35m","c"],["[0;36m","d"],["[0;37m","v"]],o="";for(const e of n)t.data.startsWith(e[0])&&(o=e[1]);""==o&&(e.innerHTML+=t.data+"\n"),e.innerHTML+='<span class="'+o+'">'+t.data.substr(7,t.data.length-11)+"</span>\n"}),actions=[["switch",["toggle"]],["light",["toggle"]],["fan",["toggle"]],["cover",["open","close"]],["button",["press"]],["lock",["lock","unlock","open"]]],multi_actions=[["select","option"],["number","value"]],source.addEventListener("state",function(t){const e=JSON.parse(t.data);document.getElementById(e.id).children[1].innerText=e.state});const states=document.getElementById("states");let row,i=0;for(;row=states.rows[i];i++)if(row.children[2].children.length){for(const t of actions)if(row.classList.contains(t[0])){let e=row.id.substr(t[0].length+1);for(let n=0;n<row.children[2].children.length&&n<t[1].length;n++)row.children[2].children[n].addEventListener("click",function(){const o=new XMLHttpRequest;o.open("POST","/"+t[0]+"/"+e+"/"+t[1][n],!0),o.send()})}for(const t of multi_actions)if(row.classList.contains(t[0])){let e=row.id.substr(t[0].length+1);row.children[2].children[0].addEventListener("change",function(){const n=new XMLHttpRequest;n.open("POST","/"+t[0]+"/"+e+"/set?"+t[1]+"="+encodeURIComponent(this.value),!0),n.send()})}}
|
const source=new EventSource("/events");source.addEventListener("log",function(t){const e=document.getElementById("log");let n=[["[1;31m","e"],["[0;33m","w"],["[0;32m","i"],["[0;35m","c"],["[0;36m","d"],["[0;37m","v"]],o="";for(const e of n)t.data.startsWith(e[0])&&(o=e[1]);""==o&&(e.innerHTML+=t.data+"\n"),e.innerHTML+='<span class="'+o+'">'+t.data.substr(7,t.data.length-11)+"</span>\n"});const actions=[["switch",["toggle"]],["light",["toggle"]],["fan",["toggle"]],["cover",["open","close"]],["button",["press"]],["lock",["lock","unlock","open"]]];const multi_actions=[["select","option"],["number","value"]];source.addEventListener("state",function(t){const e=JSON.parse(t.data);document.getElementById(e.id).children[1].innerText=e.state});const states=document.getElementById("states");let row,i=0;for(;row=states.rows[i];i++)if(row.children[2].children.length){for(const t of actions)if(row.classList.contains(t[0])){let e=row.id.substr(t[0].length+1);for(let n=0;n<row.children[2].children.length&&n<t[1].length;n++)row.children[2].children[n].addEventListener("click",function(){const o=new XMLHttpRequest;o.open("POST","/"+t[0]+"/"+e+"/"+t[1][n],!0),o.send()})}for(const t of multi_actions)if(row.classList.contains(t[0])){let e=row.id.substr(t[0].length+1);row.children[2].children[0].addEventListener("change",function(){const n=new XMLHttpRequest;n.open("POST","/"+t[0]+"/"+e+"/set?"+t[1]+"="+encodeURIComponent(this.value),!0),n.send()})}}
|
||||||
|
116
changelog/2022.11.0.rst
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
ESPHome 2022.11.0 - 16th November 2022
|
||||||
|
======================================
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Changelog for ESPHome 2022.11.0.
|
||||||
|
:image: /_static/changelog-2022.10.0.png
|
||||||
|
:author: Jesse Hills
|
||||||
|
:author_twitter: @jesserockz
|
||||||
|
|
||||||
|
.. imgtable::
|
||||||
|
:columns: 2
|
||||||
|
|
||||||
|
|
||||||
|
Raspberry Pi Pico-W
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
To be written...
|
||||||
|
|
||||||
|
Script Parameters
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
To be written...
|
||||||
|
|
||||||
|
LCD Menu
|
||||||
|
--------
|
||||||
|
|
||||||
|
To be written...
|
||||||
|
|
||||||
|
|
||||||
|
Full list of changes
|
||||||
|
--------------------
|
||||||
|
|
||||||
|
New Features
|
||||||
|
^^^^^^^^^^^^
|
||||||
|
|
||||||
|
- Allow preserving WiFi credentials entered with captive_portal :esphomepr:`3813` by :ghuser:`kuba2k2` (new-feature)
|
||||||
|
|
||||||
|
New Components
|
||||||
|
^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
- Add support for wl-134 :esphomepr:`3569` by :ghuser:`hobbypunk90` (new-integration)
|
||||||
|
- New platform ethernet_info from component text_sensor :esphomepr:`3811` by :ghuser:`gtjadsonsantos` (new-integration)
|
||||||
|
- Implementation for Atlas Scientific Peristaltic Pump :esphomepr:`3528` by :ghuser:`carlos-sarmiento` (new-integration)
|
||||||
|
- Add adc128s102 sensor :esphomepr:`3822` by :ghuser:`DeerMaximum` (new-integration)
|
||||||
|
- Added component Daikin BRC to support ceiling cassette heatpumps :esphomepr:`3743` by :ghuser:`hagak` (new-integration)
|
||||||
|
- Initial Support for RP2040 platform :esphomepr:`3284` by :ghuser:`jesserockz` (new-integration)
|
||||||
|
- Implement a simple LCD menu :esphomepr:`3406` by :ghuser:`numo68` (new-integration)
|
||||||
|
|
||||||
|
Breaking Changes
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
- Don't Use Base Network Manual IP for WiFi AP :esphomepr:`3902` by :ghuser:`bkaufx` (breaking-change)
|
||||||
|
|
||||||
|
All changes
|
||||||
|
^^^^^^^^^^^
|
||||||
|
|
||||||
|
- Update the ibeacon code :esphomepr:`3859` by :ghuser:`fhriley`
|
||||||
|
- Don't Use Base Network Manual IP for WiFi AP :esphomepr:`3902` by :ghuser:`bkaufx` (breaking-change)
|
||||||
|
- Allow preserving WiFi credentials entered with captive_portal :esphomepr:`3813` by :ghuser:`kuba2k2` (new-feature)
|
||||||
|
- Add support for wl-134 :esphomepr:`3569` by :ghuser:`hobbypunk90` (new-integration)
|
||||||
|
- New platform ethernet_info from component text_sensor :esphomepr:`3811` by :ghuser:`gtjadsonsantos` (new-integration)
|
||||||
|
- Implementation for Atlas Scientific Peristaltic Pump :esphomepr:`3528` by :ghuser:`carlos-sarmiento` (new-integration)
|
||||||
|
- Add adc128s102 sensor :esphomepr:`3822` by :ghuser:`DeerMaximum` (new-integration)
|
||||||
|
- Added component Daikin BRC to support ceiling cassette heatpumps :esphomepr:`3743` by :ghuser:`hagak` (new-integration)
|
||||||
|
- Bump platformio from 6.0.2 to 6.1.4 :esphomepr:`3711` by :ghuser:`dependabot[bot]`
|
||||||
|
- Add API interface to request a complete device config as JSON. :esphomepr:`3911` by :ghuser:`RoboMagus`
|
||||||
|
- Initial Support for RP2040 platform :esphomepr:`3284` by :ghuser:`jesserockz` (new-integration)
|
||||||
|
- Bump esphome-dashboard to 20221020.0 :esphomepr:`3920` by :ghuser:`jesserockz`
|
||||||
|
- Fix missing dependencies for heatpumpir :esphomepr:`3933` by :ghuser:`jesserockz`
|
||||||
|
- Update the PR template :esphomepr:`3934` by :ghuser:`jesserockz`
|
||||||
|
- Fix error with require_framework_version and rp2040 :esphomepr:`3923` by :ghuser:`jesserockz`
|
||||||
|
- Make mDNS on rp2040 work :esphomepr:`3936` by :ghuser:`jesserockz`
|
||||||
|
- Send manufacturer name via API :esphomepr:`3938` by :ghuser:`jesserockz`
|
||||||
|
- Update base platformio board for rp2040 :esphomepr:`3937` by :ghuser:`jesserockz`
|
||||||
|
- Implement different random for rp2040 :esphomepr:`3939` by :ghuser:`jesserockz`
|
||||||
|
- add proper device class to uptime :esphomepr:`3928` by :ghuser:`nagyrobi`
|
||||||
|
- Show local mac when scanning wifi :esphomepr:`3635` by :ghuser:`cvwillegen`
|
||||||
|
- Prefix devcontainer image with ghcr.io :esphomepr:`3942` by :ghuser:`jesserockz`
|
||||||
|
- Implement InterruptLock for RP2040 :esphomepr:`3945` by :ghuser:`jesserockz`
|
||||||
|
- Implement RP2040 preferences :esphomepr:`3946` by :ghuser:`jesserockz`
|
||||||
|
- Fix filesystem size for RP2040 OTA :esphomepr:`3947` by :ghuser:`jesserockz`
|
||||||
|
- Bump esphome/Improv to 1.2.3 :esphomepr:`3948` by :ghuser:`jesserockz`
|
||||||
|
- Add core config option to limit compile process count :esphomepr:`3952` by :ghuser:`jesserockz`
|
||||||
|
- Some RP2040 wifi changes for AP mode :esphomepr:`3953` by :ghuser:`jesserockz`
|
||||||
|
- Update rp2040 to latest framework release from GitHub :esphomepr:`3954` by :ghuser:`jesserockz`
|
||||||
|
- [SM300D2] Reduce log severity for successful reads :esphomepr:`3955` by :ghuser:`pauln`
|
||||||
|
- Fix imports for rp2040 with no wifi :esphomepr:`3956` by :ghuser:`jesserockz`
|
||||||
|
- Allow using LED pin on rpi pico-w :esphomepr:`3957` by :ghuser:`jesserockz`
|
||||||
|
- Fix RP2040 SPISettings :esphomepr:`3960` by :ghuser:`jesserockz`
|
||||||
|
- Make some minor changes to I²C so rp2040 works :esphomepr:`3959` by :ghuser:`jesserockz`
|
||||||
|
- Bump tornado from 6.1 to 6.2 :esphomepr:`3620` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump pytest-cov from 3.0.0 to 4.0.0 :esphomepr:`3922` by :ghuser:`dependabot[bot]`
|
||||||
|
- Remove gitpod :esphomepr:`3964` by :ghuser:`balloob`
|
||||||
|
- Bump pyupgrade from 3.0.0 to 3.2.0 :esphomepr:`3973` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump pytest from 7.1.3 to 7.2.0 :esphomepr:`3966` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump actions/stale from 5 to 6 :esphomepr:`3841` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump pylint from 2.15.3 to 2.15.5 :esphomepr:`3978` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump pytest-mock from 3.8.2 to 3.10.0 :esphomepr:`3877` by :ghuser:`dependabot[bot]`
|
||||||
|
- Allow multiple bluetooth proxy connections :esphomepr:`3971` by :ghuser:`jesserockz`
|
||||||
|
- Always use gh releases in base platformio file for rp2040 :esphomepr:`3988` by :ghuser:`jesserockz`
|
||||||
|
- Allow the use of multiple RDM6300 devices :esphomepr:`3989` by :ghuser:`mbardeen`
|
||||||
|
- Bump aioesphomeapi from 10.13.0 to 11.4.2 :esphomepr:`3987` by :ghuser:`dependabot[bot]`
|
||||||
|
- rp2040: Set watchdog to reboot properly :esphomepr:`3991` by :ghuser:`jesserockz`
|
||||||
|
- RP2040 uart support :esphomepr:`3990` by :ghuser:`jesserockz`
|
||||||
|
- add uart number to LOGCONFIG :esphomepr:`3996` by :ghuser:`tomaszduda23`
|
||||||
|
- Implement a simple LCD menu :esphomepr:`3406` by :ghuser:`numo68` (new-integration)
|
||||||
|
- Lint updates :esphomepr:`3992` by :ghuser:`jesserockz`
|
||||||
|
- Bump zeroconf from 0.39.1 to 0.39.4 :esphomepr:`3979` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump black from 22.8.0 to 22.10.0 :esphomepr:`3986` by :ghuser:`dependabot[bot]`
|
||||||
|
- Skip validation of defined pins :esphomepr:`3999` by :ghuser:`jenscski`
|
||||||
|
- Bump pytest-asyncio from 0.19.0 to 0.20.1 :esphomepr:`4003` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump aioesphomeapi from 11.4.2 to 11.4.3 :esphomepr:`4002` by :ghuser:`dependabot[bot]`
|
||||||
|
- Bump platformio from 6.1.4 to 6.1.5 :esphomepr:`4004` by :ghuser:`dependabot[bot]`
|
||||||
|
- Enable calibration, callbacks and custom commands for EZO sensors :esphomepr:`3910` by :ghuser:`gvdhoven`
|
||||||
|
- Bump esphome-dashboard to 20221109.0 :esphomepr:`4006` by :ghuser:`jesserockz`
|
||||||
|
- Add support for parameters in scripts :esphomepr:`3538` by :ghuser:`jimtng`
|
@ -2,7 +2,7 @@ Changelog
|
|||||||
=========
|
=========
|
||||||
|
|
||||||
.. redirect::
|
.. redirect::
|
||||||
:url: /changelog/2022.10.0.html
|
:url: /changelog/2022.11.0.html
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:glob:
|
:glob:
|
||||||
|
@ -16,7 +16,7 @@ After 1 minute of unsuccessful WiFi connection attempts, the ESP will start a Wi
|
|||||||
:width: 70.0%
|
:width: 70.0%
|
||||||
|
|
||||||
In this web interface, you can manually override the WiFi settings of the device (please note
|
In this web interface, you can manually override the WiFi settings of the device (please note
|
||||||
this will be overwritten by any subsequent upload, so make sure to also update your YAML configuration).
|
this will be overwritten by any subsequent upload (unless ``keep_user_credentials`` is enabled) so make sure to also update your YAML configuration).
|
||||||
|
|
||||||
Additionally, you can upload a new firmware file.
|
Additionally, you can upload a new firmware file.
|
||||||
|
|
||||||
@ -34,9 +34,16 @@ manually in your browser.
|
|||||||
password: !secret wifi_ap_password
|
password: !secret wifi_ap_password
|
||||||
|
|
||||||
captive_portal:
|
captive_portal:
|
||||||
|
# Set to true to preserve captive_portal credentials over OTA updates
|
||||||
|
# Note that you can't set STA credentials in YAML if you're using this
|
||||||
|
keep_user_credentials: false
|
||||||
|
|
||||||
|
|
||||||
No configuration variables.
|
Configuration variables:
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
- **keep_user_credentials** (*Optional*, boolean): Do not erase WiFi credentials entered using :doc:`captive_portal` over subsequent OTA updates.
|
||||||
|
Note: WiFi STA credentials cannot be set in YAML when using this.
|
||||||
|
|
||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
@ -27,6 +27,8 @@ submit a feature request (see FAQ).
|
|||||||
+---------------------------------------+---------------------+----------------------+
|
+---------------------------------------+---------------------+----------------------+
|
||||||
| Daikin | ``daikin`` | yes |
|
| Daikin | ``daikin`` | yes |
|
||||||
+---------------------------------------+---------------------+----------------------+
|
+---------------------------------------+---------------------+----------------------+
|
||||||
|
| :ref:`Daikin BRC<daikin_brc>` | ``daikin_brc`` | yes |
|
||||||
|
+---------------------------------------+---------------------+----------------------+
|
||||||
| :ref:`Delonghi<delonghi_ir>` | ``delonghi`` | yes |
|
| :ref:`Delonghi<delonghi_ir>` | ``delonghi`` | yes |
|
||||||
+---------------------------------------+---------------------+----------------------+
|
+---------------------------------------+---------------------+----------------------+
|
||||||
| Fujitsu General | ``fujitsu_general`` | yes |
|
| Fujitsu General | ``fujitsu_general`` | yes |
|
||||||
@ -211,6 +213,28 @@ Configuration variables:
|
|||||||
header_high: 3265us # AC Units from LG in Brazil, for example use these timings
|
header_high: 3265us # AC Units from LG in Brazil, for example use these timings
|
||||||
header_low: 9856us
|
header_low: 9856us
|
||||||
|
|
||||||
|
.. _daikin_brc:
|
||||||
|
|
||||||
|
``daikin_brc`` Climate
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
The Daikin BRC remotes are used by the ceiling cassette model of Daikin heatpumps.
|
||||||
|
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **use_fahrenheit** (*Optional*, boolean): U.S. models of the Daikin BRC remote send the temperature in Fahrenheit, if your remote shows Fahrenheit and can not be changed to Celsius then set this to true. Defaults to ``false``.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
climate:
|
||||||
|
- platform: daikin_brc
|
||||||
|
name: "AC"
|
||||||
|
sensor: room_temperature
|
||||||
|
use_fahrenheit: true
|
||||||
|
|
||||||
|
|
||||||
.. _delonghi_ir:
|
.. _delonghi_ir:
|
||||||
|
|
||||||
``delonghi`` Climate
|
``delonghi`` Climate
|
||||||
|
BIN
components/display_menu/images/lcd_menu.png
Normal file
After Width: | Height: | Size: 72 KiB |
759
components/display_menu/index.rst
Normal file
@ -0,0 +1,759 @@
|
|||||||
|
Display Menu
|
||||||
|
============
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Instructions for setting up a simple hierarchical menu on displays.
|
||||||
|
:image: lcd_menu.png
|
||||||
|
|
||||||
|
.. _display_menu:
|
||||||
|
|
||||||
|
The integration provides a menu primarily intended to be controlled either by a rotary encoder
|
||||||
|
with a button or a five-button joystick controller. It allows to navigate a hierarchy of items
|
||||||
|
and submenus with the ability to change the values and execute commands. The menu can
|
||||||
|
be activated and deactivated on demand, allowing alternating between using the screen for
|
||||||
|
the menu and other information.
|
||||||
|
|
||||||
|
Overview
|
||||||
|
--------
|
||||||
|
|
||||||
|
This document describes the configuration and automations common for the components implementing
|
||||||
|
this integration. At the moment the character based LCD displays are supported using
|
||||||
|
the :ref:`lcd_menu <lcd_menu>` integration and an instance of this is used in the configuration
|
||||||
|
examples.
|
||||||
|
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
display:
|
||||||
|
- platform: lcd_pcf8574
|
||||||
|
id: my_lcd
|
||||||
|
...
|
||||||
|
lambda: |-
|
||||||
|
id(my_lcd_menu).draw();
|
||||||
|
if (!id(my_lcd_menu).is_active())
|
||||||
|
it.print("Menu is not active");
|
||||||
|
|
||||||
|
# Declare a LCD menu
|
||||||
|
lcd_menu:
|
||||||
|
id: my_lcd_menu
|
||||||
|
display_id: my_lcd
|
||||||
|
active: true
|
||||||
|
mode: rotary
|
||||||
|
on_enter:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "root enter");'
|
||||||
|
on_leave:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "root leave");'
|
||||||
|
items:
|
||||||
|
- type: back
|
||||||
|
text: 'Back'
|
||||||
|
- type: label
|
||||||
|
text: 'Label 1'
|
||||||
|
- type: label
|
||||||
|
text: !lambda |-
|
||||||
|
return "Templated label";
|
||||||
|
|
||||||
|
# Encoder to provide navigation
|
||||||
|
sensor:
|
||||||
|
- platform: rotary_encoder
|
||||||
|
...
|
||||||
|
on_anticlockwise:
|
||||||
|
- display_menu.up:
|
||||||
|
on_clockwise:
|
||||||
|
- display_menu.down:
|
||||||
|
|
||||||
|
# A de-bounced GPIO is used to 'click'
|
||||||
|
binary_sensor:
|
||||||
|
- platform: gpio
|
||||||
|
...
|
||||||
|
filters:
|
||||||
|
- delayed_on: 10ms
|
||||||
|
- delayed_off: 10ms
|
||||||
|
on_press:
|
||||||
|
- display_menu.enter:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **root_item_id** (*Optional*, :ref:`config-id`): Manually specify the ID of the root menu item.
|
||||||
|
- **active** (*Optional*, boolean): Whether the menu should start as active, meaning accepting
|
||||||
|
user interactions and displaying output. Defaults to ``true``.
|
||||||
|
- **mode** (*Optional*, string): Defines the navigation logic. The ``rotary`` mode expects
|
||||||
|
the clockwise movement wired to :ref:`display_menu.down <display_menu-down_action>`,
|
||||||
|
the anticlockwise one to :ref:`display_menu.up <display_menu-up_action>` and the switch
|
||||||
|
to :ref:`display_menu.enter <display_menu-enter_action>` action. The ``joystick`` mode
|
||||||
|
expects the up, down, left and right buttons wired to the :ref:`display_menu.up <display_menu-up_action>`,
|
||||||
|
:ref:`display_menu.down <display_menu-down_action>`, :ref:`display_menu.left <display_menu-left_action>`
|
||||||
|
and :ref:`display_menu.right <display_menu-right_action>` actions and the middle button
|
||||||
|
to the :ref:`display_menu.enter <display_menu-enter_action>` action. Defaults to ``rotary``.
|
||||||
|
- **menu** (**Required**): The first level of the menu.
|
||||||
|
|
||||||
|
Automations:
|
||||||
|
|
||||||
|
- **on_enter** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the menu level (here the root one) is entered. See :ref:`display_menu-on_enter`.
|
||||||
|
- **on_leave** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the menu level is not displayed anymore.
|
||||||
|
See :ref:`display_menu-on_leave`.
|
||||||
|
|
||||||
|
Menu Items
|
||||||
|
----------
|
||||||
|
|
||||||
|
The component manages a hierarchy of menu items. The common configuration variables are:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Manually specify the ID used for code generation.
|
||||||
|
- **type** (**Required**, string): The type of the menu item (see below).
|
||||||
|
- **text** (*Optional*, string, :ref:`templatable <config-templatable>`): The text displayed
|
||||||
|
for the menu item. If a lambda is specified it gets an ``it`` argument pointing to
|
||||||
|
the ``MenuItem`` that is being drawn.
|
||||||
|
|
||||||
|
|
||||||
|
.. _display_menu-edit_mode:
|
||||||
|
|
||||||
|
Editing values
|
||||||
|
**************
|
||||||
|
|
||||||
|
Some of the menu items provide a way to edit values either by selecting from a list of options
|
||||||
|
or changing a numeric one. Such items can be configured in two ways.
|
||||||
|
|
||||||
|
If the ``immediate_edit`` configuration is ``false``, the editing mode has to be activated
|
||||||
|
first by activating the rotary encoder's switch or the joystick's center button.
|
||||||
|
On the activation the ``on_enter`` automation is called and the item is marked as editable
|
||||||
|
(the ``>`` selection marker changes to ``*`` as default). The value can be then
|
||||||
|
iterated through the rotary wheel (in the ``rotary`` mode) or the joystick left
|
||||||
|
and right buttons (in the ``joystick`` one). The editing mode is deactivated
|
||||||
|
by another clicking of the switch, the ``on_leave`` automation is called and the selection
|
||||||
|
marker changes back.
|
||||||
|
|
||||||
|
If the ``immediate_edit`` configuration is ``true`` the menu item is editable immediately
|
||||||
|
when it is selected. The ``on_enter`` and ``on_leave`` are not called. In the ``joystick`` mode
|
||||||
|
the left and right buttons iterate through the values; the items that are editable
|
||||||
|
show the editable marker to signal that the buttons can be used. In the ``rotary`` mode
|
||||||
|
activating the switch iterates to the next value. The selection marker does not change
|
||||||
|
(here it is used to signal whether rotating the knob navigates the menu or changes the value).
|
||||||
|
The menu item of the ``number`` type can be only immediately editable in the ``joystick`` mode.
|
||||||
|
|
||||||
|
Label
|
||||||
|
*****
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
items:
|
||||||
|
- id: my_label
|
||||||
|
type: label
|
||||||
|
text: 'My Label'
|
||||||
|
|
||||||
|
The menu item of the type ``label`` just displays a text. There is no configuration and
|
||||||
|
no interaction is possible.
|
||||||
|
|
||||||
|
Menu
|
||||||
|
****
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
items:
|
||||||
|
- type: menu
|
||||||
|
text: 'My Submenu'
|
||||||
|
on_enter:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "enter: %s", it->get_text().c_str());'
|
||||||
|
on_leave:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "leave: %s", it->get_text().c_str());'
|
||||||
|
items:
|
||||||
|
- type: label
|
||||||
|
text: 'Label'
|
||||||
|
- type: back
|
||||||
|
text: 'Back'
|
||||||
|
|
||||||
|
The menu item of the type ``menu`` defines a list of child menu items. When the item
|
||||||
|
is clicked the display shows the new menu level.
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **menu** (**Required**): Defines the child menu items.
|
||||||
|
|
||||||
|
Automations:
|
||||||
|
|
||||||
|
- **on_enter** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the menu level is entered. See :ref:`display_menu-on_enter`.
|
||||||
|
- **on_leave** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the menu level is not displayed anymore.
|
||||||
|
See :ref:`display_menu-on_leave`.
|
||||||
|
|
||||||
|
Back
|
||||||
|
****
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
items:
|
||||||
|
- type: back
|
||||||
|
text: 'Back'
|
||||||
|
|
||||||
|
The menu item of the type ``back`` closes the current menu level and goes up in
|
||||||
|
the menu level hierarchy. The ``on_leave`` automation of the current level and
|
||||||
|
``on_enter`` one of the higher one are invoked. There is no configuration.
|
||||||
|
|
||||||
|
Select
|
||||||
|
******
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
items:
|
||||||
|
- type: select
|
||||||
|
immediate_edit: false
|
||||||
|
text: 'My Color'
|
||||||
|
select: my_color
|
||||||
|
on_enter:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "select enter: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
on_leave:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "select leave: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "select value: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
|
||||||
|
select:
|
||||||
|
- platform: template
|
||||||
|
id: my_color
|
||||||
|
optimistic: true
|
||||||
|
options:
|
||||||
|
- 'Red'
|
||||||
|
- 'Green'
|
||||||
|
- 'Blue'
|
||||||
|
|
||||||
|
The menu item of the type ``select`` allows cycling through a set of values defined by the
|
||||||
|
associated ``select`` component.
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **immediate_edit** (*Optional*, boolean): Whether the item can be immediately edited when
|
||||||
|
selected. See :ref:`Editing Values <display_menu-edit_mode>`. Defaults to ``false``.
|
||||||
|
- **select** (**Required**, :ref:`config-id`): A ``select`` component managing
|
||||||
|
the edited value.
|
||||||
|
- **value_lambda** (*Optional*, :ref:`lambda <config-lambda>`):
|
||||||
|
Lambda returning a string to be displayed as value. The lambda gets an ``it`` argument
|
||||||
|
pointing to the ``MenuItem``. If not specified the selected option name of the ``select``
|
||||||
|
component is used as the value.
|
||||||
|
|
||||||
|
Automations:
|
||||||
|
|
||||||
|
- **on_enter** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is activated. See :ref:`display_menu-on_enter`.
|
||||||
|
- **on_leave** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is exited.
|
||||||
|
See :ref:`display_menu-on_leave`.
|
||||||
|
- **on_value** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the value is changed.
|
||||||
|
See :ref:`display_menu-on_value`.
|
||||||
|
|
||||||
|
Number
|
||||||
|
******
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
items:
|
||||||
|
- type: number
|
||||||
|
text: 'My Number'
|
||||||
|
format: '%.2f'
|
||||||
|
number: my_number
|
||||||
|
on_enter:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "number enter: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
on_leave:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "number leave: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "number value: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
|
||||||
|
number:
|
||||||
|
- platform: template
|
||||||
|
id: my_number
|
||||||
|
optimistic: true
|
||||||
|
min_value: 10.0
|
||||||
|
max_value: 20.0
|
||||||
|
step: 0.5
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("number", "value: %f", x);'
|
||||||
|
|
||||||
|
The menu item of the type ``number`` allows editing a floating point number.
|
||||||
|
On click the ``on_enter`` automation is called and the item is marked as editable
|
||||||
|
(the ``>`` selection marker changes to ``*`` as default). Up and down events
|
||||||
|
then increase and decrease the value by steps defined in the ``number``,
|
||||||
|
respecting the ``min_value`` and ``max_value``. The editing mode is exited
|
||||||
|
by another click.
|
||||||
|
|
||||||
|
Note that the fractional floating point values do not necessarily add nicely and
|
||||||
|
ten times ``0.100000`` is not necessarily ``1.000000``. Use steps that are
|
||||||
|
powers of two (such as ``0.125``) or take care of the rounding explicitly.
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **immediate_edit** (*Optional*, boolean): Whether the item can be immediately edited when
|
||||||
|
selected. See :ref:`Editing Values <display_menu-edit_mode>`. Ignored in the ``rotary`` mode.
|
||||||
|
Defaults to ``false``.
|
||||||
|
- **number** (**Required**, :ref:`config-id`): A ``number`` component managing
|
||||||
|
the edited value. If on entering the value is less than ``min_value`` or more than
|
||||||
|
``max_value``, the value is capped to fall into the range.
|
||||||
|
- **format** (*Optional*, string): A ``printf``-like format string specifying
|
||||||
|
exactly one ``f`` or ``g``-type conversion used to display the current value.
|
||||||
|
Defaults to ``%.1f``.
|
||||||
|
- **value_lambda** (*Optional*, :ref:`lambda <config-lambda>`):
|
||||||
|
Lambda returning a string to be displayed as value. The lambda gets an ``it`` argument
|
||||||
|
pointing to the ``MenuItem``. If not specified the value of the ``number`` component
|
||||||
|
formatted according to the ``format`` is used as the value.
|
||||||
|
|
||||||
|
Automations:
|
||||||
|
|
||||||
|
- **on_enter** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is activated. See :ref:`display_menu-on_enter`.
|
||||||
|
- **on_leave** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is exited.
|
||||||
|
See :ref:`display_menu-on_leave`.
|
||||||
|
- **on_value** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the value is changed.
|
||||||
|
See :ref:`display_menu-on_value`.
|
||||||
|
|
||||||
|
Switch
|
||||||
|
******
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
items:
|
||||||
|
- type: switch
|
||||||
|
immediate_edit: false
|
||||||
|
text: 'My Switch'
|
||||||
|
on_text: 'Bright'
|
||||||
|
off_text: 'Dark'
|
||||||
|
switch: my_switch
|
||||||
|
on_enter:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "switch enter: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
on_leave:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "switch leave: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "switch value: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
|
||||||
|
switch:
|
||||||
|
- platform: template
|
||||||
|
id: my_switch
|
||||||
|
optimistic: true
|
||||||
|
|
||||||
|
The menu item of the type ``switch`` allows toggling the associated ``switch`` component.
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **immediate_edit** (*Optional*, boolean): Whether the item can be immediately edited when
|
||||||
|
selected. See :ref:`Editing Values <display_menu-edit_mode>`. Defaults to ``false``.
|
||||||
|
- **on_text** (*Optional*, string): The text for the ``ON`` state. Defaults to ``On``.
|
||||||
|
- **off_text** (*Optional*, string): The text for the ``OFF`` state. Defaults to ``Off``.
|
||||||
|
- **switch** (**Required**, :ref:`config-id`): A ``switch`` component managing
|
||||||
|
the edited value.
|
||||||
|
- **value_lambda** (*Optional*, :ref:`lambda <config-lambda>`):
|
||||||
|
Lambda returning a string to be displayed as value. The lambda gets an ``it`` argument
|
||||||
|
pointing to the ``MenuItem``. If not specified the ``on_text`` / ``off_text`` is used.
|
||||||
|
|
||||||
|
Automations:
|
||||||
|
|
||||||
|
- **on_enter** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is activated. See :ref:`display_menu-on_enter`.
|
||||||
|
- **on_leave** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is exited.
|
||||||
|
See :ref:`display_menu-on_leave`.
|
||||||
|
- **on_value** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the value is changed.
|
||||||
|
See :ref:`display_menu-on_value`.
|
||||||
|
|
||||||
|
Command
|
||||||
|
*******
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
items:
|
||||||
|
- type: command
|
||||||
|
text: 'Hide'
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
- display_menu.hide:
|
||||||
|
|
||||||
|
The menu item of the type ``command`` allows triggering commands. There is no
|
||||||
|
additional configuration.
|
||||||
|
|
||||||
|
Automations:
|
||||||
|
|
||||||
|
- **on_value** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the menu item is clicked.
|
||||||
|
See :ref:`display_menu-on_value`.
|
||||||
|
|
||||||
|
Custom
|
||||||
|
******
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
items:
|
||||||
|
- type: custom
|
||||||
|
immediate_edit: false
|
||||||
|
text: 'My Custom'
|
||||||
|
value_lambda: 'return to_string(some_state);'
|
||||||
|
on_next:
|
||||||
|
then:
|
||||||
|
lambda: 'some_state++;'
|
||||||
|
on_prev:
|
||||||
|
then:
|
||||||
|
lambda: 'some_state--;'
|
||||||
|
|
||||||
|
The menu item of the type ``custom`` delegates navigating the values to the automations
|
||||||
|
and displaying the value to the ``value_lambda``.
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **immediate_edit** (*Optional*, boolean): Whether the item can be immediately edited when
|
||||||
|
selected. See :ref:`Editing Values <display_menu-edit_mode>`. Defaults to ``false``.
|
||||||
|
- **value_lambda** (*Optional*, :ref:`lambda <config-lambda>`):
|
||||||
|
Lambda returning a string to be displayed as value. The lambda gets an ``it`` argument
|
||||||
|
pointing to the ``MenuItem``.
|
||||||
|
|
||||||
|
Automations:
|
||||||
|
|
||||||
|
- **on_enter** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is activated. See :ref:`display_menu-on_enter`.
|
||||||
|
- **on_leave** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the editing mode is exited.
|
||||||
|
See :ref:`display_menu-on_leave`.
|
||||||
|
- **on_value** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the value is changed.
|
||||||
|
See :ref:`display_menu-on_value`.
|
||||||
|
- **on_next** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the user navigates to the next value.
|
||||||
|
See :ref:`display_menu-on_next`.
|
||||||
|
- **on_prev** (*Optional*, :ref:`Automation <automation>`): An automation to perform
|
||||||
|
when the user navigates to the previous value.
|
||||||
|
See :ref:`display_menu-on_prev`.
|
||||||
|
|
||||||
|
Automations
|
||||||
|
-----------
|
||||||
|
|
||||||
|
.. _display_menu-on_enter:
|
||||||
|
|
||||||
|
``on_enter``
|
||||||
|
************
|
||||||
|
|
||||||
|
This automation will be triggered when the menu level is entered, i.e. the component
|
||||||
|
draws its items on the display. The ``it`` parameter points to a ``MenuItem`` class
|
||||||
|
with the information of the menu item describing the displayed child items.
|
||||||
|
If present at the top level it is an internally generated root menu item,
|
||||||
|
otherwise an user defined one.
|
||||||
|
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
...
|
||||||
|
items:
|
||||||
|
- type: menu
|
||||||
|
text: 'Submenu 1'
|
||||||
|
on_enter:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "enter: %s", it->get_text().c_str());'
|
||||||
|
|
||||||
|
.. _display_menu-on_leave:
|
||||||
|
|
||||||
|
``on_leave``
|
||||||
|
************
|
||||||
|
|
||||||
|
This automation will be triggered when the menu level is exited, i.e. the component
|
||||||
|
does not draw its items on the display anymore. The ``it`` parameter points to
|
||||||
|
a ``MenuItem`` class with the information of the menu item. If present at the
|
||||||
|
top level it is an internally generated root menu item, otherwise
|
||||||
|
an user defined one. It does not matter whether the level was left due to entering
|
||||||
|
the submenu or going back to the parent menu.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
...
|
||||||
|
items:
|
||||||
|
- type: menu
|
||||||
|
text: 'Submenu 1'
|
||||||
|
on_leave:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "leave: %s", it->get_text().c_str());'
|
||||||
|
|
||||||
|
.. _display_menu-on_value:
|
||||||
|
|
||||||
|
``on_value``
|
||||||
|
************
|
||||||
|
|
||||||
|
This automation will be triggered when the value edited through the menu changed
|
||||||
|
or a command was triggered.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
...
|
||||||
|
items:
|
||||||
|
- type: select
|
||||||
|
text: 'Select Item'
|
||||||
|
select: my_select_1
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
lambda: 'ESP_LOGI("display_menu", "select value: %s, %s", it->get_text().c_str(), it->get_value_text().c_str());'
|
||||||
|
|
||||||
|
.. _display_menu-on_next:
|
||||||
|
|
||||||
|
``on_next``
|
||||||
|
***********
|
||||||
|
|
||||||
|
This automation will be triggered when the user requested to set the value to the next one.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
...
|
||||||
|
items:
|
||||||
|
- type: custom
|
||||||
|
text: 'Custom Item'
|
||||||
|
value_lambda: 'return to_string(some_state);'
|
||||||
|
on_next:
|
||||||
|
then:
|
||||||
|
lambda: 'some_state++;'
|
||||||
|
|
||||||
|
.. _display_menu-on_prev:
|
||||||
|
|
||||||
|
``on_prev``
|
||||||
|
***********
|
||||||
|
|
||||||
|
This automation will be triggered when the user requested to set the value to the previous one.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
...
|
||||||
|
items:
|
||||||
|
- type: custom
|
||||||
|
text: 'Custom Item'
|
||||||
|
value_lambda: 'return to_string(some_state);'
|
||||||
|
on_prev:
|
||||||
|
then:
|
||||||
|
lambda: 'some_state--;'
|
||||||
|
|
||||||
|
.. _display_menu-up_action:
|
||||||
|
|
||||||
|
``display_menu.up`` Action
|
||||||
|
**************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` for navigating up in a menu. The action
|
||||||
|
is usually wired to an anticlockwise turn of a rotary encoder or to the upper
|
||||||
|
button of the joystick.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: rotary_encoder
|
||||||
|
...
|
||||||
|
on_anticlockwise:
|
||||||
|
- display_menu.up:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to navigate.
|
||||||
|
|
||||||
|
.. _display_menu-down_action:
|
||||||
|
|
||||||
|
``display_menu.down`` Action
|
||||||
|
****************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` for navigating down in a menu. The action
|
||||||
|
is usually wired to a clockwise turn of a rotary encoder or to the lower
|
||||||
|
button of the joystick.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: rotary_encoder
|
||||||
|
...
|
||||||
|
on_clockwise:
|
||||||
|
- display_menu.down:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to navigate.
|
||||||
|
|
||||||
|
.. _display_menu-left_action:
|
||||||
|
|
||||||
|
``display_menu.left`` Action
|
||||||
|
****************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` usually wired to the left button
|
||||||
|
of the joystick. In the ``joystick`` mode it is used to set the previous
|
||||||
|
value or to decrement the numeric one; depending on the ``immediate_edit``
|
||||||
|
flag entering the edit mode is required or not. If used in the ``rotary``
|
||||||
|
mode it exits the editing. In both modes it can be also used to navigate
|
||||||
|
back one level when used with the ``back`` menu item.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
binary_sensor:
|
||||||
|
- platform: gpio
|
||||||
|
...
|
||||||
|
on_press:
|
||||||
|
- display_menu.left:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to navigate.
|
||||||
|
|
||||||
|
.. _display_menu-right_action:
|
||||||
|
|
||||||
|
``display_menu.right`` Action
|
||||||
|
*****************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` usually wired to the right button
|
||||||
|
of the joystick. In the ``joystick`` mode it is used to set the next
|
||||||
|
value or to increment the numeric one; depending on the ``immediate_edit``
|
||||||
|
flag entering the edit mode is required or not. In both modes it can
|
||||||
|
be also used to enter the submenu when used with the ``menu`` menu item.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
binary_sensor:
|
||||||
|
- platform: gpio
|
||||||
|
...
|
||||||
|
on_press:
|
||||||
|
- display_menu.right:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to navigate.
|
||||||
|
|
||||||
|
.. _display_menu-enter_action:
|
||||||
|
|
||||||
|
``display_menu.enter`` Action
|
||||||
|
*****************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` for triggering a selected menu item, resulting
|
||||||
|
in an action depending on the type of the item - entering a submenu, starting/stopping
|
||||||
|
editing or triggering a command. The action is usually wired to a press button
|
||||||
|
of a rotary encoder or to the center button of the joystick.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
binary_sensor:
|
||||||
|
- platform: gpio
|
||||||
|
...
|
||||||
|
filters:
|
||||||
|
- delayed_on: 10ms
|
||||||
|
- delayed_off: 10ms
|
||||||
|
on_press:
|
||||||
|
- display_menu.enter:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to navigate.
|
||||||
|
|
||||||
|
.. display_menu-show_action:
|
||||||
|
|
||||||
|
``display_menu.show`` Action
|
||||||
|
****************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` for showing an inactive menu. The state
|
||||||
|
of the menu remains unchanged, i.e. the menu level shown at the moment it was hidden
|
||||||
|
is restored, as is the selected item. The following snippet shows the menu if it is
|
||||||
|
inactive, otherwise triggers the selected item.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_press:
|
||||||
|
- if:
|
||||||
|
condition:
|
||||||
|
display_menu.is_active:
|
||||||
|
then:
|
||||||
|
- display_menu.enter:
|
||||||
|
else:
|
||||||
|
- display_menu.show:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to show.
|
||||||
|
|
||||||
|
.. display_menu-hide_action:
|
||||||
|
|
||||||
|
``display_menu.hide`` Action
|
||||||
|
****************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` for hiding the menu. A hidden menu
|
||||||
|
does not react to ``draw()`` and does not process navigation actions.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
...
|
||||||
|
items:
|
||||||
|
- type: command
|
||||||
|
text: 'Hide'
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
- display_menu.hide:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to hide.
|
||||||
|
|
||||||
|
.. display_menu-show_main_action:
|
||||||
|
|
||||||
|
``display_menu.show_main`` Action
|
||||||
|
*********************************
|
||||||
|
|
||||||
|
This is an :ref:`Action <config-action>` for showing the root level of the menu.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
lcd_menu:
|
||||||
|
...
|
||||||
|
items:
|
||||||
|
- type: command
|
||||||
|
text: 'Show Main'
|
||||||
|
on_value:
|
||||||
|
then:
|
||||||
|
- display_menu.show_main:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): The ID of the menu to hide.
|
||||||
|
|
||||||
|
.. _display_menu-is_active:
|
||||||
|
|
||||||
|
``display_menu.is_active`` Condition
|
||||||
|
************************************
|
||||||
|
|
||||||
|
This :ref:`Condition <config-condition>` checks if the given menu is active, i.e.
|
||||||
|
shown on the display and processing navigation events.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_press:
|
||||||
|
- if:
|
||||||
|
condition:
|
||||||
|
display_menu.is_active:
|
||||||
|
...
|
||||||
|
|
||||||
|
See Also
|
||||||
|
--------
|
||||||
|
|
||||||
|
- :apiref:`display_menu_base/display_menu_base.h`
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
:glob:
|
||||||
|
|
||||||
|
*
|
107
components/display_menu/lcd_menu.rst
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
LCD Menu
|
||||||
|
========
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Instructions for setting up a simple hierarchical menu on displays.
|
||||||
|
:image: lcd_menu.png
|
||||||
|
|
||||||
|
The component provides an infrastructure for setting up a hierarchical menu
|
||||||
|
on the character based LCD displays.
|
||||||
|
|
||||||
|
|
||||||
|
.. figure:: images/lcd_menu.png
|
||||||
|
:align: center
|
||||||
|
:width: 50.0%
|
||||||
|
|
||||||
|
.. _lcd_menu:
|
||||||
|
|
||||||
|
Overview
|
||||||
|
--------
|
||||||
|
|
||||||
|
The integration implements the :ref:`Display Menu <display_menu>` integration providing
|
||||||
|
a hierarchical menu primarily intended to be controlled either by a rotary encoder
|
||||||
|
with a button or a five-button joystick controller.
|
||||||
|
|
||||||
|
The component needs to be connected to an instance of a character based LCD display, which
|
||||||
|
at the moment are :ref:`lcd-pcf8574` or a :ref:`lcd-gpio`. For the best results the GPIO
|
||||||
|
connection is recommended; the I²C one running at the speed according to the datasheet
|
||||||
|
(usually 100 kHz) or even ESPHome default (50 kHz) will create perceptible delays especially
|
||||||
|
when changing a numeric value using the rotary encoder. Most PCF8574 adapters used with
|
||||||
|
these displays will happily run at 200 or even 400 kHz though so if you are comfortable
|
||||||
|
accepting risks from running your hardware out of spec, you might want to try that
|
||||||
|
in your ``i2c`` configuration.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
display:
|
||||||
|
- platform: lcd_pcf8574
|
||||||
|
id: my_lcd
|
||||||
|
dimensions: 20x4
|
||||||
|
...
|
||||||
|
user_characters:
|
||||||
|
- position: 0
|
||||||
|
data:
|
||||||
|
- 0b00100
|
||||||
|
- 0b01110
|
||||||
|
- 0b10101
|
||||||
|
- 0b00100
|
||||||
|
- 0b00100
|
||||||
|
- 0b00100
|
||||||
|
- 0b11100
|
||||||
|
- 0b00000
|
||||||
|
lambda: |-
|
||||||
|
id(my_lcd_menu).draw();
|
||||||
|
if (!id(my_lcd_menu).is_active())
|
||||||
|
it.print("Menu is not active");
|
||||||
|
|
||||||
|
# Declare a LCD menu
|
||||||
|
lcd_menu:
|
||||||
|
id: my_lcd_menu
|
||||||
|
display_id: my_lcd
|
||||||
|
active: true
|
||||||
|
mode: rotary
|
||||||
|
mark_back: 0x08
|
||||||
|
mark_selected: 0x3e
|
||||||
|
mark_editing: 0x2a
|
||||||
|
mark_submenu: 0x7e
|
||||||
|
items:
|
||||||
|
...
|
||||||
|
|
||||||
|
# Encoder to provide navigation
|
||||||
|
sensor:
|
||||||
|
- platform: rotary_encoder
|
||||||
|
...
|
||||||
|
on_anticlockwise:
|
||||||
|
- display_menu.up:
|
||||||
|
on_clockwise:
|
||||||
|
- display_menu.down:
|
||||||
|
|
||||||
|
# A de-bounced GPIO is used to 'click'
|
||||||
|
binary_sensor:
|
||||||
|
- platform: gpio
|
||||||
|
...
|
||||||
|
filters:
|
||||||
|
- delayed_on: 10ms
|
||||||
|
- delayed_off: 10ms
|
||||||
|
on_press:
|
||||||
|
- display_menu.enter:
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Manually specify the ID used for code generation.
|
||||||
|
- **display_id** (*Optional*, :ref:`config-id`): Manually specify the ID of the LCD display.
|
||||||
|
- **mark_back**, **mark_selected**, **mark_editing**, **mark_submenu** (*Optional*, 0-255):
|
||||||
|
Code of the character used to mark menu items going back one level, a selected one,
|
||||||
|
the editing mode and item leading to a submenu. Defaults to ``0x5e`` (``^``), ``0x3e`` (``>``),
|
||||||
|
``0x2a`` (``*``) and ``0x7e`` (a right arrow). As the character set lacks a good looking
|
||||||
|
up arrow, using a user defined character is advisable (use ``8`` to reference one at
|
||||||
|
position ``0`` to avoid problems with zeros in a string).
|
||||||
|
|
||||||
|
The rest of the configuration is described in the :ref:`Display Menu <display_menu>` component.
|
||||||
|
The menu inherits the dimensions of the connected LCD display and uses the whole area.
|
||||||
|
|
||||||
|
See Also
|
||||||
|
--------
|
||||||
|
|
||||||
|
- :apiref:`lcd_menu/lcd_menu.h`
|
@ -27,8 +27,38 @@ Configuration variables:
|
|||||||
``esp32s2``, ``esp32s3``, ``esp32c3`` and ``esp32h2``. Defaults to the variant that is detected from the board, if
|
``esp32s2``, ``esp32s3``, ``esp32c3`` and ``esp32h2``. Defaults to the variant that is detected from the board, if
|
||||||
a board that's unknown to ESPHome is used, this option is mandatory.
|
a board that's unknown to ESPHome is used, this option is mandatory.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Support for the ESP32-S2 and ESP32-C3 is still in development and there could be issues.
|
||||||
|
|
||||||
.. _esp32-arduino_framework:
|
.. _esp32-arduino_framework:
|
||||||
|
|
||||||
|
GPIO Pin Numbering
|
||||||
|
------------------
|
||||||
|
|
||||||
|
The ESP32 boards often use the internal GPIO pin numbering on the board, this means that
|
||||||
|
you don't have to worry about other kinds of pin numberings, yay!
|
||||||
|
|
||||||
|
Some notes about the pins on the ESP32:
|
||||||
|
|
||||||
|
- ``GPIO0`` is used to determine the boot mode on startup. It should therefore not be pulled LOW
|
||||||
|
on startup to avoid booting into flash mode. You can, however, still use this as an output pin.
|
||||||
|
- ``GPIO34``-``GPIO39`` can not be used as outputs (even though GPIO stands for "general purpose input
|
||||||
|
**output**"...).
|
||||||
|
- ``GPIO32``-``GPIO39``: These pins can be used with the :doc:`/components/sensor/adc` to measure
|
||||||
|
voltages.
|
||||||
|
- ``GPIO2``: This pin is connected to the blue LED on the board. It also supports
|
||||||
|
the :doc:`touch pad binary sensor </components/binary_sensor/esp32_touch>` like some other
|
||||||
|
pins.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
binary_sensor:
|
||||||
|
- platform: gpio
|
||||||
|
name: "Pin GPIO23"
|
||||||
|
pin: GPIO23
|
||||||
|
|
||||||
Arduino framework
|
Arduino framework
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
@ -32,6 +32,18 @@ Advanced options:
|
|||||||
the BLE receiver doesn't use it. Defaults to ``10167``.
|
the BLE receiver doesn't use it. Defaults to ``10167``.
|
||||||
- **minor** (*Optional*, int): The iBeacon minor identifier of this beacon. Usually used to
|
- **minor** (*Optional*, int): The iBeacon minor identifier of this beacon. Usually used to
|
||||||
identify beacons within an iBeacon group. Defaults to ``61958``.
|
identify beacons within an iBeacon group. Defaults to ``61958``.
|
||||||
|
- **min_interval** (*Optional*, :ref:`config-time`): The iBeacon minimum transmit interval in milliseconds from 20 to 10240.
|
||||||
|
Setting this less than ``max_interval`` gives the BLE hardware a better chance to avoid
|
||||||
|
collisions with other BLE transmissions. Defaults to the iBeacon specification's defined interval: ``100ms``.
|
||||||
|
- **max_interval** (*Optional*, :ref:`config-time`): The iBeacon maximum transmit interval in milliseconds from 20 to 10240.
|
||||||
|
Setting this greater than ``min_interval`` gives the BLE hardware a better chance to avoid
|
||||||
|
collisions with other BLE transmissions. Defaults to the iBeacon specification's defined interval: ``100ms``.
|
||||||
|
- **measured_power** (*Optional*, int): The RSSI of the iBeacon as measured 1 meter from the device.
|
||||||
|
This is used to calibrate the ranging calculations in iOS. The procedure for setting this value can
|
||||||
|
be found in Apple's `Getting Started with iBeacon PDF <https://developer.apple.com/ibeacon/Getting-Started-with-iBeacon.pdf>`__
|
||||||
|
under the heading *Calibrating iBeacon*. Between -128 to 0. Defaults to ``-59``.
|
||||||
|
- **tx_power** (*Optional*, int): The transmit power of the iBeacon in dBm.
|
||||||
|
One of -12, -9, -6, -3, 0, 3, 6, 9. Defaults to ``3dBm``.
|
||||||
|
|
||||||
Setting Up
|
Setting Up
|
||||||
----------
|
----------
|
||||||
|
@ -39,6 +39,181 @@ Configuration variables:
|
|||||||
- **board_flash_mode** (*Optional*, string): The SPI mode of the flash chip. One of ``qio``, ``qout``, ``dio`` and ``dout``. Defaults to ``dout`` for compatibility with all chips. Note: on the next OTA update the actual flash mode is automatically detected and changed to the appropriate one.
|
- **board_flash_mode** (*Optional*, string): The SPI mode of the flash chip. One of ``qio``, ``qout``, ``dio`` and ``dout``. Defaults to ``dout`` for compatibility with all chips. Note: on the next OTA update the actual flash mode is automatically detected and changed to the appropriate one.
|
||||||
- **early_pin_init** (*Optional*, boolean): Specifies whether pins should be initialised as early as possible to known values. Recommended value is ``false`` where switches are involved, as these will toggle when updating the firmware or when restarting the device. Defaults to ``true``.
|
- **early_pin_init** (*Optional*, boolean): Specifies whether pins should be initialised as early as possible to known values. Recommended value is ``false`` where switches are involved, as these will toggle when updating the firmware or when restarting the device. Defaults to ``true``.
|
||||||
|
|
||||||
|
GPIO Pin Numbering
|
||||||
|
------------------
|
||||||
|
|
||||||
|
Many boards have a pin numbering for the exposed pins that is different from the internally used
|
||||||
|
ones. ESPHome tries to map the silk-screen pin numbers into the internal pin numbers with a few
|
||||||
|
boards, but for generic ESP8266 boards it is often required to just use the internal pin numbers.
|
||||||
|
To do this, just prefix all pins with ``GPIO``, for example ``GPIO0`` for the pin with the internal pin
|
||||||
|
number 0.
|
||||||
|
|
||||||
|
Some notes on the pins:
|
||||||
|
|
||||||
|
- ``GPIO6`` - ``GPIO11``, ``GPIO0``, ``GPIO2`` and ``GPIO15`` are often already used by the internal
|
||||||
|
flash interface and boot mode detection. So it's best to avoid using these pins.
|
||||||
|
- ``GPIO17`` additionally has an ADC connected to it. See the :doc:`/components/sensor/adc`
|
||||||
|
to read voltages (in the range from 0 to 1.0V) on this pin.
|
||||||
|
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
esphome:
|
||||||
|
name: livingroom
|
||||||
|
|
||||||
|
esp8266:
|
||||||
|
board: nodemcuv2
|
||||||
|
|
||||||
|
binary_sensor:
|
||||||
|
- platform: gpio
|
||||||
|
name: "Pin GPIO17"
|
||||||
|
pin: GPIO17
|
||||||
|
|
||||||
|
|
||||||
|
Special Pins
|
||||||
|
^^^^^^^^^^^^
|
||||||
|
|
||||||
|
=================== =============================================
|
||||||
|
``GPIO0`` Controls Boot Mode
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO1`` UART TX pin
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO2`` Controls Boot Mode
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO3`` UART RX pin
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO6`` SDIO/Flash CLK pin
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO7`` SDIO/Flash Data 0 pin
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO8`` SDIO/Flash Data 1 pin
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO9`` SDIO/Flash Data 2 pin (qio/qout only)
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO10`` SDIO/Flash Data 3 pin (qio/qout only)
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO11`` SDIO/Flash CMD pin
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO12`` Attached to Hardware SPI controller MISO
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO13`` Attached to Hardware SPI controller MOSI
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO14`` Attached to Hardware SPI controller CLK
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO15`` Controls Boot Mode; Attached to Hardware SPI
|
||||||
|
controller CS
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
``GPIO16`` Special pin that can be accessed from RTC,
|
||||||
|
and is Deep-Sleep wakeup pin
|
||||||
|
------------------- ---------------------------------------------
|
||||||
|
TOUT aka ``GPIO17`` ADC pin for measuring voltages, can only be
|
||||||
|
used as analog input pin
|
||||||
|
=================== =============================================
|
||||||
|
|
||||||
|
This means effectively only the following pins can be used as general purpose GPIO:
|
||||||
|
|
||||||
|
========== ============================== ==============================
|
||||||
|
**Pin** **Restrictions** **State after Reset**
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO0`` If HIGH on boot Weak Pull Up
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO2`` If HIGH on boot Weak Pull Up
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO4`` High Impedance
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO5`` High Impedance
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO6`` Weak Pull Up
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO12`` Weak Pull Up
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO13`` Weak Pull Up
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO14`` Weak Pull Up
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO15`` If LOW on boot Weak Pull Up
|
||||||
|
---------- ------------------------------ ------------------------------
|
||||||
|
``GPIO16`` Has pull-down (but no pull-up) Weak Pull Down
|
||||||
|
resistor
|
||||||
|
========== ============================== ==============================
|
||||||
|
|
||||||
|
|
||||||
|
Boot Modes
|
||||||
|
----------
|
||||||
|
|
||||||
|
On each boot, the ESP8266 will check three pins to determine in which boot mode to enter.
|
||||||
|
There are three boot modes:
|
||||||
|
|
||||||
|
========================= ========= ========= ========== ==============
|
||||||
|
**Mode** ``GPIO0`` ``GPIO2`` ``GPIO15`` ``boot mode:``
|
||||||
|
------------------------- --------- --------- ---------- --------------
|
||||||
|
Boot from Flash (normal) HIGH HIGH LOW 3
|
||||||
|
------------------------- --------- --------- ---------- --------------
|
||||||
|
Download Code from UART LOW HIGH LOW 1
|
||||||
|
------------------------- --------- --------- ---------- --------------
|
||||||
|
Boot from SD-Card ANY ANY HIGH 4-7
|
||||||
|
========================= ========= ========= ========== ==============
|
||||||
|
|
||||||
|
You can identify these on boot-up by looking at the UART output, the first number
|
||||||
|
in the ``boot mode:`` line tells you what mode was selected
|
||||||
|
|
||||||
|
.. code-block:: text
|
||||||
|
|
||||||
|
ets Jan 8 2013,rst cause:4, boot mode:(3,6)
|
||||||
|
|
||||||
|
The first lines when viewing the UART logs might have unrecognized characters. This is
|
||||||
|
because the effective baudrate of the ESP8266 bootloader is 74800, whereas the program uses 115200.
|
||||||
|
|
||||||
|
Reset Causes
|
||||||
|
------------
|
||||||
|
|
||||||
|
Additionally, the first line also contains the **reset cause**.
|
||||||
|
These reset causes `are documented
|
||||||
|
<https://www.espressif.com/sites/default/files/documentation/esp8266_reset_causes_and_common_fatal_exception_causes_en.pdf>`__:
|
||||||
|
|
||||||
|
== ===================================
|
||||||
|
0 Undefined
|
||||||
|
-- -----------------------------------
|
||||||
|
1 Power On Reboot
|
||||||
|
-- -----------------------------------
|
||||||
|
2 External reset or deep-sleep wakeup
|
||||||
|
-- -----------------------------------
|
||||||
|
4 Hardware WDT reset
|
||||||
|
== ===================================
|
||||||
|
|
||||||
|
After a software reset, the reset cause will not change.
|
||||||
|
|
||||||
|
Electrical Characteristics
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
=========================================================== =========== =========== =========== ===========
|
||||||
|
**Parameter** **Min.** **Typical** **Max.** **Unit**
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
Operating Temperature -40 125 °C
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
Working Voltage ``V_IO`` 2.5 3.3 3.6 V
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
``V_IL`` - INPUT voltage level to be considered LOW -0.3 0.25*V_IO V
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
``V_IH`` - INPUT voltage level to be considered HIGH 0.75*V_IO 3.6 V
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
``V_OL`` - OUTPUT voltage level for LOW 0.1*V_IO V
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
``V_OH`` - OUTPUT voltage level for HIGH 0.8*V_IO V
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
``I_MAX`` - Maximum current for GPIO 12 mA
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
Power Consumption in Deep Sleep 20 µA
|
||||||
|
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
||||||
|
Power Consumption in Active Mode 120 mA
|
||||||
|
=========================================================== =========== =========== =========== ===========
|
||||||
|
|
||||||
|
Source: `ESP8266EX datasheet <https://www.espressif.com/sites/default/files/documentation/0a-esp8266ex_datasheet_en.pdf>`__
|
||||||
|
|
||||||
|
The internal pull up/down resistors have values of 30kΩ to 100kΩ
|
||||||
|
(`source <https://bbs.espressif.com/viewtopic.php?t=1079>`__).
|
||||||
|
|
||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
|
||||||
|
@ -53,6 +53,8 @@ Advanced options:
|
|||||||
- **version** (**Required**, string): Version of the project
|
- **version** (**Required**, string): Version of the project
|
||||||
- **min_version** (*Optional*, string): The minimum ESPHome version required to compile this configuration.
|
- **min_version** (*Optional*, string): The minimum ESPHome version required to compile this configuration.
|
||||||
See :ref:`esphome-min_version`.
|
See :ref:`esphome-min_version`.
|
||||||
|
- **compile_process_limit** (*Optional*, int): The maximum number of simultaneous compile processes to run.
|
||||||
|
Defaults to the number of cores of the CPU which is also the maximum you can set.
|
||||||
|
|
||||||
Old-style platform options, which have been moved to the platform-specific :doc:`esp32 </components/esp32>` and
|
Old-style platform options, which have been moved to the platform-specific :doc:`esp32 </components/esp32>` and
|
||||||
:doc:`esp8266 </components/esp8266>` sections but are still accepted here for compatibility reasons (usage not
|
:doc:`esp8266 </components/esp8266>` sections but are still accepted here for compatibility reasons (usage not
|
||||||
|
571
components/ezo_pmp.rst
Normal file
@ -0,0 +1,571 @@
|
|||||||
|
Atlas Scientific Peristaltic Pump
|
||||||
|
=================================
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Instructions for setting up an Atlas Scientific Peristaltic Pump in ESPHome
|
||||||
|
:image: ezo-pmp.jpg
|
||||||
|
:keywords: pump, peristaltic, atlas, ezo
|
||||||
|
|
||||||
|
The ``ezo_pmp`` component allows you to use an Atlas Scientific Peristaltic Pump with ESPHome.
|
||||||
|
Both the EZO-PMP (`datasheet <https://files.atlas-scientific.com/EZO_PMP_Datasheet.pdf>`__)
|
||||||
|
and EZO-PMP-L (`datasheet <https://files.atlas-scientific.com/EZO_PMP_L_Datasheet.pdf>`__) are supported.
|
||||||
|
The :ref:`I²C Bus <i2c>` is required to be set up in your configuration for this sensor to work.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
This component will not be directly controllable in the Home Assistant front-end automatically because
|
||||||
|
Home Assistant doesn't have support for pumps. In order to control the pump from the frontend you will need to use
|
||||||
|
templates to offer access to the actions you need. Please see :ref:`ezo-pmp-ha-config`.
|
||||||
|
|
||||||
|
.. figure:: images/ezo-pmp.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 80.0%
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
ezo_pmp:
|
||||||
|
id: ezo_pmp
|
||||||
|
address: 103 # Default Address for the EZO-PMP.
|
||||||
|
update_interval: 60s
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): Specify the ID of the pump so that you can control it.
|
||||||
|
- **address** (*Optional*, int): Specify the I²C address of the sensor. Defaults to 103.
|
||||||
|
- **update_interval** (*Optional*, :ref:`config-time`): The interval to check the
|
||||||
|
sensor. Defaults to ``60s``.
|
||||||
|
|
||||||
|
Sensors
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Since the EZO-PMP offers a large number of sensors and each sensor needs to be polled individually, the code has been
|
||||||
|
optimized not to update a sensor that is not defined in the config. If you need very quick updates from the pump (under 3 seconds)
|
||||||
|
only enable the sensors that you actually need.
|
||||||
|
|
||||||
|
.. _ezo_pmp-current_volume_dosed_sensor:
|
||||||
|
|
||||||
|
``current_volume_dosed``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
This sensor indicates the volume (in milliliters) that has been dosed in the currently running or last ran dosing command.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
current_volume_dosed:
|
||||||
|
id: current_volume_dosed
|
||||||
|
name: Current Volume Dosed
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Sensor <config-sensor>`.
|
||||||
|
|
||||||
|
.. _ezo_pmp-total_volume_dosed_sensor:
|
||||||
|
|
||||||
|
``total_volume_dosed``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
This sensor indicates total volume (in milliliters) that has been dosed since the last time the pump was turned on. Could be a
|
||||||
|
negative number if the pump has been run in reverse.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
total_volume_dosed:
|
||||||
|
id: total_volume_dosed
|
||||||
|
name: Total Volume Dosed
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Sensor <config-sensor>`.
|
||||||
|
|
||||||
|
.. _ezo_pmp-absolute_total_volume_dosed_sensor:
|
||||||
|
|
||||||
|
``absolute_total_volume_dosed``
|
||||||
|
-------------------------------
|
||||||
|
|
||||||
|
This sensor indicates the absolute total volume (in milliliters) that has been dosed since the last time the pump was turned on.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
absolute_total_volume_dosed:
|
||||||
|
id: absolute_total_volume_dosed
|
||||||
|
name: Absolute Total Volume Dosed
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Sensor <config-sensor>`.
|
||||||
|
|
||||||
|
.. _ezo_pmp-last_volume_requested_sensor:
|
||||||
|
|
||||||
|
``last_volume_requested``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Indicates the total volume (in milliliters) that is being dosed (or was if the pump has already finished) by a dose Action. When
|
||||||
|
using dosing actions that have a duration, the sensor will have the right calculation for total volume.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
last_volume_requested:
|
||||||
|
id: last_volume_requested
|
||||||
|
name: Last Volume Requested
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Sensor <config-sensor>`.
|
||||||
|
|
||||||
|
.. _ezo_pmp-max_flow_rate_sensor:
|
||||||
|
|
||||||
|
``max_flow_rate``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
The pump provides its own calculation of the maximum flow rate it can provide (in ml/minute). Dosing requests that exceed this rate
|
||||||
|
will fail. When using the :ref:`Dose Continuously <ezo_pmp-dose_continuously_action>` Action, this is the volume the pump will
|
||||||
|
dose every minute. This value will get updated after the pump is calibrated (see :ref:`ezo_pmp-set_calibration_volume_action`).
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
max_flow_rate:
|
||||||
|
id: max_flow_rate
|
||||||
|
name: Max Flow Rate
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Sensor <config-sensor>`.
|
||||||
|
|
||||||
|
.. _ezo_pmp-pump_voltage_sensor:
|
||||||
|
|
||||||
|
``pump_voltage``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
The current voltage of the power supply that powers the pump. Not to be confused with the voltage that powers the electronics on the pump.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
pump_voltage:
|
||||||
|
id: pump_voltage
|
||||||
|
name: Pump Voltage
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Sensor <config-sensor>`.
|
||||||
|
|
||||||
|
Binary Sensors
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
.. _ezo_pmp-pump_state_binary_sensor:
|
||||||
|
|
||||||
|
``pump_state``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Indicates if the pump is currently running or not.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
binary_sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
pump_state:
|
||||||
|
id: pump_state
|
||||||
|
name: Pump State
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Binary Sensor <config-binary_sensor>`.
|
||||||
|
|
||||||
|
.. _ezo_pmp-is_paused_binary_sensor:
|
||||||
|
|
||||||
|
``is_paused``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Indicates if a dosing action is currently paused.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
binary_sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
is_paused:
|
||||||
|
id: is_paused
|
||||||
|
name: Is Paused
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Binary Sensor <config-binary_sensor>`.
|
||||||
|
|
||||||
|
|
||||||
|
Text Sensors
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
.. _ezo_pmp-dosing_mode_text_sensor:
|
||||||
|
|
||||||
|
``dosing_mode``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Indicates the dosing mode the pump is currently running as. Can be any of `Volume`, `Volume/Time`, `Constant Flow Rate`, `Continuous`, `None`.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
text_sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
dosing_mode:
|
||||||
|
id: dosing_mode
|
||||||
|
name: Dosing Mode
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Text Sensor <config-text_sensor>`.
|
||||||
|
|
||||||
|
.. _ezo_pmp-calibration_status_text_sensor:
|
||||||
|
|
||||||
|
``calibration_status``
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Indicates calibration status of the pump. Can be any of `Fixed Volume`, `Volume/Time`, `Fixed Volume & Volume/Time` or `Uncalibrated`.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
text_sensor:
|
||||||
|
- platform: ezo_pmp
|
||||||
|
calibration_status:
|
||||||
|
id: calibration_status
|
||||||
|
name: Calibration Status
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
|
- All other options from :ref:`Text Sensor <config-text_sensor>`.
|
||||||
|
|
||||||
|
Actions
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
.. _ezo_pmp-dose_continuously_action:
|
||||||
|
|
||||||
|
``ezo_pmp.dose_continuously`` Action
|
||||||
|
------------------------------------
|
||||||
|
|
||||||
|
Use this action in an :ref:`automations <automation>` to have the peristaltic pump dose continuously
|
||||||
|
at the :ref:`Maximum Flow Rate <ezo_pmp-max_flow_rate_sensor>`. The pump will automatically stop after 20 days
|
||||||
|
of running in continuous mode.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.find:
|
||||||
|
id: ezo_pmp
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
|
||||||
|
|
||||||
|
.. _ezo_pmp-dose_volume_action:
|
||||||
|
|
||||||
|
``ezo_pmp.dose_volume`` Action
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
Use this action in an :ref:`automations <automation>` to have the peristaltic pump dose an specific volume (in milliliters)
|
||||||
|
at the :ref:`Maximum Flow Rate <ezo_pmp-max_flow_rate_sensor>`. If the volume is negative the pump will run backwards.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.dose_volume:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume: 10
|
||||||
|
|
||||||
|
# Templated
|
||||||
|
- ezo_pmp.dose_volume:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume: !lambda |-
|
||||||
|
return id(some_volume_sensor).state;
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
- **volume** (**Required**, float, :ref:`templatable <config-templatable>`): The volume to dose in milliliters. If negative, pump will run in reverse.
|
||||||
|
|
||||||
|
.. _ezo_pmp-dose_volume_over_time_action:
|
||||||
|
|
||||||
|
``ezo_pmp.dose_volume_over_time`` Action
|
||||||
|
----------------------------------------
|
||||||
|
|
||||||
|
Use this action in an :ref:`automations <automation>` to have the peristaltic pump dose an specific `volume` (in milliliters)
|
||||||
|
over the provided `duration` (in minutes). At the end of the time period the pump will have dosed the specified `volume`.
|
||||||
|
If the volume is negative the pump will run backwards.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.dose_volume_over_time:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume: 23.4
|
||||||
|
duration: 2
|
||||||
|
|
||||||
|
# Templated
|
||||||
|
- ezo_pmp.dose_volume_over_time:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume: !lambda |-
|
||||||
|
return id(some_volume_sensor).state;
|
||||||
|
duration: !lambda |-
|
||||||
|
return id(some_duration_sensor).state;
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
- **volume** (**Required**, float, :ref:`templatable <config-templatable>`): The volume to dose in milliliters. If negative, pump will run in reverse.
|
||||||
|
- **duration** (**Required**, int, :ref:`templatable <config-templatable>`): The time (in minutes) the pump will take to dose the volume requested.
|
||||||
|
|
||||||
|
|
||||||
|
.. _ezo_pmp-dose_with_constant_flow_rate_action:
|
||||||
|
|
||||||
|
``ezo_pmp.dose_with_constant_flow_rate`` Action
|
||||||
|
-----------------------------------------------
|
||||||
|
|
||||||
|
Use this action in an :ref:`automations <automation>` to have the peristaltic pump dose an specific `volume` (in milliliters) every minute
|
||||||
|
for the provided `duration` (in minutes). At the end of the time period the pump will have dosed the specified `volume` times the `duration`.
|
||||||
|
If the volume is negative the pump will run backwards.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.dose_with_constant_flow_rate:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume_per_minute: 10.2
|
||||||
|
duration: 2
|
||||||
|
|
||||||
|
# Templated
|
||||||
|
- ezo_pmp.dose_with_constant_flow_rate:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume_per_minute: !lambda |-
|
||||||
|
return id(some_volume_sensor).state;
|
||||||
|
duration: !lambda |-
|
||||||
|
return id(some_duration_sensor).state;
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
- **volume_per_minute** (**Required**, float, :ref:`templatable <config-templatable>`): The volume to dose in milliliters every minute. If negative, pump will run in reverse.
|
||||||
|
- **duration** (**Required**, int, :ref:`templatable <config-templatable>`): The time (in minutes) the pump will dose the volume requested every minute.
|
||||||
|
|
||||||
|
.. _ezo_pmp-pause_dosing_action:
|
||||||
|
|
||||||
|
``ezo_pmp.pause_dosing`` Action
|
||||||
|
-------------------------------
|
||||||
|
|
||||||
|
Use this action to pause a Dosing command that was previously issued. To determine if the dosing is paused or not, you can use the :ref:`Is Paused <ezo_pmp-is_paused_binary_sensor>` sensor.
|
||||||
|
If the pump is currently paused, issuing this action again will unpause it.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.pause_dosing:
|
||||||
|
id: ezo_pmp
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
|
||||||
|
.. _ezo_pmp-stop_dosing_action:
|
||||||
|
|
||||||
|
``ezo_pmp.stop_dosing`` Action
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
Use this action to stop the current Dosing command.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.stop_dosing:
|
||||||
|
id: ezo_pmp
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
|
||||||
|
.. _ezo_pmp-clear_total_volume_dosed_action:
|
||||||
|
|
||||||
|
``ezo_pmp.clear_total_volume_dosed`` Action
|
||||||
|
-------------------------------------------
|
||||||
|
|
||||||
|
Clear the values of the :ref:`Current Volume Dosed <ezo_pmp-current_volume_dosed_sensor>`, :ref:`Total Volume Dosed <ezo_pmp-total_volume_dosed_sensor>`
|
||||||
|
and :ref:`Absolute Total Volume Dosed <ezo_pmp-absolute_total_volume_dosed_sensor>` sensors.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.clear_total_volume_dosed:
|
||||||
|
id: ezo_pmp
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
|
||||||
|
.. _ezo_pmp-set_calibration_volume_action:
|
||||||
|
|
||||||
|
``ezo_pmp.set_calibration_volume`` Action
|
||||||
|
-----------------------------------------
|
||||||
|
|
||||||
|
Use this action to calibrate the peristaltic pump. The EZO-PMP needs two forms of calibration: absolute volume and volume over time. You can check
|
||||||
|
the calibration status by using the :ref:`Calibration Status<ezo_pmp-calibration_status_text_sensor>` sensor. For the procedure on calibrating the pump
|
||||||
|
check the datasheet.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.set_calibration_volume:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume: 10.01
|
||||||
|
|
||||||
|
# Templated
|
||||||
|
- ezo_pmp.set_calibration_volume:
|
||||||
|
id: ezo_pmp
|
||||||
|
volume: !lambda |-
|
||||||
|
return id(some_volume_sensor).state;
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
- **volume** (**Required**, float, :ref:`templatable <config-templatable>`): The volume measured as part of the calibration process.
|
||||||
|
|
||||||
|
|
||||||
|
.. _ezo_pmp-clear_calibration_action:
|
||||||
|
|
||||||
|
``ezo_pmp.clear_calibration`` Action
|
||||||
|
------------------------------------
|
||||||
|
|
||||||
|
Clear the calibration values stored in the pump. You can check the calibration status by using the
|
||||||
|
:ref:`Calibration Status<ezo_pmp-calibration_status_text_sensor>` sensor.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.clear_calibration:
|
||||||
|
id: ezo_pmp
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
|
||||||
|
.. _ezo_pmp-find_action:
|
||||||
|
|
||||||
|
``ezo_pmp.find`` Action
|
||||||
|
-----------------------
|
||||||
|
|
||||||
|
Use this action to make the LED on the Pump control board to blink for a minute. The pump will not respond to any other action while the LED is blinking.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.find:
|
||||||
|
id: ezo_pmp
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
|
||||||
|
.. _ezo_pmp-change_i2c_address_action:
|
||||||
|
|
||||||
|
``ezo_pmp.change_i2c_address`` Action
|
||||||
|
-------------------------------------------
|
||||||
|
|
||||||
|
Changes the i2c address of the pump to the provided value. After the address is changed you must upload a new version of the ESPHome firmware with the updated I2C
|
||||||
|
address for the pump to work.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
on_...:
|
||||||
|
then:
|
||||||
|
- ezo_pmp.change_i2c_address:
|
||||||
|
id: ezo_pmp
|
||||||
|
address: 100
|
||||||
|
|
||||||
|
Configuration options:
|
||||||
|
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The ID of the pump.
|
||||||
|
- **address** (**Required**, int, :ref:`templatable <config-templatable>`): The new I2C address for the pump.
|
||||||
|
|
||||||
|
.. _ezo-pmp-ha-config:
|
||||||
|
|
||||||
|
Home Assistant Configuration
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
In order to provide control of the pump from the home assistant frontend it is important to expose the actions
|
||||||
|
as components that have UI rendering. This could be done using templates in ESPHome. Here is an example using a
|
||||||
|
`Template Button` and `Template Number` to dose a certain volume over time.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
i2c:
|
||||||
|
|
||||||
|
ezo_pmp:
|
||||||
|
id: ezo_pmp
|
||||||
|
|
||||||
|
number:
|
||||||
|
- platform: template
|
||||||
|
id: volume
|
||||||
|
name: "Volume"
|
||||||
|
optimistic: true
|
||||||
|
min_value: 0
|
||||||
|
max_value: 100
|
||||||
|
step: 0.01
|
||||||
|
- platform: template
|
||||||
|
id: duration
|
||||||
|
name: "Duration"
|
||||||
|
optimistic: true
|
||||||
|
min_value: 0
|
||||||
|
max_value: 100
|
||||||
|
step: 1
|
||||||
|
|
||||||
|
button:
|
||||||
|
- platform: template
|
||||||
|
name: "Dose Over Time"
|
||||||
|
on_press:
|
||||||
|
- ezo_pmp.dose_volume_over_time:
|
||||||
|
id: ezo_pump
|
||||||
|
volume: !lambda |-
|
||||||
|
return id(volume).state;
|
||||||
|
duration: !lambda |-
|
||||||
|
return id(duration).state;
|
||||||
|
|
||||||
|
.. _ezo_pmp-lambda_calls:
|
||||||
|
|
||||||
|
lambda calls
|
||||||
|
------------
|
||||||
|
|
||||||
|
From :ref:`lambdas <config-lambda>`, you can also access the actions on the peristaltic pump to do some
|
||||||
|
advanced stuff (see the full API Reference for more info). The name of the functions is the same as the name
|
||||||
|
of the actions in YAML config.
|
||||||
|
|
||||||
|
See Also
|
||||||
|
--------
|
||||||
|
|
||||||
|
- :apiref:`ezo_pmp/ezo_pmp.h`
|
||||||
|
- :ghedit:`Edit`
|
BIN
components/images/ezo-pmp.jpg
Normal file
After Width: | Height: | Size: 8.2 KiB |
@ -20,5 +20,6 @@ Components
|
|||||||
stepper/index
|
stepper/index
|
||||||
touchscreen/index
|
touchscreen/index
|
||||||
lock/index
|
lock/index
|
||||||
|
display_menu/index
|
||||||
media_player/index
|
media_player/index
|
||||||
*
|
*
|
||||||
|
@ -34,8 +34,12 @@ Configuration variables:
|
|||||||
- **safe_mode** (*Optional*, boolean): Whether to enable safe mode.
|
- **safe_mode** (*Optional*, boolean): Whether to enable safe mode.
|
||||||
Defaults to ``true``.
|
Defaults to ``true``.
|
||||||
- **password** (*Optional*, string): The password to use for updates.
|
- **password** (*Optional*, string): The password to use for updates.
|
||||||
- **port** (*Optional*, int): The port to use for OTA updates. Defaults
|
- **port** (*Optional*, int): The port to use for OTA updates.
|
||||||
to ``3232`` for the ESP32 and ``8266`` for the ESP8266.
|
Defaults:
|
||||||
|
|
||||||
|
- ``3232`` for the ESP32
|
||||||
|
- ``8266`` for the ESP8266
|
||||||
|
- ``2040`` for the RP2040
|
||||||
- **id** (*Optional*, :ref:`config-id`): Manually specify the ID used for code generation.
|
- **id** (*Optional*, :ref:`config-id`): Manually specify the ID used for code generation.
|
||||||
- **reboot_timeout** (*Optional*, :ref:`config-time`): The amount of time to wait before rebooting when in
|
- **reboot_timeout** (*Optional*, :ref:`config-time`): The amount of time to wait before rebooting when in
|
||||||
safe mode. Defaults to ``5min``.
|
safe mode. Defaults to ``5min``.
|
||||||
|
30
components/rp2040.rst
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
RP2040 Platform
|
||||||
|
===============
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Configuration for the RP2040 platform for ESPHome.
|
||||||
|
:image: rp2040.svg
|
||||||
|
|
||||||
|
This component contains platform-specific options for the RP2040 platform.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Support for all aspects of ESPHome on the RP2040 is still in development.
|
||||||
|
Please search for or create an `issue <https://github.com/esphome/issues/issues/new?assignees=&labels=&template=bug_report.yml>`__ if you encounter an unknown problem.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
rp2040:
|
||||||
|
board: rpipicow
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
- **board** (*Optional*, string): The board type. Valid options are ``rpipico`` and ``rpipicow``.
|
||||||
|
|
||||||
|
See Also
|
||||||
|
--------
|
||||||
|
|
||||||
|
- :doc:`esphome`
|
||||||
|
- :ghedit:`Edit`
|
66
components/sensor/adc128s102.rst
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
ADC128S102 8-Channel 12-Bit A/D Converter
|
||||||
|
==========================================
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Instructions for setting up ADC128S102 12 Bit Analog to Digital Converter in ESPHome.
|
||||||
|
:keywords: ADC128S102
|
||||||
|
:image: adc128s102.png
|
||||||
|
|
||||||
|
The ADC128S102 is a low-power, eight-channel CMOS 12-bit analog-to-digital converter specified for conversion
|
||||||
|
throughput rates of 500 ksps to 1 MSPS. The converter is based on a successive-approximation register architecture
|
||||||
|
with an internal track-and-hold circuit.
|
||||||
|
|
||||||
|
.. figure:: images/adc128s102.png
|
||||||
|
:align: center
|
||||||
|
:width: 50.0%
|
||||||
|
|
||||||
|
.. _adc128s102-component:
|
||||||
|
|
||||||
|
Component/Hub
|
||||||
|
-------------
|
||||||
|
|
||||||
|
The ADC128S102 component allows you to use ADC128S102 8-Channel 12-Bit A/D Converter
|
||||||
|
(`datasheet <https://www.ti.com/lit/ds/symlink/adc128s102.pdf>`__,
|
||||||
|
`Texas Instruments <https://www.ti.com/product/ADC128S102>`__) in ESPHome.
|
||||||
|
It uses the :ref:`SPI Bus <spi>` for communication.
|
||||||
|
|
||||||
|
Once configured, you can use any of the 8 pins as
|
||||||
|
sensors for your projects.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
adc128s102:
|
||||||
|
cs_pin: GPIO15
|
||||||
|
id: my_adc
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: adc128s102 # Attached to pin 0 of the ADC128S102.
|
||||||
|
update_interval: 1s
|
||||||
|
adc128s102_id: my_adc
|
||||||
|
id: freezer_temp_source
|
||||||
|
channel: 0 # ADC128S102 channel
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
- **id** (**Required**, :ref:`config-id`): The id to use for this ADC128S102 component.
|
||||||
|
- **cs_pin** (**Required**, int): The SPI cable select pin to use
|
||||||
|
|
||||||
|
Sensor
|
||||||
|
------
|
||||||
|
|
||||||
|
The ``adc128s102`` sensor allows you to use your ADC128S102 12-Bit A/D Converter sensors with ESPHome.
|
||||||
|
First, setup a :ref:`ADC128S102 Hub <adc128s102-component>` for your ADC128S102 sensor and then use this
|
||||||
|
sensor platform to create individual sensors that will report the voltage to Home Assistant.
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
|
||||||
|
- **adc128s102_id** (**Required**, :ref:`config-id`): The id of the parent ADC128S102 component.
|
||||||
|
- **channel** (**Required**, int): The channel of the ADC128S102 to use.
|
||||||
|
- **update_interval** (*Optional*, :ref:`config-time`): The interval to check the sensor. Defaults to ``60s``.
|
||||||
|
|
||||||
|
See Also
|
||||||
|
--------
|
||||||
|
|
||||||
|
- :ref:`spi`
|
||||||
|
- :apiref:`adc128s102/adc128s102.h`
|
||||||
|
- :ghedit:`Edit`
|
@ -50,6 +50,6 @@ See Also
|
|||||||
|
|
||||||
- :ref:`sensor-filters`
|
- :ref:`sensor-filters`
|
||||||
- :doc:`adc`
|
- :doc:`adc`
|
||||||
- :doc:`/devices/esp32`
|
- :doc:`/components/esp32`
|
||||||
- :apiref:`esp32_hall/esp32_hall.h`
|
- :apiref:`esp32_hall/esp32_hall.h`
|
||||||
- :ghedit:`Edit`
|
- :ghedit:`Edit`
|
||||||
|
BIN
components/sensor/images/adc128s102.png
Normal file
After Width: | Height: | Size: 116 KiB |
@ -23,44 +23,6 @@ Configuration variables:
|
|||||||
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
- **id** (*Optional*, :ref:`config-id`): Set the ID of this sensor for use in lambdas.
|
||||||
- All other options from :ref:`Sensor <config-sensor>`.
|
- All other options from :ref:`Sensor <config-sensor>`.
|
||||||
|
|
||||||
Human readable sensor
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
The sensor reports uptime in seconds which is good for automations
|
|
||||||
but is hard to read for humans, this example creates a text sensor
|
|
||||||
with human readable output.
|
|
||||||
|
|
||||||
.. code-block:: yaml
|
|
||||||
|
|
||||||
# Example configuration entry
|
|
||||||
text_sensor:
|
|
||||||
- platform: template
|
|
||||||
name: Uptime Human Readable
|
|
||||||
id: uptime_human
|
|
||||||
icon: mdi:clock-start
|
|
||||||
sensor:
|
|
||||||
- platform: uptime
|
|
||||||
name: Uptime Sensor
|
|
||||||
id: uptime_sensor
|
|
||||||
update_interval: 60s
|
|
||||||
on_raw_value:
|
|
||||||
then:
|
|
||||||
- text_sensor.template.publish:
|
|
||||||
id: uptime_human
|
|
||||||
state: !lambda |-
|
|
||||||
int seconds = round(id(uptime_sensor).raw_state);
|
|
||||||
int days = seconds / (24 * 3600);
|
|
||||||
seconds = seconds % (24 * 3600);
|
|
||||||
int hours = seconds / 3600;
|
|
||||||
seconds = seconds % 3600;
|
|
||||||
int minutes = seconds / 60;
|
|
||||||
seconds = seconds % 60;
|
|
||||||
return (
|
|
||||||
(days ? to_string(days) + "d " : "") +
|
|
||||||
(hours ? to_string(hours) + "h " : "") +
|
|
||||||
(minutes ? to_string(minutes) + "m " : "") +
|
|
||||||
(to_string(seconds) + "s")
|
|
||||||
).c_str();
|
|
||||||
|
|
||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
30
components/text_sensor/ethernet_info.rst
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
Ethernet Info Text Sensor
|
||||||
|
=========================
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Instructions for setting up Ethernet info text sensors.
|
||||||
|
:image: ethernet.svg
|
||||||
|
|
||||||
|
The ``ethernet_info`` text sensor platform exposes different Ethernet information
|
||||||
|
via text sensors.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
text_sensor:
|
||||||
|
- platform: ethernet_info
|
||||||
|
ip_address:
|
||||||
|
name: ESP IP Address
|
||||||
|
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
- **ip_address** (*Optional*): Expose the IP Address of the ESP as a text sensor. All options from
|
||||||
|
:ref:`Text Sensor <config-text_sensor>`.
|
||||||
|
|
||||||
|
See Also
|
||||||
|
--------
|
||||||
|
|
||||||
|
- :apiref:`ethernet_info/ethernet_info_text_sensor.h`
|
||||||
|
- :ghedit:`Edit`
|
32
components/text_sensor/wl_134.rst
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
WL-134 Pet Tag Sensor
|
||||||
|
=====================
|
||||||
|
|
||||||
|
.. seo::
|
||||||
|
:description: Instructions for setting up WL-134 text sensors.
|
||||||
|
:image: fingerprint.svg
|
||||||
|
|
||||||
|
The ``wl_134`` text sensor platform exposes the last read pet tag as text sensor.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
# Example configuration entry
|
||||||
|
uart:
|
||||||
|
rx_pin: GPIO17
|
||||||
|
baud_rate: 9600
|
||||||
|
|
||||||
|
text_sensor:
|
||||||
|
- platform: wl_134
|
||||||
|
name: Transponder Code
|
||||||
|
reset: true
|
||||||
|
|
||||||
|
Configuration variables:
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
- **reset** (*Optional*, boolean): Reset the text sensor state back to "" 1s after reading a tag. Defaults to ``false``.
|
||||||
|
- All options from :ref:`Text Sensor <config-text_sensor>`.
|
||||||
|
|
||||||
|
See Also
|
||||||
|
--------
|
||||||
|
|
||||||
|
- :apiref:`wl_134/wl_134.h`
|
||||||
|
- :ghedit:`Edit`
|
@ -110,8 +110,10 @@ Force to turn off OTA function because the missing authentication.
|
|||||||
# Example configuration entry V1
|
# Example configuration entry V1
|
||||||
web_server:
|
web_server:
|
||||||
port: 80
|
port: 80
|
||||||
|
version: 1
|
||||||
ota: false
|
ota: false
|
||||||
css_include: "../../../esphome-docs/_static/webserver-v1.min.css"
|
css_include: "../../../esphome-docs/_static/webserver-v1.min.css"
|
||||||
|
css_url: ""
|
||||||
js_include: "../../../esphome-docs/_static/webserver-v1.min.js"
|
js_include: "../../../esphome-docs/_static/webserver-v1.min.js"
|
||||||
js_url: ""
|
js_url: ""
|
||||||
|
|
||||||
|
6
conf.py
@ -40,7 +40,7 @@ extensions = [
|
|||||||
"github",
|
"github",
|
||||||
"seo",
|
"seo",
|
||||||
"components",
|
"components",
|
||||||
"sitemap"
|
"sitemap",
|
||||||
]
|
]
|
||||||
|
|
||||||
# Add any paths that contain templates here, relative to this directory.
|
# Add any paths that contain templates here, relative to this directory.
|
||||||
@ -67,9 +67,9 @@ author = "ESPHome"
|
|||||||
# built documents.
|
# built documents.
|
||||||
#
|
#
|
||||||
# The short X.Y version.
|
# The short X.Y version.
|
||||||
version = "2022.10"
|
version = "2022.11"
|
||||||
# The full version, including alpha/beta/rc tags.
|
# The full version, including alpha/beta/rc tags.
|
||||||
release = "2022.10.2"
|
release = "2022.11.0b1"
|
||||||
|
|
||||||
# The language for content autogenerated by Sphinx. Refer to documentation
|
# The language for content autogenerated by Sphinx. Refer to documentation
|
||||||
# for a list of supported languages.
|
# for a list of supported languages.
|
||||||
|
@ -1,60 +0,0 @@
|
|||||||
Generic ESP32
|
|
||||||
=============
|
|
||||||
|
|
||||||
.. seo::
|
|
||||||
:description: Information about how to use generic ESP32 boards in ESPHome.
|
|
||||||
:image: esp32.svg
|
|
||||||
:keywords: ESP32
|
|
||||||
|
|
||||||
All devices based on the original ESP32 are supported by ESPHome. Simply select ``ESP32`` when
|
|
||||||
the ESPHome wizard asks you for your platform and choose a board type
|
|
||||||
from `this link <https://registry.platformio.org/platforms/platformio/espressif32/boards>`__ when the wizard
|
|
||||||
asks you for the board type.
|
|
||||||
|
|
||||||
.. code-block:: yaml
|
|
||||||
|
|
||||||
# Example configuration entry
|
|
||||||
esphome:
|
|
||||||
name: livingroom
|
|
||||||
|
|
||||||
esp32:
|
|
||||||
board: <BOARD_TYPE>
|
|
||||||
|
|
||||||
.. note::
|
|
||||||
|
|
||||||
Support for the ESP32-S2 and ESP32-C3 is currently in development.
|
|
||||||
|
|
||||||
The ESP32 boards often use the internal GPIO pin numbering on the board, this means that
|
|
||||||
you don't have to worry about other kinds of pin numberings, yay!
|
|
||||||
|
|
||||||
Some notes about the pins on the ESP32:
|
|
||||||
|
|
||||||
- ``GPIO0`` is used to determine the boot mode on startup. It should therefore not be pulled LOW
|
|
||||||
on startup to avoid booting into flash mode. You can, however, still use this as an output pin.
|
|
||||||
- ``GPIO34``-``GPIO39`` can not be used as outputs (even though GPIO stands for "general purpose input
|
|
||||||
**output**"...).
|
|
||||||
- ``GPIO32``-``GPIO39``: These pins can be used with the :doc:`/components/sensor/adc` to measure
|
|
||||||
voltages.
|
|
||||||
- ``GPIO2``: This pin is connected to the blue LED on the board. It also supports
|
|
||||||
the :doc:`touch pad binary sensor </components/binary_sensor/esp32_touch>` like some other
|
|
||||||
pins.
|
|
||||||
|
|
||||||
.. code-block:: yaml
|
|
||||||
|
|
||||||
# Example configuration entry
|
|
||||||
esphome:
|
|
||||||
name: livingroom
|
|
||||||
|
|
||||||
esp32:
|
|
||||||
board: <BOARD_TYPE>
|
|
||||||
|
|
||||||
binary_sensor:
|
|
||||||
- platform: gpio
|
|
||||||
name: "Pin GPIO23"
|
|
||||||
pin: GPIO23
|
|
||||||
|
|
||||||
See Also
|
|
||||||
--------
|
|
||||||
|
|
||||||
- :doc:`nodemcu_esp32`
|
|
||||||
- :ghedit:`Edit`
|
|
@ -1,199 +0,0 @@
|
|||||||
Generic ESP8266
|
|
||||||
===============
|
|
||||||
|
|
||||||
.. seo::
|
|
||||||
:description: Instructions for using generic ESP8266s with ESPHome.
|
|
||||||
:image: esp8266.svg
|
|
||||||
:keywords: ESP8266
|
|
||||||
|
|
||||||
All ESP8266-based devices are supported by ESPHome. Simply select ``ESP8266`` when
|
|
||||||
the ESPHome wizard asks you for your platform and choose a board type
|
|
||||||
from `this link <https://registry.platformio.org/platforms/platformio/espressif8266/boards>`__ when the wizard
|
|
||||||
asks you for the board type.
|
|
||||||
|
|
||||||
|
|
||||||
.. code-block:: yaml
|
|
||||||
|
|
||||||
# Example configuration entry
|
|
||||||
esphome:
|
|
||||||
name: livingroom
|
|
||||||
|
|
||||||
esp8266:
|
|
||||||
board: <BOARD_TYPE>
|
|
||||||
|
|
||||||
Many boards have a pin numbering for the exposed pins that is different from the internally used
|
|
||||||
ones. ESPHome tries to map the silk-screen pin numbers into the internal pin numbers with a few
|
|
||||||
boards, but for generic ESP8266 boards it is often required to just use the internal pin numbers.
|
|
||||||
To do this, just prefix all pins with ``GPIO``, for example ``GPIO0`` for the pin with the internal pin
|
|
||||||
number 0.
|
|
||||||
|
|
||||||
Some notes on the pins:
|
|
||||||
|
|
||||||
- ``GPIO6`` - ``GPIO11``, ``GPIO0``, ``GPIO2`` and ``GPIO15`` are often already used by the internal
|
|
||||||
flash interface and boot mode detection. So it's best to avoid using these pins.
|
|
||||||
- ``GPIO17`` additionally has an ADC connected to it. See the :doc:`/components/sensor/adc`
|
|
||||||
to read voltages (in the range from 0 to 1.0V) on this pin.
|
|
||||||
|
|
||||||
|
|
||||||
.. code-block:: yaml
|
|
||||||
|
|
||||||
# Example configuration entry
|
|
||||||
esphome:
|
|
||||||
name: livingroom
|
|
||||||
|
|
||||||
esp8266:
|
|
||||||
board: nodemcuv2
|
|
||||||
|
|
||||||
binary_sensor:
|
|
||||||
- platform: gpio
|
|
||||||
name: "Pin GPIO17"
|
|
||||||
pin: GPIO17
|
|
||||||
|
|
||||||
|
|
||||||
Special Pins
|
|
||||||
------------
|
|
||||||
|
|
||||||
=================== =============================================
|
|
||||||
``GPIO0`` Controls Boot Mode
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO1`` UART TX pin
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO2`` Controls Boot Mode
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO3`` UART RX pin
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO6`` SDIO/Flash CLK pin
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO7`` SDIO/Flash Data 0 pin
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO8`` SDIO/Flash Data 1 pin
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO9`` SDIO/Flash Data 2 pin (qio/qout only)
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO10`` SDIO/Flash Data 3 pin (qio/qout only)
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO11`` SDIO/Flash CMD pin
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO12`` Attached to Hardware SPI controller MISO
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO13`` Attached to Hardware SPI controller MOSI
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO14`` Attached to Hardware SPI controller CLK
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO15`` Controls Boot Mode; Attached to Hardware SPI
|
|
||||||
controller CS
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
``GPIO16`` Special pin that can be accessed from RTC,
|
|
||||||
and is Deep-Sleep wakeup pin
|
|
||||||
------------------- ---------------------------------------------
|
|
||||||
TOUT aka ``GPIO17`` ADC pin for measuring voltages, can only be
|
|
||||||
used as analog input pin
|
|
||||||
=================== =============================================
|
|
||||||
|
|
||||||
This means effectively only the following pins can be used as general purpose GPIO:
|
|
||||||
|
|
||||||
========== ============================== ==============================
|
|
||||||
**Pin** **Restrictions** **State after Reset**
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO0`` If HIGH on boot Weak Pull Up
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO2`` If HIGH on boot Weak Pull Up
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO4`` High Impedance
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO5`` High Impedance
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO6`` Weak Pull Up
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO12`` Weak Pull Up
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO13`` Weak Pull Up
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO14`` Weak Pull Up
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO15`` If LOW on boot Weak Pull Up
|
|
||||||
---------- ------------------------------ ------------------------------
|
|
||||||
``GPIO16`` Has pull-down (but no pull-up) Weak Pull Down
|
|
||||||
resistor
|
|
||||||
========== ============================== ==============================
|
|
||||||
|
|
||||||
Boot Modes
|
|
||||||
----------
|
|
||||||
|
|
||||||
On each boot, the ESP8266 will check three pins to determine in which boot mode to enter.
|
|
||||||
There are three boot modes:
|
|
||||||
|
|
||||||
========================= ========= ========= ========== ==============
|
|
||||||
**Mode** ``GPIO0`` ``GPIO2`` ``GPIO15`` ``boot mode:``
|
|
||||||
------------------------- --------- --------- ---------- --------------
|
|
||||||
Boot from Flash (normal) HIGH HIGH LOW 3
|
|
||||||
------------------------- --------- --------- ---------- --------------
|
|
||||||
Download Code from UART LOW HIGH LOW 1
|
|
||||||
------------------------- --------- --------- ---------- --------------
|
|
||||||
Boot from SD-Card ANY ANY HIGH 4-7
|
|
||||||
========================= ========= ========= ========== ==============
|
|
||||||
|
|
||||||
You can identify these on boot-up by looking at the UART output, the first number
|
|
||||||
in the ``boot mode:`` line tells you what mode was selected
|
|
||||||
|
|
||||||
.. code-block:: text
|
|
||||||
|
|
||||||
ets Jan 8 2013,rst cause:4, boot mode:(3,6)
|
|
||||||
|
|
||||||
The first lines when viewing the UART logs might have unrecognized characters. This is
|
|
||||||
because the effective baudrate of the ESP8266 bootloader is 74800, whereas the program uses 115200.
|
|
||||||
|
|
||||||
Reset Causes
|
|
||||||
------------
|
|
||||||
|
|
||||||
Additionally, the first line also contains the **reset cause**.
|
|
||||||
These reset causes `are documented
|
|
||||||
<https://www.espressif.com/sites/default/files/documentation/esp8266_reset_causes_and_common_fatal_exception_causes_en.pdf>`__:
|
|
||||||
|
|
||||||
== ===================================
|
|
||||||
0 Undefined
|
|
||||||
-- -----------------------------------
|
|
||||||
1 Power On Reboot
|
|
||||||
-- -----------------------------------
|
|
||||||
2 External reset or deep-sleep wakeup
|
|
||||||
-- -----------------------------------
|
|
||||||
4 Hardware WDT reset
|
|
||||||
== ===================================
|
|
||||||
|
|
||||||
After a software reset, the reset cause will not change.
|
|
||||||
|
|
||||||
Electrical Characteristics
|
|
||||||
--------------------------
|
|
||||||
|
|
||||||
=========================================================== =========== =========== =========== ===========
|
|
||||||
**Parameter** **Min.** **Typical** **Max.** **Unit**
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
Operating Temperature -40 125 °C
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
Working Voltage ``V_IO`` 2.5 3.3 3.6 V
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
``V_IL`` - INPUT voltage level to be considered LOW -0.3 0.25*V_IO V
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
``V_IH`` - INPUT voltage level to be considered HIGH 0.75*V_IO 3.6 V
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
``V_OL`` - OUTPUT voltage level for LOW 0.1*V_IO V
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
``V_OH`` - OUTPUT voltage level for HIGH 0.8*V_IO V
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
``I_MAX`` - Maximum current for GPIO 12 mA
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
Power Consumption in Deep Sleep 20 µA
|
|
||||||
----------------------------------------------------------- ----------- ----------- ----------- -----------
|
|
||||||
Power Consumption in Active Mode 120 mA
|
|
||||||
=========================================================== =========== =========== =========== ===========
|
|
||||||
|
|
||||||
Source: `ESP8266EX datasheet <https://www.espressif.com/sites/default/files/documentation/0a-esp8266ex_datasheet_en.pdf>`__
|
|
||||||
|
|
||||||
The internal pull up/down resistors have values of 30kΩ to 100kΩ
|
|
||||||
(`source <https://bbs.espressif.com/viewtopic.php?t=1079>`__).
|
|
||||||
|
|
||||||
See Also
|
|
||||||
--------
|
|
||||||
|
|
||||||
- :doc:`nodemcu_esp8266`
|
|
||||||
- :ghedit:`Edit`
|
|
@ -61,6 +61,6 @@ Note that in certain conditions you *can* use the pins marked as ``INTERNAL`` in
|
|||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
|
||||||
- :doc:`esp32`
|
- :doc:`/components/esp32`
|
||||||
- :doc:`nodemcu_esp8266`
|
- :doc:`nodemcu_esp8266`
|
||||||
- :ghedit:`Edit`
|
- :ghedit:`Edit`
|
||||||
|
@ -73,6 +73,6 @@ Note that in certain conditions you *can* use the pins marked as ``INTERNAL`` in
|
|||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
|
||||||
- :doc:`esp8266`
|
- :doc:`/components/esp8266`
|
||||||
- :doc:`nodemcu_esp32`
|
- :doc:`nodemcu_esp32`
|
||||||
- :ghedit:`Edit`
|
- :ghedit:`Edit`
|
||||||
|
@ -421,5 +421,5 @@ See Also
|
|||||||
- :doc:`sonoff_s20`
|
- :doc:`sonoff_s20`
|
||||||
- :doc:`sonoff_4ch`
|
- :doc:`sonoff_4ch`
|
||||||
- :doc:`sonoff_basic`
|
- :doc:`sonoff_basic`
|
||||||
- :doc:`esp8266`
|
- :doc:`/components/esp8266`
|
||||||
- :ghedit:`Edit`
|
- :ghedit:`Edit`
|
||||||
|
@ -712,9 +712,45 @@ Configuration variables:
|
|||||||
|
|
||||||
- **max_runs** (*Optional*, int): Allows limiting the maxiumun number of runs when using script
|
- **max_runs** (*Optional*, int): Allows limiting the maxiumun number of runs when using script
|
||||||
modes ``queued`` and ``parallel``, use value ``0`` for unlimited runs. Defaults to ``0``.
|
modes ``queued`` and ``parallel``, use value ``0`` for unlimited runs. Defaults to ``0``.
|
||||||
|
- **parameters** (*Optional*, :ref:`Script Parameters <script-parameters>`): A script can define one
|
||||||
|
or more parameters that must be provided in order to execute. All parameters defined here are
|
||||||
|
mandatory and must be given when calling the script.
|
||||||
- **then** (**Required**, :ref:`Action <config-action>`): The action to perform.
|
- **then** (**Required**, :ref:`Action <config-action>`): The action to perform.
|
||||||
|
|
||||||
|
|
||||||
|
.. _script-parameters:
|
||||||
|
|
||||||
|
``Script Parameters``
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
Scripts can be defined with parameters. The arguments given when calling the script can be used within
|
||||||
|
the script's lambda actions. To define the parameters, add the parameter names under `parameters:` key
|
||||||
|
and specify the data type for that parameter.
|
||||||
|
|
||||||
|
Supported data types:
|
||||||
|
|
||||||
|
* `bool`: A boolean true/false. C++ type: `bool`
|
||||||
|
* `int`: An integer. C++ type: `int32_t`
|
||||||
|
* `float`: A floating point number. C++ type: `float`
|
||||||
|
* `string`: A string. C++ type: `std::string`
|
||||||
|
|
||||||
|
Each of these also exist in array form:
|
||||||
|
|
||||||
|
* `bool[]`: An array of boolean values. C++ type: `std::vector<bool>`
|
||||||
|
* Same for other types.
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
script:
|
||||||
|
- id: blink_light
|
||||||
|
parameters:
|
||||||
|
delay_ms: int
|
||||||
|
then:
|
||||||
|
- light.turn_on: status_light
|
||||||
|
# The param delay_ms is accessible using a lambda
|
||||||
|
- delay: !lambda return delay_ms;
|
||||||
|
- light.turn_off: status_light
|
||||||
|
|
||||||
.. _script-execute_action:
|
.. _script-execute_action:
|
||||||
|
|
||||||
``script.execute`` Action
|
``script.execute`` Action
|
||||||
@ -730,11 +766,16 @@ script was already running.
|
|||||||
then:
|
then:
|
||||||
- script.execute: my_script
|
- script.execute: my_script
|
||||||
|
|
||||||
or as lambda
|
# Calling a non-parameterised script in a lambda
|
||||||
|
- lambda: id(my_script).execute();
|
||||||
|
|
||||||
.. code-block:: yaml
|
# Calling a script with parameters
|
||||||
|
- script.execute:
|
||||||
|
id: blink_light
|
||||||
|
delay_ms: 500
|
||||||
|
|
||||||
lambda: 'id(my_script).execute();'
|
# Calling a parameterised script inside a lambda
|
||||||
|
- lambda: id(blink_light)->execute(1000);
|
||||||
|
|
||||||
.. _script-stop_action:
|
.. _script-stop_action:
|
||||||
|
|
||||||
|
@ -49,6 +49,9 @@ Example configuration
|
|||||||
# In combination with the `ap` this allows the user
|
# In combination with the `ap` this allows the user
|
||||||
# to provision wifi credentials to the device.
|
# to provision wifi credentials to the device.
|
||||||
captive_portal:
|
captive_portal:
|
||||||
|
# Optionally, preserve provisioned credentials
|
||||||
|
# over subsequent OTA updates.
|
||||||
|
keep_user_credentials: true
|
||||||
|
|
||||||
# Sets up Bluetooth LE (Only on ESP32) to allow the user
|
# Sets up Bluetooth LE (Only on ESP32) to allow the user
|
||||||
# to provision wifi credentials to the device.
|
# to provision wifi credentials to the device.
|
||||||
|
@ -47,12 +47,8 @@ Happy Hacking!
|
|||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
|
||||||
- :doc:`/devices/nodemcu_esp8266`
|
- :doc:`/components/esp8266`
|
||||||
- :doc:`/devices/nodemcu_esp32`
|
- :doc:`/components/esp32`
|
||||||
- :doc:`/devices/esp8266`
|
|
||||||
- :doc:`/devices/esp32`
|
|
||||||
- :doc:`/devices/sonoff_s20`
|
|
||||||
- :doc:`/devices/sonoff_4ch`
|
|
||||||
- :doc:`migrate_espurna`
|
- :doc:`migrate_espurna`
|
||||||
- :doc:`migrate_sonoff_tasmota`
|
- :doc:`migrate_sonoff_tasmota`
|
||||||
- :ghedit:`Edit`
|
- :ghedit:`Edit`
|
||||||
|
@ -52,12 +52,8 @@ Happy Hacking!
|
|||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
|
||||||
- :doc:`/devices/nodemcu_esp8266`
|
- :doc:`/components/esp8266`
|
||||||
- :doc:`/devices/nodemcu_esp32`
|
- :doc:`/components/esp32`
|
||||||
- :doc:`/devices/esp8266`
|
|
||||||
- :doc:`/devices/esp32`
|
|
||||||
- :doc:`/devices/sonoff_s20`
|
|
||||||
- :doc:`/devices/sonoff_4ch`
|
|
||||||
- :doc:`migrate_espeasy`
|
- :doc:`migrate_espeasy`
|
||||||
- :doc:`migrate_sonoff_tasmota`
|
- :doc:`migrate_sonoff_tasmota`
|
||||||
- :ghedit:`Edit`
|
- :ghedit:`Edit`
|
||||||
|
@ -11,8 +11,7 @@ ESPHome create a binary for you and then upload that in the Tasmota web interfac
|
|||||||
Getting the Binary
|
Getting the Binary
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
First follow the guides for the :ref:`different supported devices <devices>` and create a configuration
|
First create a configuration for your device. Then, generate and download the legacy binary:
|
||||||
file. Then, generate and download the binary:
|
|
||||||
|
|
||||||
- **Using the Home Assistant add-on/dashboard**: Just click the ``COMPILE``
|
- **Using the Home Assistant add-on/dashboard**: Just click the ``COMPILE``
|
||||||
button, wait for the compilation to end and press the ``DOWNLOAD BINARY``
|
button, wait for the compilation to end and press the ``DOWNLOAD BINARY``
|
||||||
@ -64,13 +63,8 @@ Happy Hacking!
|
|||||||
See Also
|
See Also
|
||||||
--------
|
--------
|
||||||
|
|
||||||
- :doc:`/devices/sonoff_s20`
|
- :doc:`/components/esp8266`
|
||||||
- :doc:`/devices/sonoff_4ch`
|
- :doc:`/components/esp32`
|
||||||
- :doc:`/devices/sonoff`
|
|
||||||
- :doc:`/devices/nodemcu_esp8266`
|
|
||||||
- :doc:`/devices/nodemcu_esp32`
|
|
||||||
- :doc:`/devices/esp8266`
|
|
||||||
- :doc:`/devices/esp32`
|
|
||||||
- :doc:`migrate_espurna`
|
- :doc:`migrate_espurna`
|
||||||
- :doc:`migrate_espeasy`
|
- :doc:`migrate_espeasy`
|
||||||
- :ghedit:`Edit`
|
- :ghedit:`Edit`
|
||||||
|
@ -175,6 +175,7 @@ Contributors
|
|||||||
- `Dmitry Berezovsky (@corvis) <https://github.com/corvis>`__
|
- `Dmitry Berezovsky (@corvis) <https://github.com/corvis>`__
|
||||||
- `Cougar (@Cougar) <https://github.com/Cougar>`__
|
- `Cougar (@Cougar) <https://github.com/Cougar>`__
|
||||||
- `Connor Prussin (@cprussin) <https://github.com/cprussin>`__
|
- `Connor Prussin (@cprussin) <https://github.com/cprussin>`__
|
||||||
|
- `Corey Rice (@crice009) <https://github.com/crice009>`__
|
||||||
- `cryptelli (@cryptelli) <https://github.com/cryptelli>`__
|
- `cryptelli (@cryptelli) <https://github.com/cryptelli>`__
|
||||||
- `cstaahl (@cstaahl) <https://github.com/cstaahl>`__
|
- `cstaahl (@cstaahl) <https://github.com/cstaahl>`__
|
||||||
- `Chris Talkington (@ctalkington) <https://github.com/ctalkington>`__
|
- `Chris Talkington (@ctalkington) <https://github.com/ctalkington>`__
|
||||||
@ -499,6 +500,7 @@ Contributors
|
|||||||
- `Kyle Manna (@kylemanna) <https://github.com/kylemanna>`__
|
- `Kyle Manna (@kylemanna) <https://github.com/kylemanna>`__
|
||||||
- `Kalashnikov Ilya (@l1bbcsg) <https://github.com/l1bbcsg>`__
|
- `Kalashnikov Ilya (@l1bbcsg) <https://github.com/l1bbcsg>`__
|
||||||
- `Limor "Ladyada" Fried (@ladyada) <https://github.com/ladyada>`__
|
- `Limor "Ladyada" Fried (@ladyada) <https://github.com/ladyada>`__
|
||||||
|
- `Lakshantha Dissanayake (@lakshanthad) <https://github.com/lakshanthad>`__
|
||||||
- `Luca Adrian L (@lal12) <https://github.com/lal12>`__
|
- `Luca Adrian L (@lal12) <https://github.com/lal12>`__
|
||||||
- `Fredrik Lindqvist (@Landrash) <https://github.com/Landrash>`__
|
- `Fredrik Lindqvist (@Landrash) <https://github.com/Landrash>`__
|
||||||
- `Laszlo Gazdag (@lazlyhu) <https://github.com/lazlyhu>`__
|
- `Laszlo Gazdag (@lazlyhu) <https://github.com/lazlyhu>`__
|
||||||
@ -652,12 +654,10 @@ Contributors
|
|||||||
- `Ockert Marais (@OckertM) <https://github.com/OckertM>`__
|
- `Ockert Marais (@OckertM) <https://github.com/OckertM>`__
|
||||||
- `Dave Walker (@oddsockmachine) <https://github.com/oddsockmachine>`__
|
- `Dave Walker (@oddsockmachine) <https://github.com/oddsockmachine>`__
|
||||||
- `Andrey Ganzevich (@odya) <https://github.com/odya>`__
|
- `Andrey Ganzevich (@odya) <https://github.com/odya>`__
|
||||||
- `Olivér Falvai (@ofalvai) <https://github.com/ofalvai>`__
|
|
||||||
- `ogatatsu (@ogatatsu) <https://github.com/ogatatsu>`__
|
- `ogatatsu (@ogatatsu) <https://github.com/ogatatsu>`__
|
||||||
- `Oğuzhan Başer (@oguzhanbaser) <https://github.com/oguzhanbaser>`__
|
- `Oğuzhan Başer (@oguzhanbaser) <https://github.com/oguzhanbaser>`__
|
||||||
- `Omar Ghader (@omarghader) <https://github.com/omarghader>`__
|
- `Omar Ghader (@omarghader) <https://github.com/omarghader>`__
|
||||||
- `Ömer Şiar Baysal (@omersiar) <https://github.com/omersiar>`__
|
- `Ömer Şiar Baysal (@omersiar) <https://github.com/omersiar>`__
|
||||||
- `Oncleben31 (@oncleben31) <https://github.com/oncleben31>`__
|
|
||||||
- `Oscar Bolmsten (@oscar-b) <https://github.com/oscar-b>`__
|
- `Oscar Bolmsten (@oscar-b) <https://github.com/oscar-b>`__
|
||||||
- `Trammell Hudson (@osresearch) <https://github.com/osresearch>`__
|
- `Trammell Hudson (@osresearch) <https://github.com/osresearch>`__
|
||||||
- `Otamay (@Otamay) <https://github.com/Otamay>`__
|
- `Otamay (@Otamay) <https://github.com/Otamay>`__
|
||||||
@ -740,6 +740,7 @@ Contributors
|
|||||||
- `Silvio (@s1lvi0) <https://github.com/s1lvi0>`__
|
- `Silvio (@s1lvi0) <https://github.com/s1lvi0>`__
|
||||||
- `Jan Čermák (@sairon) <https://github.com/sairon>`__
|
- `Jan Čermák (@sairon) <https://github.com/sairon>`__
|
||||||
- `sascha lammers (@sascha432) <https://github.com/sascha432>`__
|
- `sascha lammers (@sascha432) <https://github.com/sascha432>`__
|
||||||
|
- `Søren Christian Aarup (@scaarup) <https://github.com/scaarup>`__
|
||||||
- `Nils Schulte (@Schnilz) <https://github.com/Schnilz>`__
|
- `Nils Schulte (@Schnilz) <https://github.com/Schnilz>`__
|
||||||
- `Wolle (@schreibfaul1) <https://github.com/schreibfaul1>`__
|
- `Wolle (@schreibfaul1) <https://github.com/schreibfaul1>`__
|
||||||
- `Ville Skyttä (@scop) <https://github.com/scop>`__
|
- `Ville Skyttä (@scop) <https://github.com/scop>`__
|
||||||
@ -896,4 +897,4 @@ Contributors
|
|||||||
- `Zack Barett (@zsarnett) <https://github.com/zsarnett>`__
|
- `Zack Barett (@zsarnett) <https://github.com/zsarnett>`__
|
||||||
- `Christian Zufferey (@zuzu59) <https://github.com/zuzu59>`__
|
- `Christian Zufferey (@zuzu59) <https://github.com/zuzu59>`__
|
||||||
|
|
||||||
*This page was last updated November 1, 2022.*
|
*This page was last updated November 9, 2022.*
|
||||||
|
BIN
images/adc128s102.png
Normal file
After Width: | Height: | Size: 16 KiB |
BIN
images/ezo-pmp.jpg
Normal file
After Width: | Height: | Size: 8.2 KiB |
BIN
images/lcd_menu.png
Normal file
After Width: | Height: | Size: 8.4 KiB |
62
images/rp2040.svg
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg
|
||||||
|
width="108.44565mm"
|
||||||
|
height="25.000002mm"
|
||||||
|
viewBox="0 0 108.44565 25.000002"
|
||||||
|
version="1.1"
|
||||||
|
id="svg8"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/">
|
||||||
|
<defs
|
||||||
|
id="defs2" />
|
||||||
|
<metadata
|
||||||
|
id="metadata5">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<g
|
||||||
|
id="layer1">
|
||||||
|
<path
|
||||||
|
id="rect833"
|
||||||
|
style="stroke-width:0.133497"
|
||||||
|
d="m 5,0 h 98.44565 c 2.77,0 5,2.23 5,5 v 15 c 0,2.77 -2.23,5 -5,5 H 5 C 2.23,25 0,22.77 0,20 V 5 C 0,2.23 2.23,0 5,0 Z" />
|
||||||
|
<g
|
||||||
|
aria-label="RP2040"
|
||||||
|
id="text837"
|
||||||
|
style="font-size:10.5833px;line-height:1.25;letter-spacing:1.08479px;fill:#fffffc;stroke-width:0.264583">
|
||||||
|
<path
|
||||||
|
d="m 15.353522,20.665705 -2.686758,-3.973693 h -1.44498 v 3.973693 H 5.8934233 V 4.8612442 h 7.6087187 q 2.190047,0 3.815649,0.7224896 1.625601,0.7224896 2.506135,2.0771577 0.880535,1.354668 0.880535,3.1608925 0,1.693335 -0.767646,2.957691 -0.767645,1.264357 -2.212624,2.009425 l 3.318937,4.876805 z m -0.02258,-9.843921 q 0,-0.8805346 -0.541867,-1.3546684 -0.541865,-0.4967117 -1.6256,-0.4967117 h -1.941691 v 3.7027591 h 1.941691 q 1.083735,0 1.625602,-0.474134 0.541867,-0.496711 0.541867,-1.377245 z"
|
||||||
|
style="font-weight:900;font-size:22.5778px;font-family:Montserrat;-inkscape-font-specification:'Montserrat Heavy'"
|
||||||
|
id="path414" />
|
||||||
|
<path
|
||||||
|
d="m 31.407412,4.8612442 q 2.190046,0 3.815648,0.7224896 1.625602,0.7224896 2.506136,2.0771577 0.880534,1.354668 0.880534,3.1608925 0,1.806224 -0.880534,3.160892 -0.880534,1.354668 -2.506136,2.077157 -1.625602,0.72249 -3.815648,0.72249 h -2.280358 v 3.883382 H 23.798693 V 4.8612442 Z m -0.338667,7.8119188 q 1.083734,0 1.625601,-0.474134 0.541868,-0.496711 0.541868,-1.377245 0,-0.8805346 -0.541868,-1.3546684 -0.541867,-0.4967117 -1.625601,-0.4967117 h -1.941691 v 3.7027591 z"
|
||||||
|
style="font-weight:900;font-size:22.5778px;font-family:Montserrat;-inkscape-font-specification:'Montserrat Heavy'"
|
||||||
|
id="path416" />
|
||||||
|
<path
|
||||||
|
d="m 48.228949,16.533967 h 5.328361 v 4.131738 H 40.891163 v -3.273781 l 5.712184,-5.283206 q 0.745067,-0.699912 0.993423,-1.196623 0.248356,-0.496712 0.248356,-0.9708456 0,-0.5870228 -0.4064,-0.9031121 -0.383823,-0.338667 -1.12889,-0.338667 -0.72249,0 -1.354668,0.3838226 -0.632179,0.3838227 -0.970846,1.0837341 L 39.965474,8.1576031 q 0.903112,-1.693335 2.641602,-2.6641805 1.738491,-0.9934232 4.199471,-0.9934232 1.873958,0 3.318937,0.6096006 1.444979,0.6096006 2.25778,1.7384907 0.812801,1.12889 0.812801,2.5964471 0,1.3095122 -0.564445,2.4609802 -0.541867,1.12889 -2.144891,2.573869 z"
|
||||||
|
style="font-weight:900;font-size:22.5778px;font-family:Montserrat;-inkscape-font-specification:'Montserrat Heavy'"
|
||||||
|
id="path418" />
|
||||||
|
<path
|
||||||
|
d="m 62.882996,21.02695 q -2.099736,0 -3.725337,-0.970846 -1.603024,-0.993423 -2.528714,-2.844803 -0.903112,-1.873957 -0.903112,-4.447827 0,-2.573869 0.903112,-4.4252485 0.92569,-1.8739574 2.528714,-2.8448029 1.625601,-0.9934232 3.725337,-0.9934232 2.099735,0 3.702759,0.9934232 1.625602,0.9708455 2.528714,2.8448029 0.92569,1.8513795 0.92569,4.4252485 0,2.57387 -0.92569,4.447827 -0.903112,1.85138 -2.528714,2.844803 -1.603024,0.970846 -3.702759,0.970846 z m 0,-4.267205 q 1.806224,0 1.806224,-3.996271 0,-3.9962703 -1.806224,-3.9962703 -1.806224,0 -1.806224,3.9962703 0,3.996271 1.806224,3.996271 z"
|
||||||
|
style="font-weight:900;font-size:22.5778px;font-family:Montserrat;-inkscape-font-specification:'Montserrat Heavy'"
|
||||||
|
id="path420" />
|
||||||
|
<path
|
||||||
|
d="m 85.665039,13.824631 h 2.099735 v 4.131738 h -2.099735 v 2.709336 h -5.170317 v -2.709336 h -8.195741 v -3.38667 l 6.705606,-9.7084548 h 5.463828 l -5.960539,8.9633868 h 2.144891 v -2.415825 h 5.012272 z"
|
||||||
|
style="font-weight:900;font-size:22.5778px;font-family:Montserrat;-inkscape-font-specification:'Montserrat Heavy'"
|
||||||
|
id="path422" />
|
||||||
|
<path
|
||||||
|
d="m 96.751789,21.02695 q -2.099735,0 -3.725337,-0.970846 -1.603024,-0.993423 -2.528713,-2.844803 -0.903112,-1.873957 -0.903112,-4.447827 0,-2.573869 0.903112,-4.4252485 0.925689,-1.8739574 2.528713,-2.8448029 1.625602,-0.9934232 3.725337,-0.9934232 2.099736,0 3.702761,0.9934232 1.6256,0.9708455 2.52871,2.8448029 0.92569,1.8513795 0.92569,4.4252485 0,2.57387 -0.92569,4.447827 -0.90311,1.85138 -2.52871,2.844803 -1.603025,0.970846 -3.702761,0.970846 z m 0,-4.267205 q 1.806224,0 1.806224,-3.996271 0,-3.9962703 -1.806224,-3.9962703 -1.806224,0 -1.806224,3.9962703 0,3.996271 1.806224,3.996271 z"
|
||||||
|
style="font-weight:900;font-size:22.5778px;font-family:Montserrat;-inkscape-font-specification:'Montserrat Heavy'"
|
||||||
|
id="path424" />
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 5.0 KiB |
30
index.rst
@ -113,26 +113,14 @@ ESPHome is a system to control your ESP8266/ESP32 by simple yet powerful configu
|
|||||||
|
|
||||||
.. _devices:
|
.. _devices:
|
||||||
|
|
||||||
Devices
|
Platforms
|
||||||
-------
|
---------
|
||||||
|
|
||||||
This list contains a bunch of getting started and more advanced guides for using ESPHome.
|
|
||||||
Technically, all ESP8266/ESP32 devices are supported by ESPHome.
|
|
||||||
|
|
||||||
.. imgtable::
|
.. imgtable::
|
||||||
|
|
||||||
Generic ESP8266, devices/esp8266, esp8266.svg
|
ESP8266, components/esp8266, esp8266.svg
|
||||||
Generic ESP32, devices/esp32, esp32.svg
|
ESP32, components/esp32, esp32.svg
|
||||||
NodeMCU ESP8266, devices/nodemcu_esp8266, nodemcu_esp8266.jpg
|
RP2040, components/rp2040, rp2040.svg
|
||||||
|
|
||||||
NodeMCU ESP32, devices/nodemcu_esp32, nodemcu_esp32.jpg
|
|
||||||
Sonoff S20, devices/sonoff_s20, sonoff_s20.jpg
|
|
||||||
Sonoff 4CH, devices/sonoff_4ch, sonoff_4ch.jpg
|
|
||||||
|
|
||||||
Generic Sonoff, devices/sonoff, sonoff.svg
|
|
||||||
Sonoff Basic, devices/sonoff_basic, sonoff_basic.jpg
|
|
||||||
Sonoff T1 UK 3 Gang V1.1, devices/sonoff_t1_uk_3gang_v1.1, sonoff_t1_uk_3g_v1.1.jpg
|
|
||||||
Sonoff T3 EU 3 Gang V1.0, devices/sonoff_t3_eu_3gang_v1.0, sonoff_t3_eu_3g_v1.0.jpg
|
|
||||||
|
|
||||||
Core Components
|
Core Components
|
||||||
---------------
|
---------------
|
||||||
@ -207,6 +195,7 @@ Analogue
|
|||||||
.. imgtable::
|
.. imgtable::
|
||||||
|
|
||||||
ADC, components/sensor/adc, flash.svg, ESP internal
|
ADC, components/sensor/adc, flash.svg, ESP internal
|
||||||
|
ADC128S102, components/sensor/adc128s102, adc128s102.png , 8-channel ADC
|
||||||
ADS1115, components/sensor/ads1115, ads1115.jpg, 4-channel ADC
|
ADS1115, components/sensor/ads1115, ads1115.jpg, 4-channel ADC
|
||||||
CD74HC4067, components/sensor/cd74hc4067, cd74hc4067.jpg, 16-channel analog multiplexer
|
CD74HC4067, components/sensor/cd74hc4067, cd74hc4067.jpg, 16-channel analog multiplexer
|
||||||
MCP3008, components/sensor/mcp3008, mcp3008.jpg, 8-channel ADC
|
MCP3008, components/sensor/mcp3008, mcp3008.jpg, 8-channel ADC
|
||||||
@ -594,12 +583,14 @@ Text Sensor Components
|
|||||||
MQTT Subscribe Text, components/text_sensor/mqtt_subscribe, mqtt.png
|
MQTT Subscribe Text, components/text_sensor/mqtt_subscribe, mqtt.png
|
||||||
Version, components/text_sensor/version, new-box.svg
|
Version, components/text_sensor/version, new-box.svg
|
||||||
WiFi Info, components/text_sensor/wifi_info, network-wifi.svg
|
WiFi Info, components/text_sensor/wifi_info, network-wifi.svg
|
||||||
|
Ethernet Info, components/text_sensor/ethernet_info, ethernet.svg
|
||||||
BLE Scanner, components/text_sensor/ble_scanner, bluetooth.svg
|
BLE Scanner, components/text_sensor/ble_scanner, bluetooth.svg
|
||||||
Modbus Text Sensor, components/text_sensor/modbus_controller, modbus.png
|
Modbus Text Sensor, components/text_sensor/modbus_controller, modbus.png
|
||||||
Template Text Sensor, components/text_sensor/template, description.svg
|
Template Text Sensor, components/text_sensor/template, description.svg
|
||||||
Custom Text Sensor, components/text_sensor/custom, language-cpp.svg
|
Custom Text Sensor, components/text_sensor/custom, language-cpp.svg
|
||||||
Nextion Text Sensor, components/text_sensor/nextion, nextion.jpg
|
Nextion Text Sensor, components/text_sensor/nextion, nextion.jpg
|
||||||
Tuya Text Sensor, components/text_sensor/tuya, tuya.png
|
Tuya Text Sensor, components/text_sensor/tuya, tuya.png
|
||||||
|
WL-134 Pet Tag Sensor , components/text_sensor/wl_134, fingerprint.svg
|
||||||
|
|
||||||
Climate Components
|
Climate Components
|
||||||
------------------
|
------------------
|
||||||
@ -659,12 +650,11 @@ Misc Components
|
|||||||
|
|
||||||
.. imgtable::
|
.. imgtable::
|
||||||
|
|
||||||
ESP8266, components/esp8266, esp8266.svg
|
|
||||||
ESP32, components/esp32, esp32.svg
|
|
||||||
|
|
||||||
Remote Receiver, components/remote_receiver, remote.svg
|
Remote Receiver, components/remote_receiver, remote.svg
|
||||||
Remote Transmitter, components/remote_transmitter, remote.svg
|
Remote Transmitter, components/remote_transmitter, remote.svg
|
||||||
Status LED, components/status_led, led-on.svg
|
Status LED, components/status_led, led-on.svg
|
||||||
|
Display Menu Core, components/display_menu/index, folder-open.svg
|
||||||
|
LCD Menu, components/display_menu/lcd_menu, lcd_menu.png
|
||||||
HTTP Request, components/http_request, connection.svg
|
HTTP Request, components/http_request, connection.svg
|
||||||
mDNS, components/mdns, radio-tower.svg
|
mDNS, components/mdns, radio-tower.svg
|
||||||
|
|
||||||
|