mirror of
https://github.com/esphome/esphome-docs.git
synced 2025-01-26 22:21:38 +01:00
Document sdl driver (#3880)
This commit is contained in:
parent
101005f1f1
commit
ca489a6870
112
components/display/sdl.rst
Normal file
112
components/display/sdl.rst
Normal file
@ -0,0 +1,112 @@
|
||||
SDL2 Display on host platform
|
||||
=============================
|
||||
|
||||
.. seo::
|
||||
:description: Instructions for setting up SDL2 display on host
|
||||
:image: sdl.png
|
||||
|
||||
.. _sdl:
|
||||
|
||||
Usage
|
||||
-----
|
||||
|
||||
The ``sdl`` display platform allows you to use create an ESPHome display on a desktop system running Linux or MacOS.
|
||||
This is particularly useful for designing display layouts, since compiling and running a host binary is much faster
|
||||
than compiling for and flashing a microcontroller target system.
|
||||
|
||||
.. code-block:: yaml
|
||||
|
||||
# Example configuration entry
|
||||
host:
|
||||
mac_address: "62:23:45:AF:B3:DD"
|
||||
|
||||
display:
|
||||
- platform: sdl
|
||||
id: sdl_display
|
||||
update_interval: 1s
|
||||
auto_clear_enabled: false
|
||||
show_test_card: true
|
||||
dimensions:
|
||||
width: 450
|
||||
height: 600
|
||||
|
||||
|
||||
Configuration variables:
|
||||
************************
|
||||
|
||||
- **lambda** (*Optional*, :ref:`lambda <config-lambda>`): The lambda to use for rendering the content on the display.
|
||||
See :ref:`display-engine` for more information.
|
||||
- **update_interval** (*Optional*, :ref:`config-time`): The interval to re-draw the screen. Defaults to ``1s``.
|
||||
- **sdl_options** (*Optional*, string): Build arguments if required to specify include or library paths. Should not be required if SDL2 is properly installed.
|
||||
- **pages** (*Optional*, list): Show pages instead of a single lambda. See :ref:`display-pages`.
|
||||
- **id** (*Optional*, :ref:`config-id`): Manually specify the ID used for code generation.
|
||||
|
||||
|
||||
.. note::
|
||||
|
||||
To build with this display you must have the
|
||||
`SDL2 <https://wiki.libsdl.org/SDL2/Installation>`__ package installed. The Sodium encryption library will
|
||||
also be required for any API calls. See below for installation hints.
|
||||
|
||||
MacOS SDL2 Installation
|
||||
-----------------------
|
||||
|
||||
The easiest way to install SDL2 on MacOS is using ``homebrew``:
|
||||
|
||||
.. code-block:: sh
|
||||
|
||||
brew install sdl2 libsodium
|
||||
|
||||
It may also be necessary to run the command:
|
||||
|
||||
|
||||
.. code-block:: sh
|
||||
|
||||
|
||||
brew link sdl2 libsodium
|
||||
|
||||
|
||||
|
||||
To ensure that the files are symlinked correctly.
|
||||
You can check installation with the command ``sdl2-config --libs --cflags``.
|
||||
|
||||
You will need the XCode command-line tools installed to build for the host platform.
|
||||
|
||||
Linux SDL2 Installation
|
||||
-----------------------
|
||||
|
||||
On Debian/Ubuntu derived Linux systems you can install with ``apt``; also check that you have the necessary build
|
||||
tools installed, and you must be using a desktop system with a graphic display.
|
||||
|
||||
.. code-block:: sh
|
||||
|
||||
apt install libsdl2-dev libsodium-dev build-essential git
|
||||
|
||||
You can check installation with the command ``sdl2-config --libs --cflags``.
|
||||
|
||||
|
||||
Microsoft Windows
|
||||
-----------------
|
||||
|
||||
Although SDL2 is supported, natively running ESPHome on Windows isn't easy. However the *Windows Subsystem for Linux* (WSL) can be
|
||||
used to install and use a Linux development environment on Windows, which will enable use of ESPHome and SDL2 as per the
|
||||
Linux instructions above. See https://learn.microsoft.com/en-us/windows/wsl/install for more information on WSL.
|
||||
|
||||
Build and run
|
||||
-------------
|
||||
|
||||
The ``esphome`` command will not automatically run the build file on the ``host`` platform. Instead use ``esphome compile yourfile.yaml``
|
||||
then locate the executable file called ``program`` within the ``.esphome`` build tree:
|
||||
|
||||
.. code-block:: sh
|
||||
|
||||
`find .esphome -name program`
|
||||
|
||||
|
||||
See Also
|
||||
--------
|
||||
|
||||
- :ref:`SDL touchscreen <sdl_touchscreen>`
|
||||
- :doc:`index`
|
||||
- :apiref:`sdl/sdl_esphome.h`
|
||||
- :ghedit:`Edit`
|
35
components/touchscreen/sdl.rst
Normal file
35
components/touchscreen/sdl.rst
Normal file
@ -0,0 +1,35 @@
|
||||
SDL2 Touch Screen Emulator
|
||||
==========================
|
||||
|
||||
.. seo::
|
||||
:description: Instructions for setting up touch screen emulation with the sdl display driver.
|
||||
:keywords: sdl, touchscreen
|
||||
|
||||
.. _sdl_touchscreen:
|
||||
|
||||
The ``sdl`` touchscreen platform allows emulating a touch screen by using the mouse with the ``sdl`` display driver.
|
||||
The ``sdl`` display component must be configured to use this.
|
||||
|
||||
Base Touchscreen Configuration
|
||||
------------------------------
|
||||
|
||||
.. code-block:: yaml
|
||||
|
||||
# Example configuration entry
|
||||
touchscreen:
|
||||
platform: sdl
|
||||
|
||||
Configuration variables:
|
||||
************************
|
||||
|
||||
- **id** (*Optional*, :ref:`config-id`): Manually set the ID of this touchscreen.
|
||||
|
||||
- All other options from :ref:`Touchscreen <config-touchscreen>`.
|
||||
|
||||
|
||||
See Also
|
||||
--------
|
||||
|
||||
- :ref:`SDL display <sdl>`
|
||||
- :apiref:`sdl/sdl_touchscreen.h`
|
||||
- :ghedit:`Edit`
|
BIN
images/sdl.png
Normal file
BIN
images/sdl.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 19 KiB |
@ -817,6 +817,7 @@ Display Hardware Platforms
|
||||
TM1638, components/display/tm1638, tm1638.jpg
|
||||
TM1651 Battery Display, components/tm1651, tm1651_battery_display.jpg
|
||||
Waveshare E-Paper, components/display/waveshare_epaper, waveshare_epaper.jpg
|
||||
Host SDL2 display, components/display/sdl, sdl.png
|
||||
|
||||
Touchscreen Components
|
||||
----------------------
|
||||
|
Loading…
Reference in New Issue
Block a user