package org.usfirst.frc.team3501.robot.subsystems;
import org.usfirst.frc.team3501.robot.Constants;
+import org.usfirst.frc.team3501.robot.sensors.Lidar;
-import edu.wpi.first.wpilibj.AnalogPotentiometer;
import edu.wpi.first.wpilibj.CANTalon;
import edu.wpi.first.wpilibj.CounterBase.EncodingType;
import edu.wpi.first.wpilibj.DoubleSolenoid;
private Lidar lidar;
public Shooter() {
- leftLidar = new AnalogPotentiometer(0);
- rightLidar = new AnalogPotentiometer(0);
shooter = new CANTalon(Constants.Shooter.PORT);
hood = new DoubleSolenoid(Constants.Shooter.HOOD_FORWARD,
Constants.Shooter.HOOD_REVERSE);
encoder = new Encoder(Constants.Shooter.ENCODER_PORT_A,
Constants.Shooter.ENCODER_PORT_B, false, EncodingType.k4X);
-
- lidar = new Lidar(Constants.Shooter.LIDAR_I2C_PORT);
}
/***
return encoder.getRate();
}
+ /*
+ * We are going to map a lidar distance to a shooter speed that will be set to
+ * the shooter. This function does not yet exist so we will just use y=x but
+ * when testing commences we shall create the function
+ */
+ public double getShooterSpeed() {
+ double distanceToGoal = lidar.getDistance();
+ double shooterSpeed = distanceToGoal; // Function to be determined
+ return shooterSpeed;
+ }
+
// Use negative # for decrement. Positive for increment.
public void changeSpeed(double change) {
punch.set(Constants.Shooter.retract);
}
- @Override
- protected void initDefaultCommand() {
- }
-
- public void openHood() {
+ public void raiseHood() {
hood.set(Constants.Shooter.open);
}
- public void closeHood() {
+ public void lowerHood() {
hood.set(Constants.Shooter.closed);
}