From 92325aebca6c9d3327089725c91da9d6c3ae93ab Mon Sep 17 00:00:00 2001 From: Antoine PerreaultE Date: Tue, 5 Dec 2023 18:16:33 -0500 Subject: [PATCH 1/2] =?UTF-8?q?Force=201=20=C3=A1=207?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/frc/robot/RobotContainer.java | 37 +++++++------- .../commands/{LancerTest.java => Force1.java} | 7 +-- src/main/java/frc/robot/commands/Force2.java | 22 ++------- src/main/java/frc/robot/commands/Force3.java | 48 +++++++------------ src/main/java/frc/robot/commands/Force4.java | 36 ++++---------- src/main/java/frc/robot/commands/Force5.java | 36 ++++---------- src/main/java/frc/robot/commands/Force6.java | 37 ++++---------- src/main/java/frc/robot/commands/Force7.java | 35 ++++---------- 8 files changed, 86 insertions(+), 172 deletions(-) rename src/main/java/frc/robot/commands/{LancerTest.java => Force1.java} (85%) diff --git a/src/main/java/frc/robot/RobotContainer.java b/src/main/java/frc/robot/RobotContainer.java index 9df979c..6e03240 100644 --- a/src/main/java/frc/robot/RobotContainer.java +++ b/src/main/java/frc/robot/RobotContainer.java @@ -11,12 +11,11 @@ import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardLayout; import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardTab; import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.RunCommand; -import edu.wpi.first.wpilibj2.command.SequentialCommandGroup; import edu.wpi.first.wpilibj2.command.button.CommandJoystick; import edu.wpi.first.wpilibj2.command.button.CommandXboxController; import frc.robot.commands.Avancer; +import frc.robot.commands.Force1; //import frc.robot.commands.Lancer; -import frc.robot.commands.LancerTest; import frc.robot.commands.Force2; import frc.robot.commands.Force3; import frc.robot.commands.Force4; @@ -61,21 +60,27 @@ public class RobotContainer { private void configureBindings() { accumulateurtest accumulateurtest = new accumulateurtest(accumulateur); - LancerTest lancertest = new LancerTest(lanceur); - // joystick1.button(7).onTrue(new Lancer(lanceur, accumulateur, force1)); - /* joystick1.button(8).onTrue(new Lancer(lanceur, accumulateur, force2)); - joystick1.button(9).onTrue(new Lancer(lanceur, accumulateur, force3)); - joystick1.button(10).onTrue(new Lancer(lanceur, accumulateur, force4)); - joystick1.button(11).onTrue(new Lancer(lanceur, accumulateur, force5)); - joystick1.button(12).onTrue(new Lancer(lanceur, accumulateur, force6));*/ - // joystick1.button(3).onTrue(new Lancer(lanceur, accumulateur, force7)); - joystick1.button(5).whileTrue(accumulateurtest); - joystick1.button(1).whileTrue(lancertest); - + Force1 Force1 = new Force1(lanceur, force1); + Force2 Force2 = new Force2(lanceur, force2); + Force3 Force3 = new Force3(lanceur, force3); + Force4 Force4 = new Force4(lanceur, force4); + Force5 Force5 = new Force5(lanceur, force5); + Force6 Force6 = new Force6(lanceur, force6); + Force7 Force7 = new Force7(lanceur, force7); + + //touche + + joystick1.button(3).whileTrue(accumulateurtest); + joystick1.button(1).whileTrue(Force1); + joystick1.button(7).whileTrue(Force2); + joystick1.button(8).whileTrue(Force3); + joystick1.button(9).whileTrue(Force4); + joystick1.button(10).whileTrue(Force5); + joystick1.button(11).whileTrue(Force6); + joystick1.button(12).whileTrue(Force7); } - - - public Command getAutonomousCommand() { + + public Command getAutonomousCommand() { return null; /* new SequentialCommandGroup(new Avancer(drive), new Force7(lanceur, force7, accumulateur) , new Lancer(lanceur, accumulateur, force1), new Reculer(drive)); diff --git a/src/main/java/frc/robot/commands/LancerTest.java b/src/main/java/frc/robot/commands/Force1.java similarity index 85% rename from src/main/java/frc/robot/commands/LancerTest.java rename to src/main/java/frc/robot/commands/Force1.java index 3c8a6d4..0241b5a 100644 --- a/src/main/java/frc/robot/commands/LancerTest.java +++ b/src/main/java/frc/robot/commands/Force1.java @@ -4,13 +4,14 @@ package frc.robot.commands; +import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj2.command.CommandBase; import frc.robot.subsystems.Lanceur; -public class LancerTest extends CommandBase { +public class Force1 extends CommandBase { private Lanceur lanceur; /** Creates a new LancerTest. */ - public LancerTest(Lanceur lanceur) { + public Force1(Lanceur lanceur, GenericEntry force1) { this.lanceur = lanceur; addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. @@ -25,7 +26,7 @@ public class LancerTest extends CommandBase { // Called every time the scheduler runs while the command is scheduled. @Override public void execute() { - lanceur.lancer(0.5); + lanceur.lancer(0.3); } // Called once the command ends or is interrupted. diff --git a/src/main/java/frc/robot/commands/Force2.java b/src/main/java/frc/robot/commands/Force2.java index ea8564c..b8c46bc 100644 --- a/src/main/java/frc/robot/commands/Force2.java +++ b/src/main/java/frc/robot/commands/Force2.java @@ -6,39 +6,27 @@ package frc.robot.commands; import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj2.command.CommandBase; -import frc.robot.subsystems.Accumulateur; import frc.robot.subsystems.Lanceur; public class Force2 extends CommandBase { private Lanceur lanceur; - private Accumulateur accumulateur; - GenericEntry force2; - /** Creates a new Force1. */ - public Force2(Lanceur lanceur,Accumulateur accumulateur, GenericEntry force2) { + /** Creates a new LancerTest. */ + public Force2(Lanceur lanceur, GenericEntry force2) { this.lanceur = lanceur; - this.accumulateur = accumulateur; - addRequirements(lanceur, accumulateur); - this.force2 = force2; + addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. } // Called when the command is initially scheduled. @Override public void initialize() { - lanceur.setPID(0,0,0); + lanceur.setPID(0.000000000000075572, 0, 0); } // Called every time the scheduler runs while the command is scheduled. @Override public void execute() { - double vitesse = (200); - lanceur.lancer(force2.getDouble(200)); - if (lanceur.vitesse() > vitesse ){ - accumulateur.tourneavant(); - accumulateur.tournearriere(); - } else { - accumulateur.stop(); - } + lanceur.lancer(0.35); } // Called once the command ends or is interrupted. diff --git a/src/main/java/frc/robot/commands/Force3.java b/src/main/java/frc/robot/commands/Force3.java index 4c1e363..5e1607e 100644 --- a/src/main/java/frc/robot/commands/Force3.java +++ b/src/main/java/frc/robot/commands/Force3.java @@ -2,54 +2,42 @@ // 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. -// 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. - package frc.robot.commands; -import frc.robot.subsystems.Accumulateur; - import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj2.command.CommandBase; import frc.robot.subsystems.Lanceur; public class Force3 extends CommandBase { - private Lanceur lanceur; - private Accumulateur accumulateur; - GenericEntry force3; - - /** Creates a new Force1. */ - public Force3(Lanceur lanceur,GenericEntry force3, Accumulateur accumulateur) { + /** Creates a new LancerTest. */ + public Force3(Lanceur lanceur, GenericEntry force3) { this.lanceur = lanceur; - addRequirements(lanceur, accumulateur); - this.force3 = force3; - this.accumulateur = accumulateur; + addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. } // Called when the command is initially scheduled. @Override public void initialize() { - lanceur.setPID(0, 0, 0); + lanceur.setPID(0.000000000000075572, 0, 0); } // Called every time the scheduler runs while the command is scheduled. @Override public void execute() { - - double vitesse = (300); - lanceur.lancer(force3.getDouble(300)); - if (lanceur.vitesse() > vitesse ){ - accumulateur.tourneavant(); - accumulateur.tournearriere(); - } else { - accumulateur.stop(); - } - } - @Override - public boolean isFinished() { - return false; - } + lanceur.lancer(0.4); } + + // Called once the command ends or is interrupted. + @Override + public void end(boolean interrupted) { + lanceur.lancer(0); + } + + // Returns true when the command should end. + @Override + public boolean isFinished() { + return false; + } +} diff --git a/src/main/java/frc/robot/commands/Force4.java b/src/main/java/frc/robot/commands/Force4.java index 1c3ed02..94e1726 100644 --- a/src/main/java/frc/robot/commands/Force4.java +++ b/src/main/java/frc/robot/commands/Force4.java @@ -3,59 +3,41 @@ // the WPILib BSD license file in the root directory of this project. package frc.robot.commands; -import frc.robot.subsystems.Accumulateur; - import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj2.command.CommandBase; import frc.robot.subsystems.Lanceur; public class Force4 extends CommandBase { - private Lanceur lanceur; - private Accumulateur accumulateur; - GenericEntry force4; - - /** Creates a new Force1. */ - public Force4(Lanceur lanceur,GenericEntry force4, Accumulateur accumulateur) { + /** Creates a new LancerTest. */ + public Force4(Lanceur lanceur, GenericEntry force4) { this.lanceur = lanceur; - addRequirements(lanceur, accumulateur); - this.force4 = force4; - this.accumulateur = accumulateur; + addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. } // Called when the command is initially scheduled. @Override public void initialize() { - lanceur.setPID(0, 0, 0); + lanceur.setPID(0.000000000000075572, 0, 0); } // Called every time the scheduler runs while the command is scheduled. @Override public void execute() { - double vitesse = (400); - lanceur.lancer(force4.getDouble(400)); - if (lanceur.vitesse() > vitesse ){ - accumulateur.tourneavant(); - accumulateur.tournearriere(); - } else { - accumulateur.stop(); - } - - + lanceur.lancer(0.45); } // Called once the command ends or is interrupted. @Override public void end(boolean interrupted) { - lanceur.stop(); - accumulateur.stop(); - } + lanceur.lancer(0); + } // Returns true when the command should end. @Override public boolean isFinished() { - return lanceur.distance()>1; + return false; } -} \ No newline at end of file +} diff --git a/src/main/java/frc/robot/commands/Force5.java b/src/main/java/frc/robot/commands/Force5.java index f9612a6..f686549 100644 --- a/src/main/java/frc/robot/commands/Force5.java +++ b/src/main/java/frc/robot/commands/Force5.java @@ -3,59 +3,41 @@ // the WPILib BSD license file in the root directory of this project. package frc.robot.commands; -import frc.robot.subsystems.Accumulateur; - import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj2.command.CommandBase; import frc.robot.subsystems.Lanceur; public class Force5 extends CommandBase { - private Lanceur lanceur; - private Accumulateur accumulateur; - GenericEntry force5; - - /** Creates a new Force1. */ - public Force5(Lanceur lanceur,GenericEntry force5, Accumulateur accumulateur) { + /** Creates a new LancerTest. */ + public Force5(Lanceur lanceur, GenericEntry force5) { this.lanceur = lanceur; - addRequirements(lanceur, accumulateur); - this.force5 = force5; - this.accumulateur = accumulateur; + addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. } // Called when the command is initially scheduled. @Override public void initialize() { - lanceur.setPID(0, 0, 0); + lanceur.setPID(0.000000000000075572, 0, 0); } // Called every time the scheduler runs while the command is scheduled. @Override public void execute() { - double vitesse = (500); - lanceur.lancer(force5.getDouble(500)); - if (lanceur.vitesse() > vitesse ){ - accumulateur.tourneavant(); - accumulateur.tournearriere(); - } else { - accumulateur.stop(); - } - - + lanceur.lancer(0.5); } // Called once the command ends or is interrupted. @Override public void end(boolean interrupted) { - lanceur.stop(); - accumulateur.stop(); - } + lanceur.lancer(0); + } // Returns true when the command should end. @Override public boolean isFinished() { - return lanceur.distance()>1; + return false; } -} \ No newline at end of file +} diff --git a/src/main/java/frc/robot/commands/Force6.java b/src/main/java/frc/robot/commands/Force6.java index 2305577..9d8a2e6 100644 --- a/src/main/java/frc/robot/commands/Force6.java +++ b/src/main/java/frc/robot/commands/Force6.java @@ -3,58 +3,41 @@ // the WPILib BSD license file in the root directory of this project. package frc.robot.commands; -import frc.robot.subsystems.Accumulateur; + import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj2.command.CommandBase; import frc.robot.subsystems.Lanceur; public class Force6 extends CommandBase { - private Lanceur lanceur; - private Accumulateur accumulateur; - GenericEntry force6; - - - /** Creates a new Force1. */ - public Force6(Lanceur lanceur, GenericEntry force6, Accumulateur accumulateur) { + /** Creates a new LancerTest. */ + public Force6(Lanceur lanceur, GenericEntry force6) { this.lanceur = lanceur; - addRequirements(lanceur, accumulateur); - this.force6 = force6; - this.accumulateur = accumulateur; + addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. } // Called when the command is initially scheduled. @Override public void initialize() { - lanceur.setPID(0, 0, 0); + lanceur.setPID(0.000000000000075572, 0, 0); } // Called every time the scheduler runs while the command is scheduled. @Override public void execute() { - double vitesse = (600); - lanceur.lancer(force6.getDouble(600)); - if (lanceur.vitesse() > vitesse ){ - accumulateur.tourneavant(); - accumulateur.tournearriere(); - } else { - accumulateur.stop(); - } - - + lanceur.lancer(0.55); } // Called once the command ends or is interrupted. @Override public void end(boolean interrupted) { - lanceur.stop(); - accumulateur.stop(); - } + lanceur.lancer(0); + } // Returns true when the command should end. @Override public boolean isFinished() { - return lanceur.distance()>1; + return false; } -} \ No newline at end of file +} diff --git a/src/main/java/frc/robot/commands/Force7.java b/src/main/java/frc/robot/commands/Force7.java index 034f228..05c9468 100644 --- a/src/main/java/frc/robot/commands/Force7.java +++ b/src/main/java/frc/robot/commands/Force7.java @@ -3,56 +3,41 @@ // the WPILib BSD license file in the root directory of this project. package frc.robot.commands; -import frc.robot.subsystems.Accumulateur; + import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj2.command.CommandBase; import frc.robot.subsystems.Lanceur; public class Force7 extends CommandBase { - private Lanceur lanceur; - private Accumulateur accumulateur; - GenericEntry force7; - - /** Creates a new Force1. */ - public Force7(Lanceur lanceur,GenericEntry force7, Accumulateur accumulateur) { + /** Creates a new LancerTest. */ + public Force7(Lanceur lanceur, GenericEntry force7) { this.lanceur = lanceur; - addRequirements(lanceur, accumulateur); - this.force7 = force7; - this.accumulateur = accumulateur; + addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. } // Called when the command is initially scheduled. @Override public void initialize() { - lanceur.setPID(0, 0, 0); + lanceur.setPID(0.000000000000075572, 0, 0); } // Called every time the scheduler runs while the command is scheduled. @Override public void execute() { - double vitesse = (700); - lanceur.lancer(force7.getDouble(700)); - if (lanceur.vitesse() > vitesse ){ - accumulateur.tourneavant(); - accumulateur.tournearriere(); - } else { - accumulateur.stop(); - } - + lanceur.lancer(0.6); } // Called once the command ends or is interrupted. @Override public void end(boolean interrupted) { - lanceur.stop(); - accumulateur.stop(); - } + lanceur.lancer(0); + } // Returns true when the command should end. @Override public boolean isFinished() { - return lanceur.distance()>1; + return false; } -} \ No newline at end of file +} From 5fa7666976fa2326c6a492bc01fa97ebc55f840a Mon Sep 17 00:00:00 2001 From: samuel desharnais Date: Tue, 5 Dec 2023 18:18:45 -0500 Subject: [PATCH 2/2] cvbn --- src/main/java/frc/robot/RobotContainer.java | 10 +++-- .../java/frc/robot/commands/LancerTest.java | 6 +++ .../java/frc/robot/commands/LanceurAuto.java | 37 +++++++++++++++++++ src/main/java/frc/robot/subsystems/Drive.java | 21 ++++++++++- 4 files changed, 69 insertions(+), 5 deletions(-) create mode 100644 src/main/java/frc/robot/commands/LanceurAuto.java diff --git a/src/main/java/frc/robot/RobotContainer.java b/src/main/java/frc/robot/RobotContainer.java index 9f25d03..9ec8880 100644 --- a/src/main/java/frc/robot/RobotContainer.java +++ b/src/main/java/frc/robot/RobotContainer.java @@ -3,6 +3,7 @@ // the WPILib BSD license file in the root directory of this project. package frc.robot; +import edu.wpi.first.cameraserver.CameraServer; import edu.wpi.first.math.MathUtil; import edu.wpi.first.networktables.GenericEntry; import edu.wpi.first.wpilibj.shuffleboard.BuiltInLayouts; @@ -10,6 +11,7 @@ import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard; import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardLayout; import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardTab; import edu.wpi.first.wpilibj2.command.Command; +import edu.wpi.first.wpilibj2.command.ParallelCommandGroup; import edu.wpi.first.wpilibj2.command.RunCommand; import edu.wpi.first.wpilibj2.command.SequentialCommandGroup; import edu.wpi.first.wpilibj2.command.button.CommandJoystick; @@ -39,6 +41,7 @@ public class RobotContainer { ShuffleboardLayout forces = Shuffleboard.getTab("Dashboard") .getLayout("forces", BuiltInLayouts.kList) .withSize(3, 7); + GenericEntry force1 = forces.add("Force1", 2).getEntry(); GenericEntry force2 = forces.add("Force2", 4).getEntry(); GenericEntry force3 = forces.add("Force3", 6).getEntry(); @@ -76,9 +79,8 @@ public class RobotContainer { public Command getAutonomousCommand() { - return null; - /* new SequentialCommandGroup(new Avancer(drive), new Force7(lanceur, force7, accumulateur) - , new Lancer(lanceur, accumulateur, force1), new Reculer(drive)); - */ } + return new SequentialCommandGroup(new ParallelCommandGroup(new LancerTest(lanceur).withTimeout(5),new accumulateurtest(accumulateur).withTimeout(5)) + ,new Avancer(drive)); + } } diff --git a/src/main/java/frc/robot/commands/LancerTest.java b/src/main/java/frc/robot/commands/LancerTest.java index 95eaeb0..03ed1ab 100644 --- a/src/main/java/frc/robot/commands/LancerTest.java +++ b/src/main/java/frc/robot/commands/LancerTest.java @@ -4,13 +4,19 @@ package frc.robot.commands; +import edu.wpi.first.networktables.GenericEntry; +import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard; +import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardTab; import edu.wpi.first.wpilibj2.command.CommandBase; import frc.robot.subsystems.Lanceur; public class LancerTest extends CommandBase { + ShuffleboardTab dashboard = Shuffleboard.getTab("Dashboard"); + private Lanceur lanceur; /** Creates a new LancerTest. */ public LancerTest(Lanceur lanceur) { + dashboard.add("vitesse lanceur", 0.5); this.lanceur = lanceur; addRequirements(lanceur); // Use addRequirements() here to declare subsystem dependencies. diff --git a/src/main/java/frc/robot/commands/LanceurAuto.java b/src/main/java/frc/robot/commands/LanceurAuto.java new file mode 100644 index 0000000..72b12f9 --- /dev/null +++ b/src/main/java/frc/robot/commands/LanceurAuto.java @@ -0,0 +1,37 @@ +// 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. + +package frc.robot.commands; + +import edu.wpi.first.wpilibj2.command.CommandBase; +import frc.robot.subsystems.Lanceur; + +public class LanceurAuto extends CommandBase { + private Lanceur lanceur; + /** Creates a new LanceurAuto. */ + public LanceurAuto(Lanceur lanceur) { + this.lanceur = lanceur; + // Use addRequirements() here to declare subsystem dependencies. + } + + // Called when the command is initially scheduled. + @Override + public void initialize() { + lanceur.setPID(0, 0, 0); + } + + // Called every time the scheduler runs while the command is scheduled. + @Override + public void execute() {} + + // Called once the command ends or is interrupted. + @Override + public void end(boolean interrupted) {} + + // Returns true when the command should end. + @Override + public boolean isFinished() { + return false; + } +} diff --git a/src/main/java/frc/robot/subsystems/Drive.java b/src/main/java/frc/robot/subsystems/Drive.java index c0aa314..1032e73 100644 --- a/src/main/java/frc/robot/subsystems/Drive.java +++ b/src/main/java/frc/robot/subsystems/Drive.java @@ -7,17 +7,32 @@ package frc.robot.subsystems; import java.io.File; import java.io.IOException; +import com.revrobotics.CANSparkMax; +import com.revrobotics.CANSparkMaxLowLevel.MotorType; + import edu.wpi.first.math.geometry.Translation2d; import edu.wpi.first.math.kinematics.SwerveModulePosition; import edu.wpi.first.wpilibj.Filesystem; +import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard; +import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardTab; import edu.wpi.first.wpilibj2.command.SubsystemBase; +import frc.robot.Constants; import swervelib.SwerveDrive; +import swervelib.encoders.CanAndCoderSwerve; import swervelib.parser.SwerveParser; public class Drive extends SubsystemBase { + ShuffleboardTab dashboard = Shuffleboard.getTab("Dashboard"); SwerveDrive swerveDrive; File swerveJsonDirectory = new File(Filesystem.getDeployDirectory(),"swerve"); - + /* final CanAndCoderSwerve avantdroitdrive = new CanAndCoderSwerve(Constants.avantdroitDrive); + final CanAndCoderSwerve avantgauchedrive = new CanAndCoderSwerve(Constants.avantgaucheDrive); + final CanAndCoderSwerve arrieregauchedrive = new CanAndCoderSwerve(Constants.arrieregaucheDrive); + final CanAndCoderSwerve arrieredroitdrive = new CanAndCoderSwerve(Constants.arrieredroitDrive); + final CanAndCoderSwerve avantdroitangle = new CanAndCoderSwerve(Constants.avantdroitAngle); + final CanAndCoderSwerve avantgaucheangle = new CanAndCoderSwerve(Constants.avantgaucheAngle); + final CanAndCoderSwerve arrieregaucheangle = new CanAndCoderSwerve(Constants.arrieregaucheAngle); + final CanAndCoderSwerve arrieredroitangle = new CanAndCoderSwerve(Constants.arrieredroitAngle); */ public void drive(double x, double y, double zRotation){ swerveDrive.drive(new Translation2d(x, y), zRotation, false, false); } @@ -25,6 +40,7 @@ public class Drive extends SubsystemBase { /** Creates a new Drive. */ public Drive() { + try { this.swerveDrive = new SwerveParser(swerveJsonDirectory).createSwerveDrive(); } catch (IOException e) { @@ -34,6 +50,9 @@ public class Drive extends SubsystemBase { public SwerveModulePosition[] distance(){ return swerveDrive.getModulePositions(); } +public void reset(){ + +} @Override public void periodic() { // This method will be called once per scheduler run