16 Commits

Author SHA1 Message Date
a09fbcefce code mieux 2025-02-20 20:17:56 -05:00
7fd7c666f1 code mieux 2025-02-20 20:17:45 -05:00
29227dd2f6 code mieux 2025-02-20 20:10:58 -05:00
dc36eea320 requin 2025-02-19 17:21:37 -05:00
eaa14fb1b1 mieu ecrit 2025-02-12 16:52:10 -05:00
3458203225 leds baleeuse et saaaaaaaaaaam 2025-02-11 19:51:37 -05:00
6683613c7f command -> commands 2025-02-06 17:48:27 -05:00
2ac9cfe8ff simulation 2025-02-03 18:59:31 -05:00
56704c3e68 id 2025-02-03 18:53:33 -05:00
4c49ad4e51 touche requin 2025-01-29 19:45:46 -05:00
afe25cf046 pu L1 2025-01-29 19:41:28 -05:00
eec4eee2ff baleeuse 2025-01-28 19:34:18 -05:00
15be1d67ea L1 2025-01-28 18:05:47 -05:00
e4c7a12606 balaye 2025-01-28 18:02:53 -05:00
72da7b7d74 requin rotatione 2025-01-28 17:56:40 -05:00
fd8ab8663b baleeuse 2025-01-27 20:14:20 -05:00
10 changed files with 215 additions and 120 deletions

View File

@ -1,7 +1,12 @@
{ {
"System Joysticks": { "FMS": {
"window": { "window": {
"enabled": false "visible": false
}
},
"Joysticks": {
"window": {
"visible": false
} }
}, },
"keyboardJoysticks": [ "keyboardJoysticks": [
@ -93,5 +98,12 @@
"buttonCount": 0, "buttonCount": 0,
"povCount": 0 "povCount": 0
} }
],
"robotJoysticks": [
{},
{
"guid": "78696e70757401000000000000000000",
"useGamepad": true
}
] ]
} }

View File

@ -4,42 +4,32 @@
package frc.robot; package frc.robot;
import edu.wpi.first.math.MathUtil;
import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.Command;
import edu.wpi.first.wpilibj2.command.Commands; import edu.wpi.first.wpilibj2.command.Commands;
import edu.wpi.first.wpilibj2.command.RunCommand;
import edu.wpi.first.wpilibj2.command.button.CommandXboxController; import edu.wpi.first.wpilibj2.command.button.CommandXboxController;
import frc.robot.commands.GrimperHaut; import frc.robot.commands.BalayeuseAlgue;
import frc.robot.commands.GrimpeurBas; import frc.robot.commands.BalayeuseCoral;
import frc.robot.commands.GrimpeurManuel; import frc.robot.commands.BalayeuseHaut;
import frc.robot.commands.ResetGrimpeur; import frc.robot.commands.L1Requin;
import frc.robot.subsystems.Requin;
import frc.robot.subsystems.Bougie; import frc.robot.subsystems.Bougie;
import frc.robot.subsystems.Grimpeur;
public class RobotContainer { public class RobotContainer {
CommandXboxController manette1 = new CommandXboxController(0); CommandXboxController manette1 = new CommandXboxController(0);
CommandXboxController manette2 = new CommandXboxController(1); CommandXboxController manette2 = new CommandXboxController(1);
Grimpeur grimpeur = new Grimpeur(); Requin requin = new Requin();
Bougie bougie = new Bougie(); Bougie bougie = new Bougie();
GrimpeurManuel grimpeurManuel = new GrimpeurManuel(grimpeur, manette2::getLeftY);
public RobotContainer() { public RobotContainer() {
grimpeur.setDefaultCommand(new RunCommand(()->{
if(grimpeur.stop()){
grimpeur.grimpe(0);
}
else{
grimpeur.grimpe(MathUtil.applyDeadband(manette2.getLeftY(), 0.2));
}}, grimpeur));
configureBindings(); configureBindings();
} }
private void configureBindings() { private void configureBindings() {
manette2.leftBumper().whileTrue(new GrimperHaut(grimpeur,bougie)); manette2.b().whileTrue(new BalayeuseAlgue(requin));
manette2.rightBumper().whileTrue(new GrimpeurBas(grimpeur)); manette2.x().whileTrue(new BalayeuseCoral(requin));
manette2.a().whileTrue(new ResetGrimpeur(grimpeur)); manette2.y().whileTrue(new L1Requin(requin,bougie));
manette2.rightBumper().whileTrue(new BalayeuseHaut(requin));
} }
public Command getAutonomousCommand() { public Command getAutonomousCommand() {
return Commands.print("No autonomous command configured"); return Commands.print("No autonomous command configured");
} }
} }

View File

@ -4,20 +4,19 @@
package frc.robot.commands; package frc.robot.commands;
import java.util.function.DoubleSupplier;
import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.Command;
import frc.robot.subsystems.Grimpeur; import frc.robot.subsystems.Bougie;
import frc.robot.subsystems.Requin;
/* 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 */ /* 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 GrimpeurManuel extends Command { public class BalayeuseAlgue extends Command {
private Grimpeur grimpeur; private Requin requin;
private DoubleSupplier x; private Bougie bougie;
/** Creates a new GrimpeurManuel. */ /** Creates a new Balayeuse. */
public GrimpeurManuel(Grimpeur grimpeur,DoubleSupplier x) { public BalayeuseAlgue(Requin requin) {
this.grimpeur = grimpeur; this.requin = requin;
this.x = x; this.bougie =bougie;
addRequirements(grimpeur); addRequirements(requin,bougie);
// Use addRequirements() here to declare subsystem dependencies. // Use addRequirements() here to declare subsystem dependencies.
} }
@ -28,19 +27,31 @@ public class GrimpeurManuel 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.stop()){ if(requin.encodeur()>=500 && requin.encodeur()<=510){
grimpeur.grimpe(0); requin.rotationer(0);
} if(requin.stop()){
else{ requin.balaye(0);
grimpeur.grimpe(x.getAsDouble()); bougie.Vert();
} }
else{
requin.balaye(0.5);
}
}
else if(requin.encodeur()>=510){
requin.rotationer(0.5);
}
else{
requin.rotationer(-0.5);
}
} }
// Called once the command ends or is interrupted. // Called once the command ends or is interrupted.
@Override @Override
public void end(boolean interrupted) { public void end(boolean interrupted) {
grimpeur.grimpe(0); requin.rotationer(0);
requin.balaye(0);
} }
// Returns true when the command should end. // Returns true when the command should end.

View File

@ -5,15 +5,18 @@
package frc.robot.commands; package frc.robot.commands;
import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.Command;
import frc.robot.subsystems.Grimpeur; import frc.robot.subsystems.Bougie;
import frc.robot.subsystems.Requin;
/* 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 */ /* 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 GrimpeurBas extends Command { public class BalayeuseCoral extends Command {
private Grimpeur grimpeur; private Requin requin;
/** Creates a new GrimpeurBas. */ private Bougie bougie;
public GrimpeurBas(Grimpeur grimpeur) { /** Creates a new Balayeuse. */
this.grimpeur = grimpeur; public BalayeuseCoral(Requin requin) {
addRequirements(grimpeur); this.requin = requin;
this.bougie = bougie;
addRequirements(requin,bougie);
// Use addRequirements() here to declare subsystem dependencies. // Use addRequirements() here to declare subsystem dependencies.
} }
@ -24,20 +27,36 @@ 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()>=-38.5 && grimpeur.encodeur()<=-39.19){ if(requin.encodeur()>=100 && requin.encodeur()<=110){
grimpeur.grimpe(0); requin.rotationer(0);
if(requin.amp()>8){
requin.balaye(0);
bougie.Vert();
if(requin.enHaut()){
requin.rotationer(0);
}
else{
requin.rotationer(0.5);
}
} }
else if(grimpeur.encodeur()>=-38.5){ else{
grimpeur.grimpe(-0.5); requin.balaye(0.5);
} }
else{grimpeur.grimpe(0.5); }
} else if(requin.encodeur()>=110){
requin.rotationer(0.5);
}
else{
requin.rotationer(-0.5);
}
} }
// Called once the command ends or is interrupted. // Called once the command ends or is interrupted.
@Override @Override
public void end(boolean interrupted) { public void end(boolean interrupted) {
grimpeur.grimpe(0); requin.rotationer(0);
requin.balaye(0);
} }
// Returns true when the command should end. // Returns true when the command should end.

View File

@ -5,15 +5,15 @@
package frc.robot.commands; package frc.robot.commands;
import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.Command;
import frc.robot.subsystems.Grimpeur; import frc.robot.subsystems.Requin;
/* 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 */ /* 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 { public class BalayeuseHaut extends Command {
private Grimpeur grimpeur; private Requin requin;
/** Creates a new ResetGrimpeur. */ /** Creates a new Balayeuse. */
public ResetGrimpeur(Grimpeur grimpeur) { public BalayeuseHaut(Requin requin) {
this.grimpeur = grimpeur; this.requin = requin;
addRequirements(grimpeur); addRequirements(requin);
// Use addRequirements() here to declare subsystem dependencies. // Use addRequirements() here to declare subsystem dependencies.
} }
@ -24,12 +24,20 @@ public class ResetGrimpeur 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() {
grimpeur.reset(); if(requin.enHaut()==true){
requin.rotationer(0);
requin.reset();
}
else{
requin.rotationer(0.5);
}
} }
// Called once the command ends or is interrupted. // Called once the command ends or is interrupted.
@Override @Override
public void end(boolean interrupted) {} public void end(boolean interrupted) {
requin.rotationer(0);
}
// Returns true when the command should end. // Returns true when the command should end.
@Override @Override

View File

@ -5,15 +5,15 @@
package frc.robot.commands; package frc.robot.commands;
import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.Command;
import frc.robot.subsystems.Bougie; import frc.robot.subsystems.Requin;
/* 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 */ /* 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 RainBow extends Command { public class ExpireAlgue extends Command {
/** Creates a new RainBow. */ private Requin requin;
private Bougie bougie; /** Creates a new ExpireAlgue. */
public RainBow(Bougie bougie) { public ExpireAlgue(Requin requin) {
this.bougie = bougie; this.requin = requin;
addRequirements(bougie); addRequirements(requin);
// Use addRequirements() here to declare subsystem dependencies. // Use addRequirements() here to declare subsystem dependencies.
} }
@ -24,13 +24,13 @@ public class RainBow 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() {
bougie.RainBow(); requin.balaye(0.5);
} }
// Called once the command ends or is interrupted. // Called once the command ends or is interrupted.
@Override @Override
public void end(boolean interrupted) { public void end(boolean interrupted) {
bougie.RainBowStop(); requin.balaye(0);
} }
// Returns true when the command should end. // Returns true when the command should end.

View File

@ -6,17 +6,17 @@ package frc.robot.commands;
import edu.wpi.first.wpilibj2.command.Command; import edu.wpi.first.wpilibj2.command.Command;
import frc.robot.subsystems.Bougie; import frc.robot.subsystems.Bougie;
import frc.robot.subsystems.Grimpeur; import frc.robot.subsystems.Requin;
/* 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 */ /* 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 GrimperHaut extends Command { public class L1Requin extends Command {
private Grimpeur grimpeur; private Requin requin;
private Bougie bougie; private Bougie bougie;
/** Creates a new Grimper. */ /** Creates a new Balayeuse. */
public GrimperHaut(Grimpeur grimpeur, Bougie bougie) { public L1Requin(Requin requin,Bougie bougie) {
this.grimpeur = grimpeur; this.requin = requin;
this.bougie = bougie; this.bougie = bougie;
addRequirements(grimpeur,bougie); addRequirements(requin,bougie);
// Use addRequirements() here to declare subsystem dependencies. // Use addRequirements() here to declare subsystem dependencies.
} }
@ -27,30 +27,39 @@ public class GrimperHaut 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.stop()==true){
grimpeur.grimpe(0); if(requin.encodeur()>=800 && requin.encodeur()<=810){
grimpeur.reset(); requin.rotationer(0);
bougie.RainBow(); if(requin.amp()>8){
requin.balaye(-0.5);
}
else{
requin.balaye(0);
bougie.Rouge();
}
}
else if(requin.encodeur()>=810){
requin.rotationer(0.5);
} }
else{ else{
grimpeur.grimpe(0.5); requin.rotationer(-0.5);
bougie.RainBowStop();
} }
} }
// Called once the command ends or is interrupted. // Called once the command ends or is interrupted.
@Override @Override
public void end(boolean interrupted) { public void end(boolean interrupted) {
grimpeur.grimpe(0); requin.rotationer(0);
if(grimpeur.stop()){ requin.balaye(0);
bougie.RainBow();
}
} }
// Returns true when the command should end. // Returns true when the command should end.
@Override @Override
public boolean isFinished() { public boolean isFinished() {
return grimpeur.stop()==true; return false;
} }
} }

View File

@ -11,7 +11,7 @@ import com.ctre.phoenix.led.RainbowAnimation;
import edu.wpi.first.wpilibj2.command.SubsystemBase; import edu.wpi.first.wpilibj2.command.SubsystemBase;
public class Bougie extends SubsystemBase { public class Bougie extends SubsystemBase {
CANdle candle = new CANdle(5); CANdle candle = new CANdle(50);
CANdleConfiguration config = new CANdleConfiguration(); CANdleConfiguration config = new CANdleConfiguration();
RainbowAnimation rainbowAnim = new RainbowAnimation(1, 0.5, 64); RainbowAnimation rainbowAnim = new RainbowAnimation(1, 0.5, 64);
/** Creates a new Bougie. */ /** Creates a new Bougie. */
@ -20,14 +20,29 @@ public class Bougie extends SubsystemBase {
candle.configAllSettings(config); candle.configAllSettings(config);
} }
public void Rouge() { public void Rouge() {
candle.setLEDs(255, 0, 0); candle.setLEDs(255, 0, 0,0,8,8);
candle.setLEDs(255, 0, 0,0,24,8);
candle.setLEDs(255, 0, 0,0,40,8);
candle.setLEDs(255, 0, 0,0,56,8);
} }
public void Vert() { public void Vert() {
candle.setLEDs(0, 255, 0); candle.setLEDs(0, 255, 0,0,8,8);
candle.setLEDs(0, 255, 0,0,24,8);
candle.setLEDs(0, 255, 0,0,40,8);
candle.setLEDs(0, 255, 0,0,56,8);
} }
public void Bleu() { public void Bleu() {
candle.setLEDs(0, 0, 255); candle.setLEDs(0, 0, 255,0,16,8);
candle.setLEDs(0, 0, 255,0,32,8);
candle.setLEDs(0, 0, 255,0,48,8);
candle.setLEDs(0, 0, 255,0,64,8);
} }
public void Jaune() {
candle.setLEDs(255, 215, 0,0,16,8);
candle.setLEDs(255, 215, 0,0,32,8);
candle.setLEDs(255, 215, 0,0,48,8);
candle.setLEDs(255, 215, 0,0,64,8);
}
public void RainBow(){candle.animate(rainbowAnim);} public void RainBow(){candle.animate(rainbowAnim);}
public void RainBowStop(){candle.animate(null);} public void RainBowStop(){candle.animate(null);}
@Override @Override
@ -35,4 +50,3 @@ public class Bougie extends SubsystemBase {
// This method will be called once per scheduler run // This method will be called once per scheduler run
} }
} }

View File

@ -4,35 +4,21 @@
package frc.robot.subsystems; package frc.robot.subsystems;
import com.revrobotics.spark.SparkMax;
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.motorcontrol.Spark;
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. */
ShuffleboardTab teb = Shuffleboard.getTab("teb"); public Grimpeur() {}
public Grimpeur() { final Spark grimpeur = new Spark(16);
teb.addBoolean("limit grimpeur", this::stop); final DigitalInput limit1 = new DigitalInput(0);
teb.addDouble("encodeur grimpeur", this::encodeur);
}
final SparkMax grimpeur = new SparkMax(21,MotorType.kBrushless);
final DigitalInput limit1 = new DigitalInput(2);
public void grimpe(double vitesse){ public void grimpe(double vitesse){
grimpeur.set(vitesse); grimpeur.set(vitesse);
} }
public boolean stop(){ final void stop(){
return limit1.get(); limit1.get();
} }
public double encodeur(){
return grimpeur.getEncoder().getPosition();
}
public void reset(){
grimpeur.getEncoder().setPosition(0);
}
@Override @Override
public void periodic() { public void periodic() {
// This method will be called once per scheduler run // This method will be called once per scheduler run

View File

@ -0,0 +1,46 @@
// 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.subsystems;
import com.revrobotics.spark.SparkFlex;
import com.revrobotics.spark.SparkMax;
import com.revrobotics.spark.SparkLowLevel.MotorType;
import edu.wpi.first.wpilibj.DigitalInput;
import edu.wpi.first.wpilibj2.command.SubsystemBase;
public class Requin extends SubsystemBase {
/** Creates a new Requin. */
public Requin() {}
final SparkFlex balaye = new SparkFlex(15, MotorType.kBrushless);
final SparkMax rotatione = new SparkMax(17, MotorType.kBrushless);
final DigitalInput limit3 = new DigitalInput(4);
final DigitalInput limit5 = new DigitalInput(5);
public void balaye(double vitesse){
balaye.set(vitesse);
}
public void rotationer(double vitesse){
rotatione.set(vitesse);
}
public boolean enHaut(){
return limit3.get();
}
public boolean stop(){
return limit5.get();
}
public double encodeur(){
return rotatione.getEncoder().getPosition();
}
public void reset(){
rotatione.getEncoder().setPosition(0);
}
public double amp(){
return balaye.getOutputCurrent();
}
@Override
public void periodic() {
// This method will be called once per scheduler run
}
}