blackmagic-camera-control

Crates.ioblackmagic-camera-control
lib.rsblackmagic-camera-control
version0.2.2
sourcesrc
created_at2021-08-28 00:02:42.992615
updated_at2022-11-07 05:05:40.470433
descriptionInterface with your Blackmagic camera over Bluetooth Low Energy in Rust
homepage
repositoryhttps://github.com/coral/blackmagic-camera-control
max_upload_size
id443286
size104,581
coral (coral)

documentation

README

Interface with your Blackmagic camera over Bluetooth in Rust!

This library allows you to easily communicate with your Blackmagic camera over Bluetooth.

  • Implements the full camera spec for easy access to commands with static type checking Command::Video(Video::Iso(640)))
  • Uses btleplug for Bluetooth to work across platforms.
  • Consumes PROTOCOL.json for code generation so it's easy to add more functions to the library

Usage

You can test the library easy by opening examples/control.rs, replacing the CAMERA_NAME const with your cameras bluetooth name and then running cargo run --example control

//Create a new camera with the device name
let mut camera = BluetoothCamera::new(CAMERA_NAME).await.unwrap();

//Connect with a set timeout
camera.connect(Duration::from_secs(10)).await.unwrap();

//Change the ISO to 320
camera.write(255, Operation::AssignValue, Command::Video(Video::Iso(640))).await.unwrap();

How does it work?

The library consumes the PROTOCOL.json file which documents the camera protocol in a machine readable format. From there it generates the commands as rust enums during the build stage (see /build). This allows us to have statically typed addressing of camera features without manually writing the code, rather relying on the conversion from the camera protocol manual. The library takes care of packaging down the commands into the camera protocol.

Contributing

Just open a PR LUL

License

All under MIT

Commit count: 43

cargo fmt