-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add choreo, move auton and alliance switches to util subsystems
- Loading branch information
1 parent
3a03f52
commit bc53932
Showing
10 changed files
with
369 additions
and
300 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
package frc.lib; | ||
|
||
import edu.wpi.first.wpilibj.DigitalInput; | ||
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard; | ||
import edu.wpi.first.wpilibj2.command.SubsystemBase; | ||
import frc.robot.Constants.AutoConstants.AllianceColor; | ||
|
||
import java.util.function.BooleanSupplier; | ||
|
||
public class AllianceSelector extends SubsystemBase{ | ||
|
||
private DigitalInput m_allianceSelectionSwitch; | ||
|
||
public AllianceSelector(int port) { | ||
this.m_allianceSelectionSwitch = new DigitalInput(port); | ||
} | ||
|
||
public BooleanSupplier fieldRotatedSupplier() { | ||
return () -> m_allianceSelectionSwitch.get(); | ||
} | ||
|
||
public AllianceColor getAllianceColor() { | ||
return m_allianceSelectionSwitch.get() ? AllianceColor.Red : AllianceColor.Blue; | ||
} | ||
|
||
@Override | ||
public void periodic() { | ||
SmartDashboard.putString("Alliance Color", getAllianceColor().name()); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
package frc.lib; | ||
|
||
import edu.wpi.first.wpilibj.DigitalInput; | ||
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard; | ||
import edu.wpi.first.wpilibj2.command.Command; | ||
import frc.robot.Constants.AutoConstants.AllianceColor; | ||
import frc.robot.Robot.AutoOption; | ||
import frc.robot.autos.ChoreoAuto; | ||
|
||
import java.util.List; | ||
|
||
public class AutoSelector { | ||
|
||
private DigitalInput[] m_switchPositions; | ||
private AllianceSelector m_allianceSelector; | ||
private List<AutoOption> m_autoOptions; | ||
|
||
private ChoreoAuto m_autonomous; | ||
|
||
public AutoSelector(int[] ports, AllianceSelector allianceSelector, List<AutoOption> autoOptions) { | ||
|
||
m_switchPositions = new DigitalInput[ports.length]; | ||
for (int i = 0; i < ports.length; i++) { | ||
m_switchPositions[i] = new DigitalInput(ports[i]); | ||
} | ||
|
||
this.m_allianceSelector = allianceSelector; | ||
this.m_autoOptions = autoOptions; | ||
} | ||
|
||
/** | ||
* @return Index in array of Digital Inputs corresponding to selected auto mode | ||
*/ | ||
private int getSwitchPosition() { | ||
for (int i = 0; i < m_switchPositions.length; i++) { | ||
if (!m_switchPositions[i].get()) { | ||
return i + 1; | ||
} | ||
} | ||
return 0; // failure of the physical switch | ||
} | ||
|
||
public ChoreoAuto getSelectedAutonomous() { | ||
int switchPosition = getSwitchPosition(); | ||
AllianceColor color = m_allianceSelector.getAllianceColor(); | ||
|
||
for (int i = 0; i < m_autoOptions.size(); i++) { | ||
if (m_autoOptions.get(i).getColor() == color) | ||
if (m_autoOptions.get(i).getOption() == switchPosition) { | ||
return m_autoOptions.get(i).getChoreoAuto(); | ||
} | ||
} | ||
return null; | ||
} | ||
|
||
/** | ||
* @return The Command that runs the selected autonomous mode | ||
*/ | ||
public Command getAutonomousCommand() { | ||
getSelectedAutonomous(); | ||
if (m_autonomous != null) return m_autonomous; | ||
else return null; | ||
} | ||
|
||
public void periodic() { | ||
|
||
if (m_autonomous != null) { | ||
SmartDashboard.putString("Auto", m_autonomous.getName()); | ||
} else { | ||
SmartDashboard.putString("Auto", "Null"); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.