A higher-level Python API for ElGato's Stream Deck.
This module is based off and uses streamdeck-elgato-python from Dean Camera.
StreamDeckLayoutManager is a pure Python project. It requires at least Python 3.8.
You can install StreamDeckLayoutManager by typing the following in a terminal window:
pip install StreamDeckLayoutManager
You can use StreamDeckLayoutManager in your own Python scripts like this:
import StreamDeckLayoutManager
streamdeck_manager = StreamDeckLayoutManager.Manager('StreamDeckConfig.toml')
streamdeck_manager.displayPage('MyPageName')
In order to receive key press/release information, you need to hook up at least one callback:
streackdeck_manager.setCallback('MyCallbackName', callback_method)
Callback method wil receive a List
of arguments, as provided by the key configuration, minus the callback name:
def streamdeckCallback(arguments):
# -- If the key's action is [ 'MyCallbackName', 'test', 42 ]
# -- then arguments in this case will be [ 'test', 42 ]
...
Config files are regualr toml
files. They have a general section named config
:
[config]
Brightness = 90
AssetFolder = 'assets'
Font = 'Roboto-Regular.ttf'
FontSize = 11
AssetFolder
is relative to the folder where the config file is found.
They also have entries for each page:
[MyPageName]
Key13Image = 'MyIcon.png'
Key13Label = 'My Label'
Key13PressedAction = [ 'MyCallbackName', 'test', 42 ]
Key13ReleasedAction = [ 'MyCallbackName', 'other_test' ]
...
The page contains numbered entries for each key from Key0
to Key14
(if you are using an original streamdeck). Each entry lists the image to use, the text to display underneath the image and the callback to call when the key is pressed or when it is released.
Image path is relative to the asset folder provided in the config
section.
Callback names such as push_page
, pop_page
and display_page
are reserved and can be used to moved between pages, including creating folders
Key14Image = 'folder.png'
Key14Label = 'MyFolder'
Key14PressedAction = [ 'push_page', 'SamplePage1' ]
This callback will push the current page onto a stack and display the page SamplePage1
.
Key14Image = 'back.png'
Key14Label = 'Go Back'
Key14PressedAction = [ 'pop_page' ]
This callback will pop the previous page from a stack and display it again.
Key9Image = 'other.png'
Key9Label = 'NextPage'
Key9PressedAction = [ 'display_page', 'SamplePage2' ]
This callback will simply display it the page SamplePage2
. The page stack is unaffected and only the current page is modified.
Initialize a new manager for streack deck at index deck_index
using the config file at config_file_path
.
Shuts down the manager.
Display page named page_name
.
Push current page onto the stack and display page named page_name
.
Pop the previous page off the stack and display it.
Manager.setKey(self, page_name: str, key_index: int, image_file: str, label: str, pressed_callback, released_callback=None)
Set the key in page named page_name
at index key_index
to display image at image_file
with label label
. When key is pressed then pressed_callback
is called, when the key is released then released_callback
is called.
Image path is relative to the asset folder provided in the config
section.
This can be used to set keys dynamically, as opposed to statically in the config file.
For example:
streamdeck_manager.setKey('MainPage', 12, 'MyImage.png', 'My Label',
['MyCallbackName', 'test_argument', 2])
Set the callback method for callback callback_name
to the method callback
.
Return the number of stream decks found.
Prints diagnostic information about the streamdeck at index index
.
StreamDeckLayoutManager is distributed under the terms of the MIT license.