Skip to content

OpenActionAPI/rust-elgato-streamdeck

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

99 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

elgato-streamdeck

Rust library for interacting with Elgato Stream Deck hardware. Heavily based on python-elgato-streamdeck and partially on rust-streamdeck.

This library was made by @TheJebForge as a better-designed alternative to rust-streamdeck, taking code from both of the libraries and making it more pleasant to use.

udev rules for Linux

If you're using systemd on your system, you might have to install udev rules to allow connecting to devices from userspace.

You can do that by using the following command to copy this repo's included 40-streamdeck.rules file into udev/rules.d/:

cp 40-streamdeck.rules /etc/udev/rules.d/

And then reloading udev rules:

sudo udevadm control --reload-rules

Unplugging and plugging back in the device should also help.

You should also create a group called "plugdev" if it doesn't exist and add yourself to it, so you get access to the devices. You also need to restart the user session to let user group changes to kick in.

Example

use elgato_streamdeck::{new_hidapi, StreamDeck};

// Create instance of HidApi
let hid = new_hidapi();

// List devices and unsafely take first one
let (kind, serial) = StreamDeck::list_devices(&hid).remove(0);

// Connect to the device
let mut device = StreamDeck::connect(&hid, kind, &serial)
    .expect("Failed to connect");

// Print out some info from the device
println!(
    "Connected to '{}' with version '{}'",
    device.serial_number().unwrap(),
    device.firmware_version().unwrap()
);

// Set device brightness
device.set_brightness(35).unwrap();

// Use image-rs to load an image
let image = image::open("no-place-like-localhost.jpg").unwrap();

// Write it to the device
device.set_button_image(7, image).unwrap();

// Flush
if device.updated {
    device.flush().unwrap();
}

Status

  • Convenient to use API for looking up devices, connecting to them and interacting with them
  • Reading buttons with async

Supported Devices

As it stands, this library should support the following devices.

Support for non-Elgato (Mirabox/Ajazz) devices has been removed in v0.11. If you wish to use these devices, please use the mirajazz crate, or use v0.10.2 of this crate.

About

Rust library for interacting with Elgato Stream Deck and other stream controller hardware

Resources

License

Stars

Watchers

Forks

Languages