Skip to content
/ ufo Public

🚀 👾 A Drone/UAV Programming Library for Rust.

Notifications You must be signed in to change notification settings

ajmwagar/ufo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🚀 👾 U.F.O: Universal Flying Objects

ufo dependency status Gitter chat

A Drone/UAV/Quadcopter/RC Plane programming library for Rust.

FYI: this is still a WIP, the traits and structs exist, but examples and documentation are lacking... Proceed with caution.

NOTE: I broke my only quadcopter. When I get a new one, I will continue to work on this library. Until then I will accept pull requests and issues, but no active development will happen.

Goals

  1. Build an extensible modular library that can support an infinite number of UAVs.
  2. Handle as much of the boiler plate as possible. (Things just work)
  3. Low Latency Between Drone and Controller

Non-Goals

  • Implement A UI for controlling UAVs (NOTE: I may decide to build a UI later on, but it will be in its own repository)
    • For controlling the drones using a keyboard checkout mothership
  • Support other types of robotics/RCs, right now this crate is for RC Drones and Planes. This may change at a later date, but not right now.

Supported drones

Right now UFO supports the following drones:

  • JJRC H61

Feel free to implement controls for your own drone and submit it in a pull request.

Installation and usage

Add this to your Cargo.toml

[dependencies]
ufo_rs = "*"

And put something like this in src/main.rs

/// Import std stuff
use std::error::Error;
use std::time::Duration;
use std::thread;

// Import traits
use ufo_rs::traits::control::*;
use ufo_rs::traits::drone::*;

// Import controller
use ufo_rs::drones::jjrc::h61;

fn main() -> Result<(), Box<dyn Error>> {
    let delay = Duration::from_millis(2000);

    // Create a new drone driver
    let mut driver = h61::Driver::new();

    // Connect to drone
    driver.connect()?;

    // Calibrate drone 

    println!("Calibrating...");

    driver.calibrate()?;

    println!("Sent!");

    // Wait 2 seconds
    thread::sleep(delay);
    
    // Take off
    println!("Taking off...");

    driver.take_off()?;

    println!("Sent!");

    // Wait again for 1 second
    thread::sleep(Duration::from_millis(1000));

    // Land
    println!("Landing...");

    driver.land()?;
    
    println!("Sent!");


    // Ta-dah!
    Ok(())
}

See the examples/ directory for more information.

Help out

If you want to help with U.F.O, we could use support in two areas:

  1. Writing Unit Tests, I want to make sure the U.F.O. is a safe and stable way to program drones. If we can find areas prone to bugs, we can build a more stable library quickly.
  2. Adding support for more drones. If you would like to help with this or to see an example, please take a look at src/drones/jjrc/h61.rs.

Inspiration:

Inspired by:

  • Gobot: Really cool robotics library for Go
  • A lack of a drone library for Rust
  • Flying things with code is fun 😄!

About

🚀 👾 A Drone/UAV Programming Library for Rust.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages