mirror of
https://github.com/Team4388/2022NoWayHome.git
synced 2026-06-09 00:38:05 -06:00
118 lines
4.7 KiB
Java
118 lines
4.7 KiB
Java
// 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 frc4388.robot.subsystems;
|
|
|
|
import com.revrobotics.CANSparkMax.ControlType;
|
|
import com.revrobotics.CANSparkMax.IdleMode;
|
|
import com.revrobotics.CANSparkMax.SoftLimitDirection;
|
|
|
|
import com.revrobotics.CANSparkMax;
|
|
import com.revrobotics.RelativeEncoder;
|
|
import com.revrobotics.SparkMaxLimitSwitch;
|
|
import com.revrobotics.SparkMaxPIDController;
|
|
|
|
import edu.wpi.first.wpilibj.interfaces.Gyro;
|
|
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
|
|
import edu.wpi.first.wpilibj2.command.SubsystemBase;
|
|
|
|
import frc4388.robot.Constants.ShooterConstants;
|
|
import frc4388.utility.Gains;
|
|
|
|
public class Turret extends SubsystemBase {
|
|
|
|
/** Creates a new Turret. */
|
|
public BoomBoom m_boomBoomSubsystem;
|
|
public SwerveDrive m_sDriveSubsystem;
|
|
|
|
public CANSparkMax m_boomBoomRotateMotor;// = new CANSparkMax(ShooterConstants.SHOOTER_ROTATE_ID,
|
|
// MotorType.kBrushless);
|
|
public static Gains m_shooterTGains = ShooterConstants.SHOOTER_TURRET_GAINS;
|
|
// SparkMaxLimitSwitch m_boomBoomRightLimit, m_boomBoomLeftLimit;
|
|
public Gyro m_turretGyro;
|
|
|
|
public double m_targetDistance = 0;
|
|
|
|
public boolean m_isAimReady = false;
|
|
|
|
SparkMaxPIDController m_boomBoomRotatePIDController;// = m_boomBoomRotateMotor.getPIDController();
|
|
public RelativeEncoder m_boomBoomRotateEncoder;// = m_boomBoomRotateMotor.getEncoder();
|
|
|
|
// Variables
|
|
public Turret(CANSparkMax boomBoomRotateMotor) { // Take in rotate motor as an argument
|
|
|
|
m_boomBoomRotateMotor = boomBoomRotateMotor;
|
|
m_boomBoomRotatePIDController = m_boomBoomRotateMotor.getPIDController();
|
|
m_boomBoomRotateEncoder = m_boomBoomRotateMotor.getEncoder();
|
|
m_boomBoomRotateMotor.setIdleMode(IdleMode.kBrake);
|
|
|
|
// m_boomBoomLeftLimit = m_boomBoomRotateMotor.getReverseLimitSwitch(SparkMaxLimitSwitch.Type.kNormallyOpen);
|
|
// m_boomBoomRightLimit = m_boomBoomRotateMotor.getForwardLimitSwitch(SparkMaxLimitSwitch.Type.kNormallyOpen);
|
|
// m_boomBoomRightLimit.enableLimitSwitch(true);
|
|
// m_boomBoomLeftLimit.enableLimitSwitch(true);
|
|
// SmartDashboard.putBoolean("Right Limit Switch Enabled", m_boomBoomRightLimit.isLimitSwitchEnabled());
|
|
// SmartDashboard.putBoolean("Left Limit Switch Enabled", m_boomBoomLeftLimit.isLimitSwitchEnabled());
|
|
|
|
m_boomBoomRotateMotor.setSoftLimit(SoftLimitDirection.kForward, (float) ShooterConstants.TURRET_FORWARD_LIMIT);
|
|
m_boomBoomRotateMotor.setSoftLimit(SoftLimitDirection.kReverse, (float) ShooterConstants.TURRET_REVERSE_LIMIT);
|
|
setTurretSoftLimits(true);
|
|
|
|
m_boomBoomRotateMotor.setInverted(true);
|
|
|
|
m_boomBoomRotatePIDController.setP(m_shooterTGains.kP);
|
|
m_boomBoomRotatePIDController.setI(m_shooterTGains.kI);
|
|
m_boomBoomRotatePIDController.setD(m_shooterTGains.kD);
|
|
m_boomBoomRotatePIDController.setFF(m_shooterTGains.kF);
|
|
m_boomBoomRotatePIDController.setIZone(m_shooterTGains.kIzone);
|
|
m_boomBoomRotatePIDController.setOutputRange(ShooterConstants.SHOOTER_TURRET_MIN, m_shooterTGains.kPeakOutput);
|
|
}
|
|
|
|
@Override
|
|
public void periodic() {
|
|
// This method will be called once per scheduler run
|
|
SmartDashboard.putNumber("Turret Angle Rotations", m_boomBoomRotateEncoder.getPosition());
|
|
SmartDashboard.putNumber("Turret Angle Degrees", m_boomBoomRotateEncoder.getPosition() * ShooterConstants.TURRET_DEGREES_PER_ROT);
|
|
}
|
|
|
|
/**
|
|
* Set status of turret motor soft limits.
|
|
* @param set Boolean to set soft limits to.
|
|
*/
|
|
public void setTurretSoftLimits(boolean set) {
|
|
m_boomBoomRotateMotor.enableSoftLimit(SoftLimitDirection.kForward, set);
|
|
m_boomBoomRotateMotor.enableSoftLimit(SoftLimitDirection.kReverse, set);
|
|
}
|
|
|
|
public void passRequiredSubsystem(BoomBoom subsystem0, SwerveDrive subsystem1) {
|
|
m_boomBoomSubsystem = subsystem0;
|
|
m_sDriveSubsystem = subsystem1;
|
|
}
|
|
|
|
public void runTurretWithInput(double input) {
|
|
m_boomBoomRotateMotor.set(input * ShooterConstants.TURRET_SPEED_MULTIPLIER);
|
|
}
|
|
|
|
public void runshooterRotatePID(double targetAngle) {
|
|
targetAngle = targetAngle / ShooterConstants.TURRET_DEGREES_PER_ROT;
|
|
m_boomBoomRotatePIDController.setReference(targetAngle, ControlType.kPosition);
|
|
}
|
|
|
|
public void resetGyroShooterRotate() {
|
|
m_boomBoomRotateEncoder.setPosition(0);
|
|
}
|
|
|
|
public double getboomBoomRotatePosition() {
|
|
return m_boomBoomRotateEncoder.getPosition();
|
|
}
|
|
|
|
public double getBoomBoomAngleDegrees() {
|
|
return (m_boomBoomRotateEncoder.getPosition() - ShooterConstants.TURRET_MOTOR_POS_AT_ZERO_ROT) * 360
|
|
/ ShooterConstants.TURRET_MOTOR_ROTS_PER_ROT;
|
|
}
|
|
|
|
public double getCurrent(){
|
|
return m_boomBoomRotateMotor.getOutputCurrent();
|
|
}
|
|
|
|
} |