Grimpeur, Fonctionne

This commit is contained in:
Antoine PerreaultE 2025-02-26 19:09:33 -05:00
parent 9b86a0b975
commit 63e476c64e
4 changed files with 64 additions and 14 deletions

View File

@ -12,6 +12,7 @@ import edu.wpi.first.wpilibj2.command.button.CommandXboxController;
import frc.robot.commands.GrimperHaut; import frc.robot.commands.GrimperHaut;
import frc.robot.commands.GrimpeurBas; import frc.robot.commands.GrimpeurBas;
import frc.robot.commands.GrimpeurManuel; import frc.robot.commands.GrimpeurManuel;
import frc.robot.commands.ResetGrimpeur;
import frc.robot.subsystems.Bougie; import frc.robot.subsystems.Bougie;
import frc.robot.subsystems.Grimpeur; import frc.robot.subsystems.Grimpeur;
@ -20,17 +21,22 @@ public class RobotContainer {
CommandXboxController manette2 = new CommandXboxController(1); CommandXboxController manette2 = new CommandXboxController(1);
Grimpeur grimpeur = new Grimpeur(); Grimpeur grimpeur = new Grimpeur();
Bougie bougie = new Bougie(); Bougie bougie = new Bougie();
GrimpeurManuel grimpeurManuel = new GrimpeurManuel(grimpeur, manette1::getLeftY); GrimpeurManuel grimpeurManuel = new GrimpeurManuel(grimpeur, manette2::getLeftY);
public RobotContainer() { public RobotContainer() {
grimpeur.setDefaultCommand(new RunCommand(()->{ grimpeur.setDefaultCommand(new RunCommand(()->{
grimpeur.grimpe(MathUtil.applyDeadband(manette2.getLeftY(), 0.2)); if(grimpeur.stop()){
}, grimpeur)); grimpeur.grimpe(0);
}
else{
grimpeur.grimpe(MathUtil.applyDeadband(manette2.getLeftY(), 0.2));
}}, grimpeur));
configureBindings(); configureBindings();
} }
private void configureBindings() { private void configureBindings() {
manette1.leftBumper().whileTrue(new GrimperHaut(grimpeur,bougie)); manette2.leftBumper().whileTrue(new GrimperHaut(grimpeur,bougie));
manette1.rightBumper().whileTrue(new GrimpeurBas(grimpeur)); manette2.rightBumper().whileTrue(new GrimpeurBas(grimpeur));
manette2.a().whileTrue(new ResetGrimpeur(grimpeur));
} }
public Command getAutonomousCommand() { public Command getAutonomousCommand() {

View File

@ -24,13 +24,13 @@ public class GrimpeurBas extends Command {
// Called every time the scheduler runs while the command is scheduled. // Called every time the scheduler runs while the command is scheduled.
@Override @Override
public void execute() { public void execute() {
if(grimpeur.encodeur()>=500 && grimpeur.encodeur()<=510){ if(grimpeur.encodeur()>=-38.5 && grimpeur.encodeur()<=-39.19){
grimpeur.grimpe(0); grimpeur.grimpe(0);
} }
else if(grimpeur.encodeur()>=510){ else if(grimpeur.encodeur()>=-38.5){
grimpeur.grimpe(0.5); grimpeur.grimpe(-0.5);
} }
else{grimpeur.grimpe(-0.5); else{grimpeur.grimpe(0.5);
} }
} }

View File

@ -0,0 +1,39 @@
// 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 frc.robot.commands;
import edu.wpi.first.wpilibj2.command.Command;
import frc.robot.subsystems.Grimpeur;
/* You should consider using the more terse Command factories API instead https://docs.wpilib.org/en/stable/docs/software/commandbased/organizing-command-based.html#defining-commands */
public class ResetGrimpeur extends Command {
private Grimpeur grimpeur;
/** Creates a new ResetGrimpeur. */
public ResetGrimpeur(Grimpeur grimpeur) {
this.grimpeur = grimpeur;
addRequirements(grimpeur);
// Use addRequirements() here to declare subsystem dependencies.
}
// Called when the command is initially scheduled.
@Override
public void initialize() {}
// Called every time the scheduler runs while the command is scheduled.
@Override
public void execute() {
grimpeur.reset();
}
// Called once the command ends or is interrupted.
@Override
public void end(boolean interrupted) {}
// Returns true when the command should end.
@Override
public boolean isFinished() {
return false;
}
}

View File

@ -8,14 +8,19 @@ import com.revrobotics.spark.SparkMax;
import com.revrobotics.spark.SparkLowLevel.MotorType; import com.revrobotics.spark.SparkLowLevel.MotorType;
import edu.wpi.first.wpilibj.DigitalInput; import edu.wpi.first.wpilibj.DigitalInput;
import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard;
import edu.wpi.first.wpilibj.shuffleboard.ShuffleboardTab;
import edu.wpi.first.wpilibj2.command.SubsystemBase; import edu.wpi.first.wpilibj2.command.SubsystemBase;
public class Grimpeur extends SubsystemBase { public class Grimpeur extends SubsystemBase {
/** Creates a new Grimpeur. */ /** Creates a new Grimpeur. */
public Grimpeur() {} ShuffleboardTab teb = Shuffleboard.getTab("teb");
public Grimpeur() {
teb.addBoolean("limit grimpeur", this::stop);
teb.addDouble("encodeur grimpeur", this::encodeur);
}
final SparkMax grimpeur = new SparkMax(21,MotorType.kBrushless); final SparkMax grimpeur = new SparkMax(21,MotorType.kBrushless);
final DigitalInput limit1 = new DigitalInput(3); final DigitalInput limit1 = new DigitalInput(2);
public void grimpe(double vitesse){ public void grimpe(double vitesse){
grimpeur.set(vitesse); grimpeur.set(vitesse);
} }