2020-02-08 15:58:11 -07:00
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
/* Copyright (c) 2019 FIRST. All Rights Reserved. */
|
|
|
|
|
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
|
|
|
|
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
|
|
|
|
/* the project. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
|
|
package frc4388.robot.commands;
|
|
|
|
|
|
2020-02-18 18:45:07 -08:00
|
|
|
import com.revrobotics.CANDigitalInput;
|
|
|
|
|
import com.revrobotics.CANSparkMax;
|
|
|
|
|
import com.revrobotics.CANDigitalInput.LimitSwitchPolarity;
|
|
|
|
|
import com.revrobotics.CANSparkMaxLowLevel.MotorType;
|
|
|
|
|
|
2020-02-08 15:58:11 -07:00
|
|
|
import edu.wpi.first.wpilibj2.command.CommandBase;
|
2020-02-18 18:45:07 -08:00
|
|
|
import frc4388.robot.Constants.IntakeConstants;
|
2020-02-08 15:58:11 -07:00
|
|
|
import frc4388.robot.subsystems.Intake;
|
|
|
|
|
import frc4388.utility.controller.IHandController;
|
|
|
|
|
|
|
|
|
|
public class RunExtenderOutIn extends CommandBase {
|
|
|
|
|
private Intake m_intake;
|
2020-02-20 17:00:50 -07:00
|
|
|
|
2020-02-18 18:45:07 -08:00
|
|
|
CANSparkMax m_intakeMotor = new CANSparkMax(IntakeConstants.INTAKE_SPARK_ID, MotorType.kBrushless);
|
|
|
|
|
CANSparkMax m_extenderMotor = new CANSparkMax(IntakeConstants.EXTENDER_SPARK_ID, MotorType.kBrushless);
|
|
|
|
|
CANDigitalInput m_extenderForwardLimit;
|
|
|
|
|
CANDigitalInput m_extenderReverseLimit;
|
|
|
|
|
|
|
|
|
|
|
2020-02-08 15:58:11 -07:00
|
|
|
|
|
|
|
|
/**
|
2020-02-10 17:50:52 -07:00
|
|
|
* Uses input from opperator to run the extender motor.
|
|
|
|
|
* The left bumper will run the extender in and out.
|
2020-02-08 15:58:11 -07:00
|
|
|
* @param subsystem pass the Intake subsystem from {@link frc4388.robot.RobotContainer#RobotContainer() RobotContainer}
|
|
|
|
|
*/
|
2020-02-10 17:37:26 -07:00
|
|
|
public RunExtenderOutIn(Intake subsystem) {
|
2020-02-08 15:58:11 -07:00
|
|
|
// Use addRequirements() here to declare subsystem dependencies.
|
|
|
|
|
m_intake = subsystem;
|
|
|
|
|
addRequirements(m_intake);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Called when the command is initially scheduled.
|
|
|
|
|
@Override
|
|
|
|
|
public void initialize() {
|
2020-02-20 17:00:50 -07:00
|
|
|
m_intake.isExtended = !m_intake.isExtended;
|
2020-02-08 15:58:11 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Called every time the scheduler runs while the command is scheduled.
|
|
|
|
|
@Override
|
|
|
|
|
public void execute() {
|
2020-02-20 17:00:50 -07:00
|
|
|
if (m_intake.isExtended){
|
2020-02-08 15:58:11 -07:00
|
|
|
m_intake.runExtender(0.3);
|
|
|
|
|
} else {
|
|
|
|
|
m_intake.runExtender(-0.3);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Called once the command ends or is interrupted.
|
|
|
|
|
@Override
|
|
|
|
|
public void end(boolean interrupted) {
|
2020-02-10 17:37:26 -07:00
|
|
|
m_intake.runExtender(0.0);
|
2020-02-08 15:58:11 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Returns true when the command should end.
|
|
|
|
|
@Override
|
|
|
|
|
public boolean isFinished() {
|
2020-02-20 17:00:50 -07:00
|
|
|
if (m_intake.isExtended && m_extenderForwardLimit.get() == true){
|
2020-02-10 17:37:26 -07:00
|
|
|
return true;
|
|
|
|
|
}
|
2020-02-18 18:45:07 -08:00
|
|
|
|
2020-02-20 17:00:50 -07:00
|
|
|
else if(m_intake.isExtended && m_extenderReverseLimit.get() == true){
|
2020-02-18 18:45:07 -08:00
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
else{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2020-02-08 15:58:11 -07:00
|
|
|
}
|
|
|
|
|
}
|