extern crate ev3dev_rs;
extern crate tokio;
use ev3dev_rs::Ev3Result;
use ev3dev_rs::pupdevices::{GyroSensor, Motor, ColorSensor};
use ev3dev_rs::robotics::DriveBase;
use ev3dev_rs::parameters::{MotorPort, MotorPort, Direction}
#[tokio::main]
async fn main() -> Ev3Result<()> {
use ev3dev_rs::parameters::{Direction, SensorPort};
let left_motor = Motor::new(MotorPort::OutA, Direction::Clockwise)?;
let right_motor = Motor::new(MotorPort::OutD, Direction::Clockwise)?;
let gyro_sensor = GyroSensor::new(SensorPort::In1)?;
let color_sensor = ColorSensor::new(SensorPort::In4)?;
println!("Detected color: {}", color_sensor.color()?);
let drive = DriveBase::new(&left_motor, &right_motor, 62.4, 130.5)?.with_gyro(&gyro_sensor)?;
drive.use_gyro(true)?;
drive.straight(500).await?;
drive.turn(90).await?;
drive.curve(600, 90).await?;
drive.veer(600, 500).await?;
Ok(())
}
extern crate ev3dev_rs;
extern crate tokio;
use ev3dev_rs::pupdevices::{GyroSensor, Motor, ColorSensor};
use ev3dev_rs::robotics::DriveBase;
use ev3dev_rs::parameters::{MotorPort, MotorPort}
#[tokio::main]
async fn main() -> Ev3Result<()> {
use ev3dev_rs::parameters::{Direction, SensorPort};
let left_motor = Motor::new(MotorPort::OutA, Direction::Clockwise)?;
let right_motor = Motor::new(MotorPort::OutD, Direction::Clockwise)?;
let gyro_sensor = GyroSensor::new(SensorPort::In1)?;
let mut drive = DriveBase::new(&left, &right, 62.4, 130.5)?.with_gyro(&gyro)?;
drive.use_gyro(true)?;
drive.find_calibrated_axle_track(50).await?;
Ok(())
}