package org.usfirst.frc.team3501.robot.commands.driving;
+import org.usfirst.frc.team3501.robot.Constants.DeadReckoning;
import org.usfirst.frc.team3501.robot.Constants.Direction;
import org.usfirst.frc.team3501.robot.Robot;
import edu.wpi.first.wpilibj.Timer;
import edu.wpi.first.wpilibj.command.Command;
+/***
+ * This command turns the robot in a specified direction for a specified
+ * duration in seconds.
+ *
+ * pre-condition: robot is on a flat surface
+ *
+ * post-condition: robot has turned in the specified direction for the specified
+ * time
+ *
+ * TODO: test for speed/ time constants for specific angles (ex. 30 degrees, 60
+ * degrees, 90 degrees)
+ *
+ * @author Meryem, Avi, and Sarvesh
+ *
+ */
+
public class TurnForTime extends Command {
- private final double SPEED = 0.5;
private Direction direction;
private double seconds;
private Timer timer;
+ private double speed;
- public TurnForTime(double seconds, Direction direction) {
+ public TurnForTime(double seconds, Direction direction, double speed) {
this.seconds = seconds;
this.direction = direction;
+ this.speed = speed;
+ }
+
+ public TurnForTime(double seconds, Direction direction) {
+ this(seconds, direction, DeadReckoning.DEFAULT_SPEED);
}
@Override
protected void initialize() {
timer = new Timer();
timer.start();
+
+ if (direction == Direction.RIGHT) {
+ Robot.driveTrain.drive(speed, -speed);
+ } else if (direction == Direction.LEFT) {
+ Robot.driveTrain.drive(-speed, speed);
+ }
}
@Override
protected void execute() {
- if (direction == Direction.RIGHT) {
- Robot.driveTrain.setMotorSpeeds(SPEED, -SPEED);
- } else if (direction == Direction.LEFT) {
- Robot.driveTrain.setMotorSpeeds(-SPEED, SPEED);
- }
}
@Override
protected boolean isFinished() {
- if (timer.get() >= seconds)
- return true;
- return false;
+ return (timer.get() >= seconds);
}
@Override
protected void end() {
+ Robot.driveTrain.drive(0, 0);
}
@Override