mirror of
https://github.com/Team4388/2024AcrossTheRidgebotiverse.git
synced 2026-06-09 08:48:03 -06:00
micha;
This commit is contained in:
@@ -4,6 +4,8 @@
|
||||
|
||||
package frc4388.robot.subsystems;
|
||||
|
||||
import com.ctre.phoenix6.configs.Slot0Configs;
|
||||
import com.ctre.phoenix6.controls.PositionVoltage;
|
||||
import com.ctre.phoenix6.hardware.TalonFX;
|
||||
|
||||
import edu.wpi.first.wpilibj2.command.SubsystemBase;
|
||||
@@ -18,14 +20,25 @@ public class Climber extends SubsystemBase {
|
||||
|
||||
public Climber(TalonFX climbMotor) {
|
||||
this.climbMotor = climbMotor;
|
||||
this.climbMotor.setInverted(true);
|
||||
var slot0Configs = new Slot0Configs();
|
||||
slot0Configs.kP = 0.7; // An error of 0.5 rotations results in 12 V output
|
||||
slot0Configs.kI = 0.0; // no output for integrated error
|
||||
slot0Configs.kD = 0.06; // A velocity of 1 rps results in 0.1 V output
|
||||
|
||||
climbMotor.getConfigurator().apply(slot0Configs);
|
||||
}
|
||||
|
||||
public void climbOut() {
|
||||
climbMotor.set(Constants.ClimbConstants.CLIMB_OUT_SPEED);
|
||||
PositionVoltage request = new PositionVoltage(0);
|
||||
climbMotor.setControl(request.withPosition(-520));
|
||||
//climbMotor.set(Constants.ClimbConstants.CLIMB_IN_SPEED);
|
||||
}
|
||||
|
||||
public void climbIn() {
|
||||
climbMotor.set(Constants.ClimbConstants.CLIMB_IN_SPEED);
|
||||
PositionVoltage request = new PositionVoltage(-520);
|
||||
climbMotor.setControl(request.withPosition(0));
|
||||
// climbMotor.set(Constants.ClimbConstants.CLIMB_IN_SPEED);
|
||||
}
|
||||
|
||||
public void stopClimb() {
|
||||
|
||||
@@ -26,6 +26,7 @@ import com.revrobotics.SparkLimitSwitch;
|
||||
import com.revrobotics.SparkPIDController;
|
||||
import com.revrobotics.RelativeEncoder;
|
||||
import edu.wpi.first.wpilibj.CAN;
|
||||
import edu.wpi.first.wpilibj.GenericHID.RumbleType;
|
||||
import edu.wpi.first.wpilibj.motorcontrol.Spark;
|
||||
import edu.wpi.first.wpilibj.motorcontrol.Talon;
|
||||
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
|
||||
@@ -35,6 +36,7 @@ import frc4388.robot.Constants.IntakeConstants;
|
||||
import frc4388.robot.commands.PID;
|
||||
import frc4388.utility.Gains;
|
||||
import frc4388.utility.configurable.ConfigurableDouble;
|
||||
import frc4388.utility.controller.DeadbandedXboxController;
|
||||
|
||||
public class Intake extends SubsystemBase {
|
||||
|
||||
@@ -52,6 +54,9 @@ public class Intake extends SubsystemBase {
|
||||
private TalonFX talonPivot;
|
||||
private CANcoder encoder;
|
||||
|
||||
private DeadbandedXboxController m_driverXbox;
|
||||
private DeadbandedXboxController m_operatorXbox;
|
||||
|
||||
private boolean r;
|
||||
|
||||
private HardwareLimitSwitchConfigs l;
|
||||
@@ -96,14 +101,17 @@ public class Intake extends SubsystemBase {
|
||||
// }
|
||||
|
||||
//For Talon
|
||||
public Intake(TalonFX talonIntake, TalonFX talonPivot) {
|
||||
public Intake(TalonFX talonIntake, TalonFX talonPivot, DeadbandedXboxController driverXbox, DeadbandedXboxController operatorXbox) {
|
||||
this.talonIntake = talonIntake;
|
||||
this.talonPivot = talonPivot;
|
||||
|
||||
this.m_driverXbox = driverXbox;
|
||||
this.m_operatorXbox = operatorXbox;
|
||||
|
||||
talonIntake.getConfigurator().apply(new TalonFXConfiguration());
|
||||
talonPivot.getConfigurator().apply(new TalonFXConfiguration());
|
||||
|
||||
talonIntake.setNeutralMode(NeutralModeValue.Brake);
|
||||
talonIntake.setNeutralMode(NeutralModeValue.Coast);
|
||||
talonPivot.setNeutralMode(NeutralModeValue.Brake);
|
||||
|
||||
// talonPivot.getConfigurator().apply(new HardwareLimitSwitchConfigs());
|
||||
@@ -323,6 +331,8 @@ public class Intake extends SubsystemBase {
|
||||
// }
|
||||
// }
|
||||
|
||||
private int rumbleTime = 0;
|
||||
|
||||
@Override
|
||||
public void periodic() {
|
||||
// This method will be called once per scheduler run
|
||||
@@ -336,5 +346,26 @@ public class Intake extends SubsystemBase {
|
||||
SmartDashboard.putNumber("Pivot Position", getArmPos());
|
||||
|
||||
smartDashboardOuttakeValue = SmartDashboard.getNumber("Outtake Speed", IntakeConstants.INTAKE_OUT_SPEED_UNPRESSED);
|
||||
|
||||
// if(getTalonIntakeLimitSwitchState()){
|
||||
// rumbleTime = 1000;
|
||||
// m_driverXbox.setRumble(RumbleType.kLeftRumble, 1.0);
|
||||
// m_driverXbox.setRumble(RumbleType.kRightRumble, 1.0);
|
||||
// m_operatorXbox.setRumble(RumbleType.kLeftRumble, 1.0);
|
||||
// m_operatorXbox.setRumble(RumbleType.kRightRumble, 1.0);
|
||||
// // m_hid.setRumble(RumbleType.kLeftRumble, 0.0);
|
||||
// // m_hid.setRumble(RumbleType.kRightRumble, 0.0);
|
||||
// }
|
||||
// if(rumbleTime > 0){
|
||||
// rumbleTime--;
|
||||
// if(rumbleTime <= 0){
|
||||
// rumbleTime = 0;
|
||||
// m_driverXbox.setRumble(RumbleType.kLeftRumble, 0);
|
||||
// m_driverXbox.setRumble(RumbleType.kRightRumble, 0);
|
||||
// m_operatorXbox.setRumble(RumbleType.kLeftRumble, 0);
|
||||
// m_operatorXbox.setRumble(RumbleType.kRightRumble, 0);
|
||||
// }
|
||||
|
||||
// }
|
||||
}
|
||||
}
|
||||
|
||||
@@ -30,6 +30,7 @@ public class Limelight extends SubsystemBase {
|
||||
}
|
||||
|
||||
private void update() {
|
||||
SmartDashboard.putBoolean("Apriltag", isTag);
|
||||
if(!isTag){
|
||||
return;
|
||||
}
|
||||
@@ -55,7 +56,6 @@ public class Limelight extends SubsystemBase {
|
||||
isNearSpeaker = distance <= VisionConstants.SpeakerBubbleDistance;
|
||||
|
||||
SmartDashboard.putBoolean("nearSpeaker", isNearSpeaker);
|
||||
SmartDashboard.putBoolean("Apriltag", isTag);
|
||||
SmartDashboard.putNumber("speakerDistance", distance);
|
||||
}
|
||||
|
||||
|
||||
@@ -189,6 +189,16 @@ public class SwerveDrive extends SubsystemBase {
|
||||
gyro.resetFlip();
|
||||
rotTarget = 0.0;
|
||||
}
|
||||
|
||||
public void resetGyroRightBlue() {
|
||||
gyro.resetRightSideBlue();
|
||||
rotTarget = 0.0;
|
||||
}
|
||||
|
||||
public void resetGyroRightAmp() {
|
||||
gyro.resetAmpSide();
|
||||
rotTarget = 0.0;
|
||||
}
|
||||
|
||||
public void stopModules() {
|
||||
for (SwerveModule module : this.modules) {
|
||||
|
||||
Reference in New Issue
Block a user