diff options
author | kartofen <mladenovnasko0@gmail.com> | 2024-03-03 23:20:11 +0200 |
---|---|---|
committer | kartofen <mladenovnasko0@gmail.com> | 2024-03-03 23:20:11 +0200 |
commit | 39f4c3f833ec119a0060cb833c7a1953bca76eef (patch) | |
tree | d943fd0f8d6f0e5edf423ee8ba24aabb671717c5 /src/main/java/frc/robot/subsystems/Chain.java | |
parent | b929a1d34690d3d7fed6686459ff803962ce907f (diff) |
more subsystems
Diffstat (limited to 'src/main/java/frc/robot/subsystems/Chain.java')
-rw-r--r-- | src/main/java/frc/robot/subsystems/Chain.java | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/src/main/java/frc/robot/subsystems/Chain.java b/src/main/java/frc/robot/subsystems/Chain.java new file mode 100644 index 0000000..2485739 --- /dev/null +++ b/src/main/java/frc/robot/subsystems/Chain.java @@ -0,0 +1,44 @@ +package frc.robot.subsystems; + +import org.littletonrobotics.junction.Logger; + +import com.revrobotics.CANSparkMax; + +import edu.wpi.first.math.controller.ProfiledPIDController; +import edu.wpi.first.wpilibj.Encoder; +import edu.wpi.first.wpilibj2.command.SubsystemBase; +import frc.robot.Constants; + +public class Chain extends SubsystemBase +{ + private final CANSparkMax m_motor = Constants.chain; + private final Encoder m_encoder = Constants.chain_encoder; + + private final ProfiledPIDController m_pid = new ProfiledPIDController(Constants.ChainkP, Constants.ChainkI, Constants.ChainkD, Constants.chain_constraints); + + public Chain() + { + // m_motor.setInverted(true); + // m_encoder.setReverseDirection(true); + + m_encoder.setDistancePerPulse(1.0/Constants.ChainEncoderScale); + m_encoder.reset(); + } + + public void reset() + { + m_encoder.reset(); + } + + // perc between 0 and 1; + public void atPercentage(double perc) + { + m_motor.setVoltage(m_pid.calculate(m_encoder.getDistance(), perc)); + } + + @Override + public void periodic() + { + Logger.recordOutput(getName() + "/position", m_encoder.getDistance()); + } +} |