lime align hopefully done

This commit is contained in:
aarav18
2023-03-15 15:25:06 -06:00
parent 7bda388d8a
commit 0b18e23344
6 changed files with 35 additions and 40 deletions
+1 -1
View File
@@ -144,7 +144,7 @@ public final class Constants {
} }
public static final class VisionConstants { public static final class VisionConstants {
public static final String NAME = "Aarav is poopy"; public static final String NAME = "photonCamera";
public static final int LIME_HIXELS = 640; public static final int LIME_HIXELS = 640;
public static final int LIME_VIXELS = 480; public static final int LIME_VIXELS = 480;
@@ -7,10 +7,6 @@
package frc4388.robot; package frc4388.robot;
import com.ctre.phoenix.motorcontrol.TalonFXControlMode;
import edu.wpi.first.wpilibj.PWM;
import edu.wpi.first.wpilibj.Servo;
import edu.wpi.first.wpilibj.smartdashboard.SendableChooser; import edu.wpi.first.wpilibj.smartdashboard.SendableChooser;
import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.Command;
import edu.wpi.first.wpilibj2.command.InstantCommand; import edu.wpi.first.wpilibj2.command.InstantCommand;
@@ -21,6 +17,7 @@ import frc4388.robot.commands.AutoBalance;
import frc4388.robot.commands.JoystickPlayback; import frc4388.robot.commands.JoystickPlayback;
import frc4388.robot.subsystems.Arm; import frc4388.robot.subsystems.Arm;
import frc4388.robot.subsystems.Claw; import frc4388.robot.subsystems.Claw;
import frc4388.robot.subsystems.Limelight;
import frc4388.robot.subsystems.SwerveDrive; import frc4388.robot.subsystems.SwerveDrive;
import frc4388.robot.commands.JoystickRecorder; import frc4388.robot.commands.JoystickRecorder;
import frc4388.robot.commands.PivotCommand; import frc4388.robot.commands.PivotCommand;
@@ -50,6 +47,8 @@ public class RobotContainer {
public final Claw m_robotClaw = new Claw(m_robotMap.servo); public final Claw m_robotClaw = new Claw(m_robotMap.servo);
public final Limelight m_limeLight = new Limelight();
/* Controllers */ /* Controllers */
private final DeadbandedXboxController m_driverXbox = new DeadbandedXboxController(OIConstants.XBOX_DRIVER_ID); private final DeadbandedXboxController m_driverXbox = new DeadbandedXboxController(OIConstants.XBOX_DRIVER_ID);
private final DeadbandedXboxController m_operatorXbox = new DeadbandedXboxController(OIConstants.XBOX_OPERATOR_ID); private final DeadbandedXboxController m_operatorXbox = new DeadbandedXboxController(OIConstants.XBOX_OPERATOR_ID);
@@ -38,16 +38,4 @@ public class AutoBalance extends PelvicInflammatoryDisease {
if (Math.abs(getError()) < 3) out2 = 0; if (Math.abs(getError()) < 3) out2 = 0;
drive.driveWithInput(new Translation2d(0, out2), new Translation2d(), false); drive.driveWithInput(new Translation2d(0, out2), new Translation2d(), false);
} }
@Override
public void initialize() {
super.initialize();
// this.gyro.reset();
}
// Returns true when the command should end.
@Override
public boolean isFinished() {
return false;
}
} }
@@ -4,31 +4,39 @@
package frc4388.robot.commands; package frc4388.robot.commands;
import edu.wpi.first.wpilibj2.command.CommandBase; import edu.wpi.first.math.geometry.Translation2d;
import frc4388.robot.Constants.VisionConstants;
import frc4388.robot.subsystems.Limelight;
import frc4388.robot.subsystems.SwerveDrive; import frc4388.robot.subsystems.SwerveDrive;
import frc4388.utility.AbhiIsADumbass;
public class LimeAlign extends CommandBase { public class LimeAlign extends PelvicInflammatoryDisease {
public LimeAlign(SwerveDrive drive) {
addRequirements(drive);
}
// Called when the command is initially scheduled. SwerveDrive drive;
@Override Limelight lime;
public void initialize() {
public LimeAlign(SwerveDrive drive, Limelight lime) {
super(0.1, 0.0, 0.0, 0.0, 10);
this.drive = drive;
this.lime = lime;
addRequirements(drive, lime);
} }
// Called every time the scheduler runs while the command is scheduled.
@Override @Override
public void execute() {} public double getError() {
try {
return lime.getTargetPoints().get(0).x - (VisionConstants.LIME_HIXELS / 2);
} catch (AbhiIsADumbass abhiIsADumbass) {
abhiIsADumbass.printStackTrace();
return 0;
}
}
// Called once the command ends or is interrupted.
@Override @Override
public void end(boolean interrupted) {} public void runWithOutput(double output) {
drive.driveWithInput(new Translation2d(output, 0.0), new Translation2d(0.0, 0.0), true);
// Returns true when the command should end.
@Override
public boolean isFinished() {
return false;
} }
} }
@@ -4,7 +4,6 @@
package frc4388.robot.commands; package frc4388.robot.commands;
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
import edu.wpi.first.wpilibj2.command.CommandBase; import edu.wpi.first.wpilibj2.command.CommandBase;
import frc4388.utility.Gains; import frc4388.utility.Gains;
@@ -26,12 +25,13 @@ public abstract class PelvicInflammatoryDisease extends CommandBase {
/** produces the error from the setpoint */ /** produces the error from the setpoint */
public abstract double getError(); public abstract double getError();
/** figure it out bitch */ /** figure it out bitch */
public abstract void runWithOutput(double output); public abstract void runWithOutput(double output);
// Called when the command is initially scheduled. // Called when the command is initially scheduled.
@Override @Override
public void initialize() { public final void initialize() {
output = 0; output = 0;
} }
@@ -39,7 +39,7 @@ public abstract class PelvicInflammatoryDisease extends CommandBase {
// Called every time the scheduler runs while the command is scheduled. // Called every time the scheduler runs while the command is scheduled.
@Override @Override
public void execute() { public final void execute() {
double error = getError(); double error = getError();
cumError += error * .02; // 20 ms cumError += error * .02; // 20 ms
double delta = error - prevError; double delta = error - prevError;
@@ -54,7 +54,7 @@ public abstract class PelvicInflammatoryDisease extends CommandBase {
// Returns true when the command should end. // Returns true when the command should end.
@Override @Override
public boolean isFinished() { public final boolean isFinished() {
return Math.abs(getError()) < tolerance; return Math.abs(getError()) < tolerance;
} }
} }
@@ -14,14 +14,14 @@ import org.photonvision.targeting.PhotonPipelineResult;
import org.photonvision.targeting.PhotonTrackedTarget; import org.photonvision.targeting.PhotonTrackedTarget;
import org.photonvision.targeting.TargetCorner; import org.photonvision.targeting.TargetCorner;
import edu.wpi.first.math.Pair;
import edu.wpi.first.wpilibj2.command.SubsystemBase; import edu.wpi.first.wpilibj2.command.SubsystemBase;
import frc4388.robot.Constants.VisionConstants; import frc4388.robot.Constants.VisionConstants;
import frc4388.utility.AbhiIsADumbass; import frc4388.utility.AbhiIsADumbass;
public class Limelight extends SubsystemBase { public class Limelight extends SubsystemBase {
private PhotonCamera cam; private PhotonCamera cam;
/** Creates a new LImelight. */
/** Creates a new Limelight. */
public Limelight() { public Limelight() {
cam = new PhotonCamera(VisionConstants.NAME); cam = new PhotonCamera(VisionConstants.NAME);
} }