4 releases

0.3.0 Oct 3, 2024
0.2.2 Jun 4, 2024
0.2.1 Nov 4, 2021
0.2.0 Oct 1, 2021

#358 in Hardware support


Used in 2 crates

MIT/Apache

42KB
824 lines

Crazyflie link

Link implementation for the Crazyflie quadcopter.

This crates implements low-level link communication to a Crazyflie using the Crazyradio dongle or the direct USB connection. It allows to scan for Crazyflies and to open a bidirectional link.

This crate API is async, it is implemented using the Tokio executor.

Limitations

This crate currently only supports 2Mbit/s datarate over Crazyradio.

This crate currently only supports the Tokio executor.


lib.rs:

Crazyflie Link

This Crate implement the Crazyflie radio link connection using Crazyradio. It allows to scan for Crazyflies and to open a safe bidirectional radio connection using a Crazyradio.

The entry point to this Crate is the [LinkContext], it keeps track of Crazyradio dongles and provides functions to open a link [Connection].

A connection can then be used to send and receive packet with the Crazyflie.

Example:

// Create a link Context
let context = crazyflie_link::LinkContext::new();

// Scan for Crazyflies
let cf_found = context.scan([0xe7; 5]).await?;

if let Some(uri) = cf_found.first() {
    let connection = context.open_link(uri).await?;
    let packet = connection.recv_packet().await?;
    println!("Packet received: {:?}", packet);
}

Dependencies

~7–15MB
~172K SLoC