2022-01-11 11:05:52 -07:00
// Copyright (c) FIRST and other WPILib contributors.
// Open Source Software; you can modify and/or share it under the terms of
// the WPILib BSD license file in the root directory of this project.
2021-11-15 16:26:16 -07:00
package frc4388.robot ;
2022-03-24 19:08:24 -06:00
import java.io.File ;
import java.nio.file.Files ;
import java.nio.file.StandardOpenOption ;
2022-02-10 21:18:00 -07:00
import java.util.ArrayList ;
2022-03-24 19:08:24 -06:00
import java.util.Arrays ;
2022-02-27 22:59:32 -07:00
import java.util.Objects ;
2022-02-15 11:05:59 -07:00
import java.util.logging.Logger ;
2022-01-21 16:50:26 -07:00
2022-03-24 19:08:24 -06:00
import com.diffplug.common.base.Errors ;
2022-01-29 14:39:46 -07:00
import com.pathplanner.lib.PathPlanner ;
2022-02-04 19:02:41 -07:00
import com.pathplanner.lib.PathPlannerTrajectory ;
2022-02-07 19:49:27 -07:00
import com.pathplanner.lib.PathPlannerTrajectory.PathPlannerState ;
2022-02-04 19:02:41 -07:00
import com.pathplanner.lib.commands.PPSwerveControllerCommand ;
2022-01-29 14:39:46 -07:00
import edu.wpi.first.math.controller.PIDController ;
import edu.wpi.first.math.controller.ProfiledPIDController ;
2022-01-22 15:55:04 -07:00
import edu.wpi.first.math.geometry.Pose2d ;
2022-01-29 14:39:46 -07:00
import edu.wpi.first.math.geometry.Rotation2d ;
2022-03-24 19:08:24 -06:00
import edu.wpi.first.util.sendable.Sendable ;
import edu.wpi.first.util.sendable.SendableBuilder ;
import edu.wpi.first.wpilibj.Filesystem ;
2022-02-11 18:53:13 -07:00
import edu.wpi.first.wpilibj.GenericHID ;
2022-01-29 01:16:58 -07:00
import edu.wpi.first.wpilibj.XboxController ;
2022-03-24 19:08:24 -06:00
import edu.wpi.first.wpilibj.shuffleboard.BuiltInLayouts ;
import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard ;
import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardLayout ;
2022-03-24 13:59:59 -06:00
import edu.wpi.first.wpilibj.smartdashboard.SendableChooser ;
2022-02-16 22:31:00 -07:00
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard ;
2021-11-15 16:26:16 -07:00
import edu.wpi.first.wpilibj2.command.Command ;
2022-02-03 20:53:43 -07:00
import edu.wpi.first.wpilibj2.command.InstantCommand ;
2022-03-22 22:10:46 -06:00
import edu.wpi.first.wpilibj2.command.ParallelCommandGroup ;
2021-11-15 16:26:16 -07:00
import edu.wpi.first.wpilibj2.command.RunCommand ;
2022-02-03 20:53:43 -07:00
import edu.wpi.first.wpilibj2.command.SequentialCommandGroup ;
2021-11-15 16:26:16 -07:00
import edu.wpi.first.wpilibj2.command.button.JoystickButton ;
2022-02-11 18:53:13 -07:00
import frc4388.robot.Constants.OIConstants ;
2022-03-05 22:57:55 -07:00
import frc4388.robot.Constants.StorageConstants ;
2022-02-11 18:59:00 -07:00
import frc4388.robot.Constants.SwerveDriveConstants ;
2022-03-08 16:31:42 -07:00
import frc4388.robot.commands.PathRecorder ;
2022-03-22 22:10:46 -06:00
import frc4388.robot.commands.RunCommandForTime ;
2022-03-21 22:49:54 -06:00
import frc4388.robot.commands.DriveCommands.DriveWithInputForTime ;
2022-03-14 20:10:12 -06:00
import frc4388.robot.commands.ExtenderIntakeCommands.ExtenderIntakeGroup ;
import frc4388.robot.commands.ShooterCommands.TrackTarget ;
2022-01-20 18:08:05 -07:00
import frc4388.robot.subsystems.BoomBoom ;
2022-03-22 17:41:02 -06:00
import frc4388.robot.subsystems.Claws ;
2022-03-10 16:47:32 -07:00
import frc4388.robot.subsystems.Climber ;
2022-03-12 15:05:32 -07:00
import frc4388.robot.subsystems.Extender ;
2022-01-20 18:08:05 -07:00
import frc4388.robot.subsystems.Hood ;
2022-03-05 15:32:48 -07:00
import frc4388.robot.subsystems.Intake ;
2022-01-15 14:20:49 -07:00
import frc4388.robot.subsystems.Serializer ;
2022-02-26 15:41:54 -07:00
import frc4388.robot.subsystems.Storage ;
2021-12-02 17:51:06 -07:00
import frc4388.robot.subsystems.SwerveDrive ;
2022-01-20 18:08:05 -07:00
import frc4388.robot.subsystems.Turret ;
2022-03-05 11:29:40 -07:00
import frc4388.robot.subsystems.VisionOdometry ;
2022-03-24 00:30:25 -06:00
import frc4388.utility.Vector2D ;
2022-03-12 17:33:38 -07:00
import frc4388.utility.controller.ButtonBox ;
2022-03-22 19:48:40 -06:00
import frc4388.utility.controller.DeadbandedXboxController ;
2021-11-15 16:26:16 -07:00
/**
* This class is where the bulk of the robot should be declared. Since
* Command-based is a "declarative" paradigm, very little robot logic should
* actually be handled in the {@link Robot} periodic methods (other than the
* scheduler calls). Instead, the structure of the robot (including subsystems,
* commands, and button mappings) should be declared here.
*/
public class RobotContainer {
2022-02-25 01:33:32 -07:00
private static final Logger LOGGER = Logger . getLogger ( RobotContainer . class . getSimpleName ( ) ) ;
2022-03-14 20:10:12 -06:00
// RobotMap
2022-03-07 15:26:05 -07:00
public final RobotMap m_robotMap = new RobotMap ( ) ;
2022-01-11 11:05:52 -07:00
2022-03-11 23:25:05 -07:00
/* Subsystems */
2022-03-20 18:09:16 -06:00
public final Climber m_robotClimber = new Climber ( m_robotMap . elbow ) ;
2022-03-18 14:13:37 -06:00
public final Claws m_robotClaws = new Claws ( m_robotMap . leftClaw , m_robotMap . rightClaw ) ;
2022-03-05 15:32:48 -07:00
public final SwerveDrive m_robotSwerveDrive = new SwerveDrive ( m_robotMap . leftFront , m_robotMap . leftBack , m_robotMap . rightFront , m_robotMap . rightBack , m_robotMap . gyro ) ;
2022-03-07 15:26:05 -07:00
public final Serializer m_robotSerializer = new Serializer ( m_robotMap . serializerBelt , /*m_robotMap.serializerShooterBelt,*/ m_robotMap . serializerBeam ) ;
2022-03-14 20:10:12 -06:00
public final Intake m_robotIntake = new Intake ( m_robotMap . intakeMotor ) ;
2022-03-12 15:05:32 -07:00
public final Extender m_robotExtender = new Extender ( m_robotMap . extenderMotor ) ;
2022-03-05 22:57:55 -07:00
2022-03-07 15:26:05 -07:00
public final Storage m_robotStorage = new Storage ( m_robotMap . storageMotor ) ;
2022-03-06 11:14:30 -07:00
// private final LED m_robotLED = new LED(m_robotMap.LEDController);
2022-03-07 15:26:05 -07:00
public final BoomBoom m_robotBoomBoom = new BoomBoom ( m_robotMap . shooterFalconLeft , m_robotMap . shooterFalconRight ) ;
public final Hood m_robotHood = new Hood ( m_robotMap . angleAdjusterMotor ) ;
public final Turret m_robotTurret = new Turret ( m_robotMap . shooterTurret ) ;
2022-03-13 19:59:55 -06:00
public final VisionOdometry m_robotVisionOdometry = new VisionOdometry ( m_robotSwerveDrive , m_robotTurret ) ;
2022-01-11 11:05:52 -07:00
2022-03-01 20:23:01 -07:00
/* Autonomous */
2022-03-08 16:31:42 -07:00
private final PathRecorder m_pathChooser = new PathRecorder ( m_robotSwerveDrive ) ;
2022-03-14 20:10:12 -06:00
// Controllers
2022-03-22 19:48:40 -06:00
private final static XboxController m_driverXbox = new DeadbandedXboxController ( OIConstants . XBOX_DRIVER_ID ) ;
private final static XboxController m_operatorXbox = new DeadbandedXboxController ( OIConstants . XBOX_OPERATOR_ID ) ;
2022-03-12 19:02:37 -07:00
private final ButtonBox m_buttonBox = new ButtonBox ( OIConstants . BUTTON_BOX_ID ) ;
2022-03-12 17:43:17 -07:00
2022-03-12 22:19:42 -07:00
public static boolean softLimits = true ;
2022-03-18 17:18:39 -06:00
2022-03-18 17:39:06 -06:00
// control mode switching
2022-03-18 18:29:53 -06:00
public static enum ControlMode { SHOOTER , CLIMBER } ;
public static ControlMode currentControlMode = ControlMode . SHOOTER ;
2022-03-18 17:18:39 -06:00
2022-03-18 17:39:06 -06:00
// turret mode switching
private enum TurretMode { MANUAL , AUTONOMOUS } ;
private TurretMode currentTurretMode = TurretMode . MANUAL ;
// climber mode switching
2022-03-18 17:18:39 -06:00
private enum ClimberMode { MANUAL , AUTONOMOUS } ;
private ClimberMode currentClimberMode = ClimberMode . MANUAL ;
2022-02-16 22:31:00 -07:00
2022-03-24 19:17:41 -06:00
private enum DriveMode { ON , OFF } ;
private DriveMode currentDriveMode = DriveMode . ON ;
2022-03-24 16:58:29 -06:00
private SendableChooser < SequentialCommandGroup > quickAutoChooser = new SendableChooser < > ( ) ;
2022-03-24 13:59:59 -06:00
2022-03-24 08:49:37 -06:00
/**
* SmartDash
* - Limelight cam X
* - Limit switches X
* - Shooter RPM X
* - Distance to target x
* - target locked
* - claws boolean
* - field
*/
2022-03-24 15:41:08 -06:00
// private SequentialCommandGroup makeTheWeirdGroup() {
// SequentialCommandGroup weirdAutoShootingGroup = new SequentialCommandGroup(new TrackTarget(m_robotTurret, m_robotBoomBoom, m_robotHood, m_robotVisionOdometry, true),
// new ParallelCommandGroup(
// new TrackTarget(m_robotTurret, m_robotBoomBoom, m_robotHood, m_robotVisionOdometry, true),
// new RunCommandForTime(new RunCommand(() -> m_robotStorage.runStorage(StorageConstants.STORAGE_SPEED), m_robotStorage), 2.0)
// )); // * weird way of shooting, i think we should make a new TrackTarget with built-in Storage control instead.
// return weirdAutoShootingGroup;
// }
2022-01-11 11:05:52 -07:00
/**
* The container for the robot. Contains subsystems, OI devices, and commands.
*/
public RobotContainer ( ) {
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// double turretDistanceFromFront = 10.0; // * distance of turret from the front of the robot in inches. might need to be somewhat accurate.
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// double distancePerSecond = 134.0; // * assuming emulated joystick input magnitude is 1.0
// double offset = 10.0; // * distance (in inches) from ball that we actually want to stop
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// Vector2D firstBallPosition = new Vector2D(15.56 - (82.83 / 2.00), 11.21 - 162.00); // * position of first ball, relative to hub.
// Vector2D secondBallPosition = new Vector2D(-(40.44 * (Math.sqrt(2.00) / 2.00)) - ((82.83 - 7.58) * (Math.sqrt(2.00) / 2.00)) - (82.83 / 2.00), -(40.44 * (Math.sqrt(2.00) / 2.00)) + ((82.83 - 7.58) * (Math.sqrt(2.00) / 2.00)) - (219.25 / 2.00)); // * position of second ball, relative to hub.
// Vector2D firstToSecond = Vector2D.subtract(secondBallPosition, firstBallPosition); // * vector from first ball to second ball, used to calculate emulated joystick inputs.
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// var justShoot = new SequentialCommandGroup( new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2((219.25 / 2.00) - turretDistanceFromFront, (82.83 / 2.00) - 15.56)), m_robotTurret), 1.0, true), // * aim with turret to target
// makeTheWeirdGroup(), // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage)); // * stop running storage
// // ! SHOOT FIRST BALL, THEN DRIVE OFF LINE (HOPEFULLY)
// var offTheLine = new SequentialCommandGroup( new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2((219.25 / 2.00) - turretDistanceFromFront, (82.83 / 2.00) - 15.56)), m_robotTurret), 1.0, true), // * aim with turret to target
// makeTheWeirdGroup(), // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage), // * stop running storage
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new SequentialCommandGroup( new InstantCommand(() -> m_robotSwerveDrive.resetGyro(), m_robotSwerveDrive), // * reset gyro before moving
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 1.0, 0.0, 0.0}, 0.25))); // * drive off line
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// // ! TWO BALL AUTO (HOPEFULLY)
// var twoBall = new SequentialCommandGroup( new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2((219.25 / 2.00) - turretDistanceFromFront, (82.83 / 2.00) - 15.56)), m_robotTurret), 1.0, true), // * aim with turret to target
// makeTheWeirdGroup(), // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage), // * stop running storage
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new ExtenderIntakeGroup(m_robotIntake, m_robotExtender), // * extend out, in preparation of running intake
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new ParallelCommandGroup( new RunCommand(() -> m_robotIntake.runAtOutput(1.0), m_robotIntake), // * run intake all throughout path
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new SequentialCommandGroup( new InstantCommand(() -> m_robotSwerveDrive.resetGyro(), m_robotSwerveDrive), // * reset gyro before moving
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 1.0, 0.0, 0.0}, (40.44 - offset) / distancePerSecond), // * drive to first ball
// // new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, -1.0, 0.0, 0.0, true)), // * brake (see line 376),
// new InstantCommand(() -> m_robotSwerveDrive.stopModules(), m_robotSwerveDrive),
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2(firstBallPosition.y, firstBallPosition.x)), m_robotTurret), 1.0, true), // * aim with turret to target
// makeTheWeirdGroup(), // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage)))); // * stop running storage
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// // ! THREE BALL AUTO (HOPEFULLY)
// var threeBall = new SequentialCommandGroup( new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2((219.25 / 2.00) - turretDistanceFromFront, (82.83 / 2.00) - 15.56)), m_robotTurret), 1.0, true), // * aim with turret to target
// makeTheWeirdGroup(), // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage), // * stop running storage
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new ExtenderIntakeGroup(m_robotIntake, m_robotExtender), // * extend out, in preparation of running intake
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new ParallelCommandGroup( new RunCommand(() -> m_robotIntake.runAtOutput(1.0), m_robotIntake), // * run intake all throughout path
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new SequentialCommandGroup( new InstantCommand(() -> m_robotSwerveDrive.resetGyro(), m_robotSwerveDrive), // * reset gyro before moving
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 1.0, 0.0, 0.0}, (40.44 - offset) / distancePerSecond), // * drive to first ball
// //new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, -1.0, 0.0, 0.0, true)), // * brake (see line 363)
// new InstantCommand(() -> m_robotSwerveDrive.stopModules(), m_robotSwerveDrive),
// new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2(firstBallPosition.y, firstBallPosition.x)), m_robotTurret), 1.0, true), // * aim with turret to target
// makeTheWeirdGroup(), // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage), // * stop running storage
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// //new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, 0.0, -firstToSecond.unit().x, -firstToSecond.unit().y, true), m_robotSwerveDrive), // * rotate so intake points towards second ball
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 0.0, -firstToSecond.unit().x, -firstToSecond.unit().y}, 0.5d),
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {-firstToSecond.unit().x, -firstToSecond.unit().y, 0.0, 0.0}, (firstToSecond.magnitude() - offset) / distancePerSecond), // * drive to second ball
// //new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(firstToSecond.unit().x, firstToSecond.unit().y, 0.0, 0.0, true)), // * brake (see line 363)
// new InstantCommand(() -> m_robotSwerveDrive.stopModules(), m_robotSwerveDrive),
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// new Shoot(m_robotSwerveDrive, m_robotBoomBoom, m_robotTurret, m_robotHood, m_robotVisionOdometry, secondBallPosition.toDoubleArray()), // * aim to target
// makeTheWeirdGroup(), // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage) // * stop running storage
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// )));
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// autoChoices = Map.of(
// "justShoot", justShoot,
// "offTheLine", offTheLine,
// "twoBall", twoBall,
// "threeBall", threeBall
// );
2022-03-24 13:59:59 -06:00
2022-03-24 15:41:08 -06:00
// SmartDashboard.putData(quickAutoChooser);
2022-03-24 13:59:59 -06:00
2022-01-11 11:05:52 -07:00
configureButtonBindings ( ) ;
/* Default Commands */
2022-03-20 20:18:02 -06:00
// Swerve Drive with Input
2022-03-07 15:26:05 -07:00
m_robotSwerveDrive . setDefaultCommand (
2022-03-20 00:50:01 -06:00
new RunCommand ( ( ) - > {
2022-03-24 19:17:41 -06:00
if ( currentDriveMode . equals ( DriveMode . ON ) ) {
2022-03-20 00:50:01 -06:00
m_robotSwerveDrive . driveWithInput ( getDriverController ( ) . getLeftX ( ) ,
getDriverController ( ) . getLeftY ( ) ,
getDriverController ( ) . getRightX ( ) ,
getDriverController ( ) . getRightY ( ) ,
2022-03-20 20:18:02 -06:00
true ) ; }
2022-03-24 19:17:41 -06:00
if ( currentDriveMode . equals ( DriveMode . OFF ) ) {
2022-03-20 20:18:02 -06:00
m_robotSwerveDrive . driveWithInput ( 0 ,
0 ,
0 ,
0 ,
2022-03-24 19:17:41 -06:00
false ) ;
2022-03-20 20:18:02 -06:00
} }
2022-03-20 00:50:01 -06:00
, m_robotSwerveDrive ) . withName ( " Swerve driveWithInput defaultCommand " ) ) ;
2022-03-18 17:18:39 -06:00
2022-03-20 20:18:02 -06:00
// Intake with Triggers
2022-03-05 22:57:55 -07:00
m_robotIntake . setDefaultCommand (
new RunCommand ( ( ) - > m_robotIntake . runWithTriggers (
2022-03-07 15:26:05 -07:00
getOperatorController ( ) . getLeftTriggerAxis ( ) ,
getOperatorController ( ) . getRightTriggerAxis ( ) ) ,
2022-03-05 22:57:55 -07:00
m_robotIntake ) . withName ( " Intake runWithTriggers defaultCommand " ) ) ;
2022-03-20 00:16:49 -06:00
m_robotBoomBoom . setDefaultCommand ( new RunCommand ( ( ) - > m_robotBoomBoom . runDrumShooter ( 0 . 0 ) , m_robotBoomBoom ) ) ;
2022-03-18 17:18:39 -06:00
2022-03-20 20:18:02 -06:00
// Serializer Manual
2022-03-08 16:14:34 -07:00
m_robotSerializer . setDefaultCommand (
2022-03-18 15:09:08 -06:00
new RunCommand ( ( ) - > m_robotSerializer . setSerializer ( getOperatorController ( ) . getLeftTriggerAxis ( ) * 0 . 8 ) , //m_robotSerializer.setSerializerStateWithBeam(),
2022-03-08 16:14:34 -07:00
m_robotSerializer ) . withName ( " Serializer setSerializerStateWithBeam defaultCommand " ) ) ;
2022-03-20 00:16:49 -06:00
2022-03-20 20:18:02 -06:00
// Turret Manual
2022-03-20 00:16:49 -06:00
m_robotTurret . setDefaultCommand (
new RunCommand ( ( ) - > {
2022-03-20 12:09:41 -06:00
if ( RobotContainer . currentControlMode . equals ( ControlMode . SHOOTER ) ) { m_robotTurret . runTurretWithInput ( getOperatorController ( ) . getLeftX ( ) ) ; }
if ( RobotContainer . currentControlMode . equals ( ControlMode . CLIMBER ) ) { m_robotTurret . runTurretWithInput ( 0 ) ; }
2022-03-20 00:16:49 -06:00
} , m_robotTurret ) ) ;
2022-03-18 23:56:01 -06:00
2022-03-20 20:18:02 -06:00
// Hood Manual
2022-03-18 23:56:01 -06:00
m_robotHood . setDefaultCommand (
new RunCommand ( ( ) - > {
2022-03-20 12:09:41 -06:00
if ( RobotContainer . currentControlMode . equals ( ControlMode . SHOOTER ) ) { m_robotHood . runHood ( getOperatorController ( ) . getRightY ( ) ) ; }
if ( RobotContainer . currentControlMode . equals ( ControlMode . CLIMBER ) ) { m_robotHood . runHood ( 0 ) ; }
2022-03-18 23:56:01 -06:00
} , m_robotHood ) ) ;
2022-03-20 20:18:02 -06:00
//Climber Manual
2022-03-20 00:16:49 -06:00
m_robotClimber . setDefaultCommand (
2022-03-20 20:18:02 -06:00
new RunCommand ( ( ) - > {
if ( RobotContainer . currentControlMode . equals ( ControlMode . SHOOTER ) ) { m_robotClimber . setMotors ( 0 . 0 ) ; }
2022-03-24 13:30:36 -06:00
if ( RobotContainer . currentControlMode . equals ( ControlMode . CLIMBER ) ) { m_robotClimber . setMotors ( - getOperatorController ( ) . getRightY ( ) ) ; }
2022-03-20 20:18:02 -06:00
} , m_robotClimber ) ) ;
2022-03-21 20:00:34 -06:00
m_robotBoomBoom . setDefaultCommand (
2022-03-22 17:07:06 -06:00
new RunCommand ( ( ) - > m_robotBoomBoom . runDrumShooter ( 0 . 45 ) , m_robotBoomBoom )
2022-03-21 20:00:34 -06:00
) ;
2022-03-22 17:41:02 -06:00
2022-03-24 19:08:24 -06:00
if ( m_robotBoomBoom . readManualData ) {
var tab = Shuffleboard . getTab ( " Manual Shooter Data " ) ;
var manual = tab . getLayout ( " Manual Shooter Data " , BuiltInLayouts . kList ) . withSize ( 2 , 3 ) ;
manual . add ( " Manual Shooter Data " , new Sendable ( ) {
private double manualHoodExt ;
private double manualDrumVel ;
@Override
public void initSendable ( SendableBuilder builder ) {
builder . setSmartDashboardType ( " RobotPreferences " ) ;
builder . addBooleanProperty ( " Disable CSV " , ( ) - > m_robotBoomBoom . readManualData , b - > m_robotBoomBoom . readManualData = b ) ;
builder . addDoubleProperty ( " Drum Velocity " , ( ) - > manualDrumVel , d - > manualDrumVel = d ) ;
builder . addDoubleProperty ( " Hood Extension " , ( ) - > manualHoodExt , d - > manualHoodExt = d ) ;
builder . addDoubleProperty ( " Measured Distance " , ( ) - > SmartDashboard . getNumber ( " Distance to Target " , - 1 ) , System . out : : println ) ;
}
} ) ;
manual . add ( " Shooter Table Appender " , new InstantCommand ( ( ) - > Errors . log ( ) . run ( ( ) - > Files . write ( new File ( Filesystem . getDeployDirectory ( ) , " ShooterData.csv " ) . toPath ( ) , String . format ( " %s,%s,%s%n " , SmartDashboard . getNumber ( " Manual Shooter Data/Distance to Target " , - 1 ) , SmartDashboard . getNumber ( " Manual Shooter Data/Hood Extension " , - 1 ) , SmartDashboard . getNumber ( " Manual Shooter Data/Drum Velocity " , - 1 ) ) . getBytes ( ) , StandardOpenOption . WRITE , StandardOpenOption . APPEND ) ) ) {
@Override
public boolean runsWhenDisabled ( ) {
return true ;
}
} . withName ( " Append " ) ) ;
var csv = tab . getLayout ( " Shooter Data " , BuiltInLayouts . kList ) . withPosition ( 2 , 0 ) . withSize ( 4 , 3 ) ;
csv . add ( " Initial Shooter Data " , builder - > Arrays . stream ( m_robotBoomBoom . m_shooterTable ) . forEach ( e - > builder . addDoubleArrayProperty ( Double . toString ( e . distance ) , ( ) - > new double [ ] { e . hoodExt , e . drumVelocity } , a - > { } ) ) ) ;
csv . add ( " Reload Data " , new InstantCommand ( m_robotBoomBoom : : updateShooterTable ) {
@Override
public boolean runsWhenDisabled ( ) {
return true ;
}
} . withName ( " Reload " ) ) ;
}
2022-01-11 11:05:52 -07:00
}
2022-01-15 11:31:15 -07:00
2022-01-11 11:05:52 -07:00
/**
* Use this method to define your button->command mappings. Buttons can be
* created by instantiating a {@link GenericHID} or one of its subclasses
* ({@link edu.wpi.first.wpilibj.Joystick} or {@link XboxController}), and then
* passing it to a {@link edu.wpi.first.wpilibj2.command.button.JoystickButton}.
*/
private void configureButtonBindings ( ) {
2022-03-20 20:18:02 -06:00
//! Driver Buttons
2022-01-11 11:05:52 -07:00
2022-03-06 00:48:38 -07:00
// Start > Calibrate Odometry
2022-03-06 11:23:40 -07:00
new JoystickButton ( getDriverController ( ) , XboxController . Button . kBack . value )
2022-03-06 00:48:38 -07:00
. whenPressed ( ( ) - > resetOdometry ( new Pose2d ( 0 , 0 , new Rotation2d ( 0 ) ) ) ) ;
2022-03-20 20:18:02 -06:00
// Start > Calibrate Odometry
2022-03-06 11:23:40 -07:00
new JoystickButton ( getDriverController ( ) , XboxController . Button . kStart . value )
2022-03-20 20:18:02 -06:00
. whenPressed ( m_robotSwerveDrive : : resetGyro ) ;
2022-03-06 00:48:38 -07:00
// Left Bumper > Shift Down
2022-03-18 13:04:20 -06:00
new JoystickButton ( getDriverController ( ) , XboxController . Button . kLeftBumper . value )
. whenPressed ( ( ) - > m_robotSwerveDrive . highSpeed ( false ) ) ;
2022-03-20 20:18:02 -06:00
2022-03-18 13:04:20 -06:00
// Right Bumper > Shift Up
2022-03-18 23:11:30 -06:00
new JoystickButton ( getDriverController ( ) , XboxController . Button . kRightBumper . value )
. whenPressed ( ( ) - > m_robotSwerveDrive . highSpeed ( true ) ) ;
2022-03-20 18:09:16 -06:00
2022-03-20 16:22:11 -06:00
2022-03-20 20:18:02 -06:00
//! Operator Buttons
// Right Bumper > Storage Out
new JoystickButton ( getOperatorController ( ) , XboxController . Button . kRightBumper . value )
. whileHeld ( new RunCommand ( ( ) - > m_robotStorage . runStorage ( - StorageConstants . STORAGE_SPEED ) ) )
. whenReleased ( new RunCommand ( ( ) - > m_robotStorage . runStorage ( 0 . 0 ) ) ) ;
// Left Bumper > Storage In
new JoystickButton ( getOperatorController ( ) , XboxController . Button . kLeftBumper . value )
. whileHeld ( new RunCommand ( ( ) - > m_robotStorage . runStorage ( StorageConstants . STORAGE_SPEED ) ) )
. whenReleased ( new RunCommand ( ( ) - > m_robotStorage . runStorage ( 0 . 0 ) ) ) ;
// B > Toggle claws
2022-03-20 16:22:11 -06:00
new JoystickButton ( getOperatorController ( ) , XboxController . Button . kB . value )
2022-03-20 20:52:05 -06:00
. whenPressed ( new InstantCommand ( ( ) - > m_robotClaws . toggleClaws ( ) , m_robotClaws ) ) ;
2022-03-20 14:25:38 -06:00
2022-03-20 20:18:02 -06:00
// X > Toggles extender in and out
2022-03-21 20:00:34 -06:00
new JoystickButton ( getOperatorController ( ) , XboxController . Button . kX . value )
. whenPressed ( new ExtenderIntakeGroup ( m_robotIntake , m_robotExtender ) ) ;
2022-03-16 20:16:32 -06:00
2022-03-20 20:18:02 -06:00
// A > Spit Out Ball
new JoystickButton ( getOperatorController ( ) , XboxController . Button . kA . value )
2022-03-20 20:52:05 -06:00
. whileHeld ( new RunCommand ( ( ) - > m_robotTurret . gotoMidpoint ( ) , m_robotTurret ) )
2022-03-20 20:18:02 -06:00
. whileHeld ( new RunCommand ( ( ) - > m_robotBoomBoom . runDrumShooter ( 0 . 25 ) ) ) ;
// Y > Full aim command
2022-03-14 15:16:21 -06:00
// new JoystickButton(getOperatorController(), XboxController.Button.kY.value)
2022-03-20 21:21:45 -06:00
// .whileHeld(new Seek(m_robotSwerveDrive, m_robotBoomBoom, m_robotTurret, m_robotHood, m_robotVisionOdometry));
//! Test Buttons
2022-03-21 20:00:34 -06:00
// new JoystickButton(getOperatorController(), XboxController.Button.kY.value)
// .whenPressed(new Shoot(m_robotSwerveDrive, m_robotBoomBoom, m_robotTurret, m_robotHood, m_robotVisionOdometry, false, false));
2022-03-20 20:18:02 -06:00
2022-03-21 20:00:34 -06:00
new JoystickButton ( getOperatorController ( ) , XboxController . Button . kY . value )
2022-03-24 15:41:08 -06:00
. whileHeld ( new TrackTarget ( m_robotTurret , m_robotBoomBoom , m_robotHood , m_robotVisionOdometry ) ) ;
2022-03-05 22:57:55 -07:00
2022-03-20 20:18:02 -06:00
// new JoystickButton(getOperatorController(), XboxController.Button.kY.value)
// .whileHeld(new RunCommand(() -> m_robotClaws.setOpen(true)));
2022-03-05 22:57:55 -07:00
2022-03-20 20:18:02 -06:00
// new JoystickButton(getOperatorController(), XboxController.Button.kB.value)
// .whileHeld(new RunCommand(() -> m_robotClaws.setOpen(false)));
2022-03-05 22:57:55 -07:00
2022-03-20 20:18:02 -06:00
// new JoystickButton(getOperatorController(), XboxController.Button.kA.value)
// .whenPressed(new Shoot(m_robotSwerveDrive, m_robotBoomBoom, m_robotTurret, m_robotHood));
2022-03-13 17:57:36 -06:00
2022-03-20 20:18:02 -06:00
// new JoystickButton(getOperatorController(), XboxController.Button.kA.value)
// .whenPressed(new RunCommand(() -> m_robotBoomBoom.runDrumShooter(0.25)))
// .whenReleased(new RunCommand(() -> m_robotBoomBoom.runDrumShooter(0.0)));
2022-03-10 16:47:32 -07:00
2022-03-05 22:57:55 -07:00
2022-03-20 20:18:02 -06:00
//! Button Box Buttons
// Left Switch > Disables soft limits on press, release resets encoders (all for turret, hood, climber, and extender)
2022-03-12 19:02:37 -07:00
new JoystickButton ( getButtonBox ( ) , ButtonBox . Button . kLeftSwitch . value )
2022-03-20 20:18:02 -06:00
. whenPressed ( new InstantCommand ( ( ) - > m_robotTurret . setTurretSoftLimits ( false ) , m_robotTurret ) )
. whenPressed ( new InstantCommand ( ( ) - > m_robotTurret . calibrationSpeed = 0 . 3 , m_robotTurret ) )
2022-03-19 21:03:01 -06:00
2022-03-20 20:18:02 -06:00
. whenPressed ( new InstantCommand ( ( ) - > m_robotHood . setHoodSoftLimits ( false ) , m_robotHood ) )
. whenPressed ( new InstantCommand ( ( ) - > m_robotHood . calibrationSpeed = 0 . 3 , m_robotHood ) )
2022-03-19 21:03:01 -06:00
2022-03-20 20:18:02 -06:00
. whenPressed ( new InstantCommand ( ( ) - > m_robotExtender . setExtenderSoftLimits ( false ) , m_robotExtender ) )
2022-03-19 21:03:01 -06:00
2022-03-20 20:18:02 -06:00
. whenReleased ( new InstantCommand ( ( ) - > m_robotTurret . setTurretSoftLimits ( true ) , m_robotTurret ) )
. whenReleased ( new InstantCommand ( ( ) - > m_robotTurret . calibrationSpeed = 1 . 0 , m_robotTurret ) )
2022-03-19 21:03:01 -06:00
2022-03-20 20:18:02 -06:00
. whenReleased ( new InstantCommand ( ( ) - > m_robotHood . setHoodSoftLimits ( true ) , m_robotHood ) )
. whenReleased ( new InstantCommand ( ( ) - > m_robotHood . calibrationSpeed = 1 . 0 , m_robotHood ) )
2022-03-19 21:03:01 -06:00
2022-03-20 20:18:02 -06:00
. whenReleased ( new InstantCommand ( ( ) - > m_robotExtender . setExtenderSoftLimits ( true ) , m_robotExtender ) )
2022-03-06 00:24:51 -07:00
2022-03-20 20:18:02 -06:00
. whenReleased ( new InstantCommand ( ( ) - > m_robotTurret . m_boomBoomRotateEncoder . setPosition ( 0 ) , m_robotTurret ) )
. whenReleased ( new InstantCommand ( ( ) - > m_robotHood . m_angleEncoder . setPosition ( 0 ) , m_robotHood ) )
. whenReleased ( new InstantCommand ( ( ) - > m_robotExtender . setEncoder ( 0 ) , m_robotExtender ) )
. whenReleased ( new InstantCommand ( ( ) - > ExtenderIntakeGroup . setDirectionToOut ( ) , m_robotIntake , m_robotExtender ) )
. whenReleased ( new InstantCommand ( ( ) - > m_robotClimber . setEncoders ( 0 ) , m_robotClimber ) ) ;
2022-03-12 17:33:38 -07:00
2022-03-20 20:18:02 -06:00
// Middle Switch > Climber and Shooter mode switching
2022-03-18 17:37:11 -06:00
new JoystickButton ( getButtonBox ( ) , ButtonBox . Button . kMiddleSwitch . value )
2022-03-24 19:17:41 -06:00
. whenPressed ( new InstantCommand ( ( ) - > RobotContainer . currentControlMode = ControlMode . CLIMBER ) )
. whenReleased ( new InstantCommand ( ( ) - > RobotContainer . currentControlMode = ControlMode . SHOOTER ) ) ;
// Right Switch > Drive On vs Off mode switching
2022-03-24 10:38:13 -06:00
new JoystickButton ( getButtonBox ( ) , ButtonBox . Button . kRightSwitch . value )
2022-03-24 19:17:41 -06:00
. whileHeld ( new InstantCommand ( ( ) - > currentDriveMode = DriveMode . OFF ) )
. whenReleased ( new InstantCommand ( ( ) - > currentDriveMode = DriveMode . ON ) ) ;
2022-03-18 15:09:08 -06:00
2022-03-20 20:18:02 -06:00
// Left Button > Extender In
2022-03-12 19:02:37 -07:00
new JoystickButton ( getButtonBox ( ) , ButtonBox . Button . kLeftButton . value )
2022-03-24 10:38:13 -06:00
. whileHeld ( new RunCommand ( ( ) - > m_robotExtender . runExtender ( 1 . 0 ) , m_robotExtender ) )
2022-03-20 20:18:02 -06:00
. whenReleased ( new RunCommand ( ( ) - > m_robotExtender . runExtender ( 0 . 0 ) , m_robotExtender ) ) ;
2022-03-12 17:33:38 -07:00
2022-03-20 20:18:02 -06:00
// Left Button > Extender Out
2022-03-12 19:02:37 -07:00
new JoystickButton ( getButtonBox ( ) , ButtonBox . Button . kRightButton . value )
2022-03-24 10:38:13 -06:00
. whileHeld ( new RunCommand ( ( ) - > m_robotExtender . runExtender ( - 1 . 0 ) , m_robotExtender ) )
2022-03-20 20:18:02 -06:00
. whenReleased ( new RunCommand ( ( ) - > m_robotExtender . runExtender ( 0 . 0 ) , m_robotExtender ) ) ;
2022-03-12 17:33:38 -07:00
}
2022-01-11 11:05:52 -07:00
2022-03-20 19:31:42 -06:00
/**
* Generate autonomous
* @param maxVel max velocity for the path (null to override default value of 5.0)
* @param maxAccel max acceleration for the path (null to override default value of 5.0)
* @param inputs strings (paths) or commands you want to run (in order)
* @return array of commands
*/
public Command [ ] buildAuto ( Double maxVel , Double maxAccel , Object . . . inputs ) {
maxVel = Objects . requireNonNullElse ( maxVel , SwerveDriveConstants . PATH_MAX_VELOCITY ) ;
maxAccel = Objects . requireNonNullElse ( maxAccel , SwerveDriveConstants . PATH_MAX_ACCELERATION ) ;
ArrayList < Command > commands = new ArrayList < Command > ( ) ;
PIDController xController = SwerveDriveConstants . X_CONTROLLER ;
PIDController yController = SwerveDriveConstants . Y_CONTROLLER ;
ProfiledPIDController thetaController = SwerveDriveConstants . THETA_CONTROLLER ;
thetaController . enableContinuousInput ( - Math . PI , Math . PI ) ;
// parse input
for ( int i = 0 ; i < inputs . length ; i + + ) {
if ( inputs [ i ] instanceof String ) {
PathPlannerTrajectory traj = PathPlanner . loadPath ( inputs [ i ] . toString ( ) , maxVel , maxAccel ) ;
2022-03-21 22:49:54 -06:00
PathPlannerState initState = traj . getInitialState ( ) ;
Pose2d initPose = new Pose2d ( initState . poseMeters . getTranslation ( ) , initState . holonomicRotation ) ;
commands . add ( new InstantCommand ( ( ) - > m_robotSwerveDrive . resetOdometry ( initPose ) , m_robotSwerveDrive ) ) ;
2022-03-20 19:31:42 -06:00
commands . add ( new PPSwerveControllerCommand (
traj ,
m_robotSwerveDrive : : getOdometry ,
m_robotSwerveDrive . m_kinematics ,
xController ,
yController ,
thetaController ,
m_robotSwerveDrive : : setModuleStates ,
m_robotSwerveDrive ) ) ;
}
2022-03-21 22:49:54 -06:00
2022-03-20 19:31:42 -06:00
if ( inputs [ i ] instanceof Command ) {
commands . add ( ( Command ) inputs [ i ] ) ;
}
}
2022-03-21 22:49:54 -06:00
commands . add ( new InstantCommand ( ( ) - > m_robotSwerveDrive . driveWithInput ( 0 , 0 , 0 , 0 , true ) , m_robotSwerveDrive ) ) ;
2022-03-20 19:31:42 -06:00
Command [ ] ret = new Command [ commands . size ( ) ] ;
ret = commands . toArray ( ret ) ;
return ret ;
2022-01-11 11:05:52 -07:00
}
/**
* Use this to pass the autonomous command to the main {@link Robot} class.
*
* @return the command to run in autonomous
*/
2022-02-16 22:31:00 -07:00
public Command getAutonomousCommand ( ) {
2022-03-22 22:22:38 -06:00
// ! ways to not coast
2022-03-24 00:30:25 -06:00
// // * 1. try zero joystick input: new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, 0.0, 0.0, 0.0, false), m_robotSwerveDrive);
2022-03-22 22:22:38 -06:00
// * 2. try opposite joystick input: new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, -1.0, 0.0, 0.0, false), m_robotSwerveDrive);
// * 3a. try permanently setting drive motors to brake, not coast, in RobotMap.java, and ask the driver how it feels.
// * 3b. try to only set the drive motors to brake if in auto mode.
2022-03-24 18:35:33 -06:00
// * 4. try new InstantCommand(() -> m_robotSwerveDrive.stopModules(), m_robotSwerveDrive);
2022-03-22 22:22:38 -06:00
2022-03-24 00:30:25 -06:00
// ! 1.0 input, 1 second: 134 inches
// ! 0.75 input, 1 second: 48 inches
// ? positive leftY went left, negative leftY went right?
2022-03-24 10:42:36 -06:00
// TODO: if line 372 is true, switch joystick inputs accordingly
2022-03-24 16:58:29 -06:00
2022-03-24 15:41:08 -06:00
double turretDistanceFromFront = 10 . 0 ; // * distance of turret from the front of the robot in inches. might need to be somewhat accurate.
2022-03-24 16:58:29 -06:00
2022-03-24 15:41:08 -06:00
double distancePerSecond = 134 . 0 ; // * assuming emulated joystick input magnitude is 1.0
double offset = 10 . 0 ; // * distance (in inches) from ball that we actually want to stop
2022-03-24 16:58:29 -06:00
2022-03-24 18:35:33 -06:00
// ! ball positions are unit tested
2022-03-24 15:41:08 -06:00
Vector2D firstBallPosition = new Vector2D ( 15 . 56 - ( 82 . 83 / 2 . 00 ) , 11 . 21 - 162 . 00 ) ; // * position of first ball, relative to hub.
Vector2D secondBallPosition = new Vector2D ( - ( 40 . 44 * ( Math . sqrt ( 2 . 00 ) / 2 . 00 ) ) - ( ( 82 . 83 - 7 . 58 ) * ( Math . sqrt ( 2 . 00 ) / 2 . 00 ) ) - ( 82 . 83 / 2 . 00 ) , - ( 40 . 44 * ( Math . sqrt ( 2 . 00 ) / 2 . 00 ) ) + ( ( 82 . 83 - 7 . 58 ) * ( Math . sqrt ( 2 . 00 ) / 2 . 00 ) ) - ( 219 . 25 / 2 . 00 ) ) ; // * position of second ball, relative to hub.
Vector2D firstToSecond = Vector2D . subtract ( secondBallPosition , firstBallPosition ) ; // * vector from first ball to second ball, used to calculate emulated joystick inputs.
2022-03-24 16:58:29 -06:00
2022-03-24 17:51:18 -06:00
SequentialCommandGroup weirdAutoShootingGroup = new SequentialCommandGroup ( new TrackTarget ( m_robotTurret , m_robotBoomBoom , m_robotHood , m_robotVisionOdometry , true ) ,
new ParallelCommandGroup (
new TrackTarget ( m_robotTurret , m_robotBoomBoom , m_robotHood , m_robotVisionOdometry , true ) ,
new RunCommandForTime ( new RunCommand ( ( ) - > m_robotStorage . runStorage ( StorageConstants . STORAGE_SPEED ) , m_robotStorage ) , 2 . 0 )
) ) ; // * weird way of shooting, i think we should make a new TrackTarget with built-in Storage control instead.
2022-03-24 15:41:08 -06:00
2022-03-24 17:51:18 -06:00
// ! DRIVE OFF LINE, THEN SHOOT BALL (HOPEFULLY)
return new SequentialCommandGroup ( new InstantCommand ( ( ) - > m_robotSwerveDrive . resetGyro ( ) , m_robotSwerveDrive ) , // * reset gyro before moving
2022-03-24 18:35:33 -06:00
new DriveWithInputForTime ( m_robotSwerveDrive , new double [ ] { 0 . 0 , 0 . 5 , 0 . 0 , 0 . 0 } , 0 . 5 ) , // * drive out of tarmac
2022-03-24 17:51:18 -06:00
new InstantCommand ( ( ) - > m_robotSwerveDrive . stopModules ( ) , m_robotSwerveDrive ) , // * brake
2022-03-24 18:43:06 -06:00
2022-03-24 18:35:33 -06:00
new RunCommandForTime ( new RunCommand ( ( ) - > m_robotTurret . runShooterRotatePID ( ( 180 . 0 / Math . PI ) * Math . atan2 ( - ( 82 . 83 / 2 . 00 ) + 15 . 56 , - ( 219 . 25 / 2 . 00 ) - 40 . 44 + 10 . 00 ) ) , m_robotTurret ) , 1 . 0 , true ) , // * aim with turret to target
2022-03-24 17:51:18 -06:00
weirdAutoShootingGroup , // * shoot
new InstantCommand ( ( ) - > m_robotStorage . runStorage ( 0 . 0 ) , m_robotStorage ) // * stop running storage
) ;
2022-03-24 15:41:08 -06:00
// ! TWO BALL AUTO (HOPEFULLY)
2022-03-24 18:43:06 -06:00
// return new SequentialCommandGroup( new ExtenderIntakeGroup(m_robotIntake, m_robotExtender), // * extend out, in preparation of running intake
2022-03-24 15:41:08 -06:00
// new ParallelCommandGroup( new RunCommand(() -> m_robotIntake.runAtOutput(1.0), m_robotIntake), // * run intake all throughout path
// new SequentialCommandGroup( new InstantCommand(() -> m_robotSwerveDrive.resetGyro(), m_robotSwerveDrive), // * reset gyro before moving
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 1.0, 0.0, 0.0}, (40.44 - offset) / distancePerSecond), // * drive to first ball
// // new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, -1.0, 0.0, 0.0, true)), // * brake (see line 376),
// new InstantCommand(() -> m_robotSwerveDrive.stopModules(), m_robotSwerveDrive),
2022-03-24 18:43:06 -06:00
// new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID((180.0 / Math.PI) * Math.atan2(-(82.83 / 2.00) + 15.56, -(219.25 / 2.00) - 40.44 + 10.00)), m_robotTurret), 1.0, true), // * aim with turret to target
2022-03-24 15:41:08 -06:00
// weirdAutoShootingGroup, // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage)))); // * stop running storage
// ! THREE BALL AUTO (HOPEFULLY)
// return new SequentialCommandGroup( new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2((219.25 / 2.00) - turretDistanceFromFront, (82.83 / 2.00) - 15.56)), m_robotTurret), 1.0, true), // * aim with turret to target
// weirdAutoShootingGroup, // * shoot
2022-03-24 16:58:29 -06:00
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage), // * stop running storage
2022-03-24 15:41:08 -06:00
// new ExtenderIntakeGroup(m_robotIntake, m_robotExtender), // * extend out, in preparation of running intake
// new ParallelCommandGroup( new RunCommand(() -> m_robotIntake.runAtOutput(1.0), m_robotIntake), // * run intake all throughout path
// new SequentialCommandGroup( new InstantCommand(() -> m_robotSwerveDrive.resetGyro(), m_robotSwerveDrive), // * reset gyro before moving
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 1.0, 0.0, 0.0}, (40.44 - offset) / distancePerSecond), // * drive to first ball
// //new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, -1.0, 0.0, 0.0, true)), // * brake (see line 363)
// new InstantCommand(() -> m_robotSwerveDrive.stopModules(), m_robotSwerveDrive),
// new RunCommandForTime(new RunCommand(() -> m_robotTurret.runShooterRotatePID(-Math.atan2(firstBallPosition.y, firstBallPosition.x)), m_robotTurret), 1.0, true), // * aim with turret to target
// weirdAutoShootingGroup, // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage), // * stop running storage
// //new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, 0.0, -firstToSecond.unit().x, -firstToSecond.unit().y, true), m_robotSwerveDrive), // * rotate so intake points towards second ball
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 0.0, -firstToSecond.unit().x, -firstToSecond.unit().y}, 0.5d),
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {-firstToSecond.unit().x, -firstToSecond.unit().y, 0.0, 0.0}, (firstToSecond.magnitude() - offset) / distancePerSecond), // * drive to second ball
// //new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(firstToSecond.unit().x, firstToSecond.unit().y, 0.0, 0.0, true)), // * brake (see line 363)
// new InstantCommand(() -> m_robotSwerveDrive.stopModules(), m_robotSwerveDrive),
// new Shoot(m_robotSwerveDrive, m_robotBoomBoom, m_robotTurret, m_robotHood, m_robotVisionOdometry, secondBallPosition.toDoubleArray()), // * aim to target
// weirdAutoShootingGroup, // * shoot
// new InstantCommand(() -> m_robotStorage.runStorage(0.0), m_robotStorage) // * stop running storage
// )));
// return new SequentialCommandGroup( new InstantCommand(() -> m_robotSwerveDrive.resetGyro(), m_robotSwerveDrive),
// new DriveWithInputForTime(m_robotSwerveDrive, new double[] {0.0, 1.0, 0.0, 0.0}, 1.0),
// new InstantCommand(() -> m_robotSwerveDrive.driveWithInput(0.0, -1.0, 0.0, 0.0, false), m_robotSwerveDrive),
// new TrackTarget(m_robotTurret, m_robotBoomBoom, m_robotHood, m_robotVisionOdometry, true),
// new ParallelCommandGroup(
// new TrackTarget(m_robotTurret, m_robotBoomBoom, m_robotHood, m_robotVisionOdometry, true),
// new RunCommandForTime(new RunCommand(() -> m_robotStorage.runStorage(StorageConstants.STORAGE_SPEED), m_robotStorage), 1.0))
2022-03-24 16:58:29 -06:00
2022-03-24 15:41:08 -06:00
// );
2022-03-22 22:22:38 -06:00
2022-01-11 11:05:52 -07:00
}
2022-03-20 15:24:48 -06:00
public static XboxController getDriverController ( ) {
2022-01-11 11:05:52 -07:00
return m_driverXbox ;
}
2022-03-21 12:29:03 -06:00
public XboxController getOperatorController ( ) {
return m_operatorXbox ;
}
2022-03-12 19:02:37 -07:00
public ButtonBox getButtonBox ( ) {
return m_buttonBox ;
2022-03-12 17:33:38 -07:00
}
2022-03-12 22:19:42 -07:00
public static void setSoftLimits ( boolean set ) {
softLimits = set ;
}
2022-01-11 11:05:52 -07:00
/**
2022-02-17 19:52:05 -07:00
* Get odometry.
2022-03-05 11:12:33 -07:00
*
2022-02-17 19:52:05 -07:00
* @return Odometry
2022-01-11 11:05:52 -07:00
*/
2022-01-22 15:55:04 -07:00
public Pose2d getOdometry ( ) {
return m_robotSwerveDrive . getOdometry ( ) ;
}
2022-01-24 17:00:06 -07:00
2022-01-11 11:05:52 -07:00
/**
2022-02-17 19:52:05 -07:00
* Set odometry to given pose.
2022-03-05 11:12:33 -07:00
*
2022-02-17 19:52:05 -07:00
* @param pose Pose to set odometry to.
2022-01-11 11:05:52 -07:00
*/
2022-02-05 11:50:49 -07:00
public void resetOdometry ( Pose2d pose ) {
2022-01-29 14:39:46 -07:00
m_robotSwerveDrive . resetOdometry ( pose ) ;
2022-01-24 17:00:06 -07:00
}
2021-11-15 16:26:16 -07:00
}