Compare commits
45 Commits
Author | SHA1 | Date | |
---|---|---|---|
e58cdf0b5b | |||
9f83b61c46 | |||
5d84d83f7d | |||
87c3abcb65 | |||
93e5bb0b46 | |||
7be5f8c2fc | |||
26d32e3707 | |||
1f4111ef6d | |||
bb9d5a5550 | |||
69ef6b6982 | |||
0be9356fa9 | |||
1627770572 | |||
c1bdf0aab7 | |||
0e04704942 | |||
53adcf5701 | |||
319c370c6e | |||
451d3c6e20 | |||
2260580c81 | |||
9cd08cf07c | |||
8aca411a23 | |||
44f6030e99 | |||
6f75b9cc42 | |||
210d219793 | |||
06abfa4dbb | |||
26a4b9f9a3 | |||
b384585224 | |||
ee2c9ff4b2 | |||
20c95efe93 | |||
4869632d6d | |||
afaec61f6d | |||
126058e9d4 | |||
1f17aaf4de | |||
eece0f47fa | |||
c81f118058 | |||
7848c4aaf2 | |||
1d1d6e962d | |||
d6420659e9 | |||
aafb2a62b5 | |||
0fdfa4269d | |||
017f168b3c | |||
5ffa28596c | |||
e7b4b47928 | |||
0577ce368a | |||
7521c0d94e | |||
b16d11b70a |
1
.SysId/sysid.json
Normal file
1
.SysId/sysid.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
@ -1,4 +1,9 @@
|
|||||||
{
|
{
|
||||||
|
"Joysticks": {
|
||||||
|
"window": {
|
||||||
|
"visible": false
|
||||||
|
}
|
||||||
|
},
|
||||||
"System Joysticks": {
|
"System Joysticks": {
|
||||||
"window": {
|
"window": {
|
||||||
"enabled": false
|
"enabled": false
|
||||||
|
@ -4,39 +4,74 @@
|
|||||||
|
|
||||||
package frc.robot;
|
package frc.robot;
|
||||||
|
|
||||||
|
import com.pathplanner.lib.auto.NamedCommands;
|
||||||
import edu.wpi.first.math.MathUtil;
|
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.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.Algue1Test;
|
||||||
import frc.robot.commands.GrimpeurBas;
|
import frc.robot.commands.Algue2Test;
|
||||||
import frc.robot.commands.GrimpeurManuel;
|
import frc.robot.commands.AlgueExpire;
|
||||||
import frc.robot.commands.ResetGrimpeur;
|
import frc.robot.commands.CorailAspir;
|
||||||
|
import frc.robot.commands.CorailTest;
|
||||||
|
import frc.robot.commands.CoralAlgueInspire;
|
||||||
|
import frc.robot.commands.CoralExpire;
|
||||||
|
import frc.robot.commands.Depart;
|
||||||
|
import frc.robot.commands.DepartPince;
|
||||||
|
import frc.robot.commands.ElevateurManuel;
|
||||||
|
import frc.robot.commands.L2;
|
||||||
|
import frc.robot.commands.L3;
|
||||||
|
import frc.robot.commands.L4;
|
||||||
|
import frc.robot.commands.PinceManuel;
|
||||||
|
import frc.robot.commands.PinceManuel2;
|
||||||
|
import frc.robot.commands.StationPince;
|
||||||
|
import frc.robot.commands.reset;
|
||||||
|
import frc.robot.subsystems.Elevateur;
|
||||||
|
import frc.robot.subsystems.Pince;
|
||||||
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();
|
|
||||||
Bougie bougie = new Bougie();
|
Bougie bougie = new Bougie();
|
||||||
GrimpeurManuel grimpeurManuel = new GrimpeurManuel(grimpeur, manette2::getLeftY);
|
Pince pince = new Pince();
|
||||||
|
Elevateur elevateur = new Elevateur();
|
||||||
|
ElevateurManuel elevateurManuel = new ElevateurManuel(elevateur, manette2::getLeftY);
|
||||||
|
PinceManuel pinceManuel = new PinceManuel(pince,manette2::getRightY);
|
||||||
|
PinceManuel2 pinceManuel2 = new PinceManuel2(pince);
|
||||||
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();
|
||||||
|
elevateur.setDefaultCommand(new RunCommand(()->{
|
||||||
|
elevateur.vitesse(MathUtil.applyDeadband(manette2.getLeftY(), 0.2));
|
||||||
|
}, elevateur));
|
||||||
|
pince.setDefaultCommand(new RunCommand(()->{
|
||||||
|
pince.pivote(MathUtil.applyDeadband(manette2.getRightY()/5, 0.2));
|
||||||
|
}, pince));
|
||||||
|
NamedCommands.registerCommand("Station",new StationPince(pince, elevateur));
|
||||||
|
NamedCommands.registerCommand("L4", new L4(elevateur, pince));
|
||||||
|
NamedCommands.registerCommand("L3", new L3(elevateur, pince));
|
||||||
|
NamedCommands.registerCommand("CoralExpire",new CoralExpire(pince,bougie));
|
||||||
|
NamedCommands.registerCommand("CoraletAlgue", new CoralAlgueInspire(pince,bougie));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void configureBindings() {
|
private void configureBindings() {
|
||||||
manette2.leftBumper().whileTrue(new GrimperHaut(grimpeur,bougie));
|
// manette1
|
||||||
manette2.rightBumper().whileTrue(new GrimpeurBas(grimpeur));
|
manette1.a().whileTrue(new Depart(elevateur, pince));
|
||||||
manette2.a().whileTrue(new ResetGrimpeur(grimpeur));
|
manette1.b().whileTrue(new L2(elevateur,pince));
|
||||||
|
manette1.x().whileTrue(new L3(elevateur, pince));
|
||||||
|
manette1.y().whileTrue(new L4(elevateur, pince));
|
||||||
|
manette1.rightTrigger().whileTrue(new CoralAlgueInspire(pince, bougie));
|
||||||
|
manette1.rightBumper().whileTrue(new StationPince(pince, elevateur));
|
||||||
|
//manette2
|
||||||
|
manette2.leftTrigger().whileTrue(new AlgueExpire(pince, bougie));
|
||||||
|
manette2.a().whileTrue(new CorailAspir(pince));
|
||||||
|
manette2.b().whileTrue(new CoralExpire(pince, bougie));
|
||||||
|
manette2.povLeft().whileTrue(new Algue1Test(pince));
|
||||||
|
manette2.povRight().whileTrue(new Algue2Test(pince));
|
||||||
|
manette2.x().whileTrue(new CorailTest(pince));
|
||||||
|
manette2.start().whileTrue(new reset(elevateur));
|
||||||
}
|
}
|
||||||
|
|
||||||
public Command getAutonomousCommand() {
|
public Command getAutonomousCommand() {
|
||||||
|
@ -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.Pince;
|
||||||
|
|
||||||
/* 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 Algue1Test extends Command {
|
||||||
/** Creates a new RainBow. */
|
private Pince pince;
|
||||||
private Bougie bougie;
|
/** Creates a new AlgueTest. */
|
||||||
public RainBow(Bougie bougie) {
|
public Algue1Test(Pince pince) {
|
||||||
this.bougie = bougie;
|
this.pince = pince;
|
||||||
addRequirements(bougie);
|
addRequirements(pince);
|
||||||
// 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();
|
pince.algue1Test(0.2);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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();
|
pince.algue1Test(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns true when the command should end.
|
// Returns true when the command should end.
|
41
src/main/java/frc/robot/commands/Algue2Test.java
Normal file
41
src/main/java/frc/robot/commands/Algue2Test.java
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
// 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.Pince;
|
||||||
|
|
||||||
|
/* 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 Algue2Test extends Command {
|
||||||
|
private Pince pince;
|
||||||
|
/** Creates a new AlgueTest. */
|
||||||
|
public Algue2Test(Pince pince) {
|
||||||
|
this.pince = pince;
|
||||||
|
addRequirements(pince);
|
||||||
|
// 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() {
|
||||||
|
pince.algue2Test(0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
pince.algue2Test(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
@ -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.Pince;
|
||||||
|
|
||||||
/* 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 AlgueExpire extends Command {
|
||||||
private Grimpeur grimpeur;
|
private Pince pince;
|
||||||
private Bougie bougie;
|
private Bougie bougie;
|
||||||
/** Creates a new Grimper. */
|
/** Creates a new CoralAlgue. */
|
||||||
public GrimperHaut(Grimpeur grimpeur, Bougie bougie) {
|
public AlgueExpire(Pince pince,Bougie bougie) {
|
||||||
this.grimpeur = grimpeur;
|
this.pince = pince;
|
||||||
this.bougie = bougie;
|
this.bougie = bougie;
|
||||||
addRequirements(grimpeur,bougie);
|
addRequirements(pince,bougie);
|
||||||
// Use addRequirements() here to declare subsystem dependencies.
|
// Use addRequirements() here to declare subsystem dependencies.
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -27,30 +27,25 @@ 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){
|
if(pince.emperagealgue()>60){
|
||||||
grimpeur.grimpe(0);
|
pince.aspirealgue(-0.5);
|
||||||
grimpeur.reset();
|
|
||||||
bougie.RainBow();
|
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
grimpeur.grimpe(0.5);
|
pince.aspirealgue(-0.5);
|
||||||
bougie.RainBowStop();
|
bougie.Jaune();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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);
|
pince.aspirealgue(0);
|
||||||
if(grimpeur.stop()){
|
|
||||||
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;
|
||||||
}
|
}
|
||||||
}
|
}
|
42
src/main/java/frc/robot/commands/CorailAspir.java
Normal file
42
src/main/java/frc/robot/commands/CorailAspir.java
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
// 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.Pince;
|
||||||
|
|
||||||
|
/* 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 CorailAspir extends Command {
|
||||||
|
/** Creates a new CorailAspir. */
|
||||||
|
private Pince pince;
|
||||||
|
public CorailAspir(Pince pince) {
|
||||||
|
// Use addRequirements() here to declare subsystem dependencies.
|
||||||
|
this.pince = pince;
|
||||||
|
addRequirements(pince);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 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() {
|
||||||
|
|
||||||
|
pince.aspirecoral(0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
pince.aspirecoral(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
41
src/main/java/frc/robot/commands/CorailTest.java
Normal file
41
src/main/java/frc/robot/commands/CorailTest.java
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
// 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.Pince;
|
||||||
|
|
||||||
|
/* 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 CorailTest extends Command {
|
||||||
|
private Pince pince;
|
||||||
|
/** Creates a new AlgueTest. */
|
||||||
|
public CorailTest(Pince pince) {
|
||||||
|
this.pince = pince;
|
||||||
|
addRequirements(pince);
|
||||||
|
// 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() {
|
||||||
|
pince.aspirecoral(0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
pince.aspirecoral(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
53
src/main/java/frc/robot/commands/CoralAlgueInspire.java
Normal file
53
src/main/java/frc/robot/commands/CoralAlgueInspire.java
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
// 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.Bougie;
|
||||||
|
import frc.robot.subsystems.Pince;
|
||||||
|
|
||||||
|
/* 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 CoralAlgueInspire extends Command {
|
||||||
|
private Pince pince;
|
||||||
|
private Bougie bougie;
|
||||||
|
/** Creates a new CoralAlgue. */
|
||||||
|
public CoralAlgueInspire(Pince pince, Bougie bougie) {
|
||||||
|
this.pince = pince;
|
||||||
|
this.bougie = bougie;
|
||||||
|
addRequirements(pince,bougie);
|
||||||
|
// 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() {
|
||||||
|
pince.aspirecoral(-.5);
|
||||||
|
if(pince.emperagealgue()>60){
|
||||||
|
pince.aspirealgue(0);
|
||||||
|
bougie.Bleu();
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
pince.aspirealgue(0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
pince.aspirecoral(0);
|
||||||
|
pince.aspirealgue(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
49
src/main/java/frc/robot/commands/CoralExpire.java
Normal file
49
src/main/java/frc/robot/commands/CoralExpire.java
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
// 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.Pince;
|
||||||
|
import frc.robot.subsystems.Bougie;
|
||||||
|
/* 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 CoralExpire extends Command {
|
||||||
|
private Pince pince;
|
||||||
|
Bougie bougie;
|
||||||
|
/** Creates a new CoralAlgue. */
|
||||||
|
public CoralExpire(Pince pince, Bougie bougie) {
|
||||||
|
this.pince = pince;
|
||||||
|
this.bougie = bougie;
|
||||||
|
addRequirements(pince,bougie);
|
||||||
|
// 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() {
|
||||||
|
//if(pince.emperagecoral() > 60){
|
||||||
|
// pince.aspirecoral(0);
|
||||||
|
//}
|
||||||
|
//else{
|
||||||
|
pince.aspirecoral(-.5);
|
||||||
|
//bougie.Jaune();
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
pince.aspirecoral(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
52
src/main/java/frc/robot/commands/Depart.java
Normal file
52
src/main/java/frc/robot/commands/Depart.java
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
// 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.Elevateur;
|
||||||
|
import frc.robot.subsystems.Pince;
|
||||||
|
|
||||||
|
/* 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 Depart extends Command {
|
||||||
|
private Elevateur elevateur;
|
||||||
|
private Pince pince;
|
||||||
|
/** Creates a new L2. */
|
||||||
|
public Depart(Elevateur elevateur, Pince pince) {
|
||||||
|
this.pince = pince;
|
||||||
|
this.elevateur = elevateur;
|
||||||
|
addRequirements(elevateur,pince);
|
||||||
|
// 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() {
|
||||||
|
if(elevateur.limit2()==true){
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
elevateur.reset();
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
elevateur.vitesse(.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return elevateur.limit2()==true;
|
||||||
|
}
|
||||||
|
}
|
@ -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.Pince;
|
||||||
|
|
||||||
/* 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 DepartPince extends Command {
|
||||||
private Grimpeur grimpeur;
|
private Pince pince;
|
||||||
/** Creates a new GrimpeurBas. */
|
/** Creates a new DepartPince. */
|
||||||
public GrimpeurBas(Grimpeur grimpeur) {
|
public DepartPince(Pince pince) {
|
||||||
this.grimpeur = grimpeur;
|
this.pince = pince;
|
||||||
addRequirements(grimpeur);
|
addRequirements(pince);
|
||||||
// Use addRequirements() here to declare subsystem dependencies.
|
// Use addRequirements() here to declare subsystem dependencies.
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -24,20 +24,19 @@ 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(pince.position()==true){
|
||||||
grimpeur.grimpe(0);
|
pince.pivote(0);
|
||||||
|
pince.reset();
|
||||||
}
|
}
|
||||||
else if(grimpeur.encodeur()>=-38.5){
|
else{
|
||||||
grimpeur.grimpe(-0.5);
|
pince.pivote(.2);
|
||||||
}
|
}
|
||||||
else{grimpeur.grimpe(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);
|
pince.pivote(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns true when the command should end.
|
// Returns true when the command should end.
|
48
src/main/java/frc/robot/commands/ElevateurManuel.java
Normal file
48
src/main/java/frc/robot/commands/ElevateurManuel.java
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
// 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 java.util.function.DoubleSupplier;
|
||||||
|
|
||||||
|
import edu.wpi.first.wpilibj2.command.Command;
|
||||||
|
import frc.robot.subsystems.Elevateur;
|
||||||
|
|
||||||
|
/* 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 ElevateurManuel extends Command {
|
||||||
|
private DoubleSupplier doubleSupplier;
|
||||||
|
private Elevateur elevateur;
|
||||||
|
/** Creates a new ElevateurManuel. */
|
||||||
|
public ElevateurManuel(Elevateur elevateur,DoubleSupplier doubleSupplier) {
|
||||||
|
this.doubleSupplier = doubleSupplier;
|
||||||
|
this.elevateur = elevateur;
|
||||||
|
addRequirements(elevateur);
|
||||||
|
// 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() {
|
||||||
|
if(elevateur.limit2()==true){
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
}
|
||||||
|
elevateur.vitesse(doubleSupplier.getAsDouble()/7);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
65
src/main/java/frc/robot/commands/L2.java
Normal file
65
src/main/java/frc/robot/commands/L2.java
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
// 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.Elevateur;
|
||||||
|
import frc.robot.subsystems.Pince;
|
||||||
|
|
||||||
|
/* 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 L2 extends Command {
|
||||||
|
private Elevateur elevateur;
|
||||||
|
private Pince pince;
|
||||||
|
/** Creates a new L2. */
|
||||||
|
public L2(Elevateur elevateur,Pince pince) {
|
||||||
|
this.elevateur = elevateur;
|
||||||
|
this.pince = pince;
|
||||||
|
addRequirements(elevateur,pince);
|
||||||
|
// 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() {
|
||||||
|
if(elevateur.position()>=500 && elevateur.position()<=510){
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
}
|
||||||
|
else if(elevateur.position()>=510){
|
||||||
|
elevateur.vitesse(0.3);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
elevateur.vitesse(.3);
|
||||||
|
}
|
||||||
|
if(pince.encodeurpivot()>=500 && pince.encodeurpivot()<=510){
|
||||||
|
pince.pivote(0);
|
||||||
|
|
||||||
|
}
|
||||||
|
else if(pince.encodeurpivot()>=510){
|
||||||
|
pince.pivote(0.2);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
pince.pivote(-0.2);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
63
src/main/java/frc/robot/commands/L3.java
Normal file
63
src/main/java/frc/robot/commands/L3.java
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
// 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.Elevateur;
|
||||||
|
import frc.robot.subsystems.Pince;
|
||||||
|
|
||||||
|
/* 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 L3 extends Command {
|
||||||
|
private Elevateur elevateur;
|
||||||
|
private Pince pince;
|
||||||
|
/** Creates a new L2. */
|
||||||
|
public L3(Elevateur elevateur,Pince pince) {
|
||||||
|
this.elevateur = elevateur;
|
||||||
|
this.pince = pince;
|
||||||
|
addRequirements(elevateur,pince);
|
||||||
|
// 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() {
|
||||||
|
if(elevateur.position()>=700 && elevateur.position()<=710){
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
}
|
||||||
|
else if(elevateur.position()>=510){
|
||||||
|
elevateur.vitesse(0.5);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
elevateur.vitesse(-.5);
|
||||||
|
}
|
||||||
|
if(pince.encodeurpivot()>=700 && pince.encodeurpivot()<=710){
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
else if(pince.encodeurpivot()>=710){
|
||||||
|
pince.pivote(0.2);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
pince.pivote(-0.2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
63
src/main/java/frc/robot/commands/L4.java
Normal file
63
src/main/java/frc/robot/commands/L4.java
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
// 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.Elevateur;
|
||||||
|
import frc.robot.subsystems.Pince;
|
||||||
|
|
||||||
|
/* 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 L4 extends Command {
|
||||||
|
private Elevateur elevateur;
|
||||||
|
private Pince pince;
|
||||||
|
/** Creates a new L2. */
|
||||||
|
public L4(Elevateur elevateur,Pince pince) {
|
||||||
|
this.elevateur = elevateur;
|
||||||
|
this.pince = pince;
|
||||||
|
addRequirements(elevateur,pince);
|
||||||
|
// 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() {
|
||||||
|
if(elevateur.position()>=800 && elevateur.position()<=809){
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
}
|
||||||
|
else if(elevateur.position()>=810){
|
||||||
|
elevateur.vitesse(0.5);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
elevateur.vitesse(.5);
|
||||||
|
}
|
||||||
|
if(pince.encodeurpivot()>=800 && pince.encodeurpivot()<=809){
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
else if(pince.encodeurpivot()>=810){
|
||||||
|
pince.pivote(0.2);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
pince.pivote(-0.2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
@ -3,21 +3,21 @@
|
|||||||
// the WPILib BSD license file in the root directory of this project.
|
// the WPILib BSD license file in the root directory of this project.
|
||||||
|
|
||||||
package frc.robot.commands;
|
package frc.robot.commands;
|
||||||
|
|
||||||
import java.util.function.DoubleSupplier;
|
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.Pince;
|
||||||
|
|
||||||
/* 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 PinceManuel extends Command {
|
||||||
private Grimpeur grimpeur;
|
private Pince pince;
|
||||||
private DoubleSupplier x;
|
private DoubleSupplier x;
|
||||||
/** Creates a new GrimpeurManuel. */
|
/** Creates a new PinceManuel. */
|
||||||
public GrimpeurManuel(Grimpeur grimpeur,DoubleSupplier x) {
|
public PinceManuel(Pince pince, DoubleSupplier x) {
|
||||||
this.grimpeur = grimpeur;
|
this.pince = pince;
|
||||||
this.x = x;
|
this.x = x;
|
||||||
addRequirements(grimpeur);
|
//this.doubleSupplier = doubleSupplier;
|
||||||
|
addRequirements(pince);
|
||||||
// Use addRequirements() here to declare subsystem dependencies.
|
// Use addRequirements() here to declare subsystem dependencies.
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -28,19 +28,18 @@ 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(pince.position()){
|
||||||
grimpeur.grimpe(0);
|
pince.pivote(0);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
grimpeur.grimpe(x.getAsDouble());
|
pince.pivote(x.getAsDouble());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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);
|
pince.pivote(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns true when the command should end.
|
// Returns true when the command should end.
|
47
src/main/java/frc/robot/commands/PinceManuel2.java
Normal file
47
src/main/java/frc/robot/commands/PinceManuel2.java
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
// 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.Pince;
|
||||||
|
|
||||||
|
/* 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 PinceManuel2 extends Command {
|
||||||
|
private Pince pince;
|
||||||
|
//private DoubleSupplier doubleSupplier;
|
||||||
|
/** Creates a new PinceManuel. */
|
||||||
|
public PinceManuel2(Pince pince
|
||||||
|
|
||||||
|
//,DoubleSupplier doubleSupplier
|
||||||
|
) {
|
||||||
|
this.pince = pince;
|
||||||
|
// this.doubleSupplier = doubleSupplier;
|
||||||
|
addRequirements(pince);
|
||||||
|
// 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() {
|
||||||
|
|
||||||
|
pince.pivote(-0.2);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
64
src/main/java/frc/robot/commands/StationPince.java
Normal file
64
src/main/java/frc/robot/commands/StationPince.java
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
// 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.Elevateur;
|
||||||
|
import frc.robot.subsystems.Pince;
|
||||||
|
|
||||||
|
/* 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 StationPince extends Command {
|
||||||
|
|
||||||
|
private Pince pince;
|
||||||
|
private Elevateur elevateur;
|
||||||
|
/** Creates a new L2Pince. */
|
||||||
|
public StationPince(Pince pince,Elevateur elevateur) {
|
||||||
|
this.elevateur = elevateur;
|
||||||
|
this.pince = pince;
|
||||||
|
addRequirements(pince,elevateur);
|
||||||
|
// 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() {
|
||||||
|
pince.aspirecoral(0.5);
|
||||||
|
if(pince.encodeurpivot()>=900 && pince.encodeurpivot()<=910){
|
||||||
|
pince.pivote(0);
|
||||||
|
}
|
||||||
|
else if(pince.encodeurpivot()>=910){
|
||||||
|
pince.pivote(0.2);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
pince.pivote(-0.2);
|
||||||
|
}
|
||||||
|
if(elevateur.position()>=400 && elevateur.position()<=410){
|
||||||
|
elevateur.vitesse(0);
|
||||||
|
}
|
||||||
|
else if(elevateur.position()>=410){
|
||||||
|
elevateur.vitesse(0.3);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
elevateur.vitesse(-.3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called once the command ends or is interrupted.
|
||||||
|
@Override
|
||||||
|
public void end(boolean interrupted) {
|
||||||
|
pince.pivote(0);
|
||||||
|
pince.aspirecoral(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns true when the command should end.
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
@ -5,16 +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.Elevateur;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* 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 reset extends Command {
|
||||||
private Grimpeur grimpeur;
|
/** Creates a new reset. */
|
||||||
/** Creates a new ResetGrimpeur. */
|
private Elevateur elevateur;
|
||||||
public ResetGrimpeur(Grimpeur grimpeur) {
|
public reset(Elevateur elevateur) {
|
||||||
this.grimpeur = grimpeur;
|
|
||||||
addRequirements(grimpeur);
|
|
||||||
// Use addRequirements() here to declare subsystem dependencies.
|
// Use addRequirements() here to declare subsystem dependencies.
|
||||||
|
this.elevateur = elevateur;
|
||||||
|
addRequirements(elevateur);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Called when the command is initially scheduled.
|
// Called when the command is initially scheduled.
|
||||||
@ -24,7 +26,7 @@ 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();
|
elevateur.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Called once the command ends or is interrupted.
|
// Called once the command ends or is interrupted.
|
@ -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(23);
|
||||||
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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
37
src/main/java/frc/robot/subsystems/Elevateur.java
Normal file
37
src/main/java/frc/robot/subsystems/Elevateur.java
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
// 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 edu.wpi.first.networktables.GenericEntry;
|
||||||
|
import edu.wpi.first.wpilibj.DigitalInput;
|
||||||
|
import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard;
|
||||||
|
import edu.wpi.first.wpilibj2.command.SubsystemBase;
|
||||||
|
import com.revrobotics.spark.SparkMax;
|
||||||
|
import com.revrobotics.spark.SparkLowLevel.MotorType;
|
||||||
|
public class Elevateur extends SubsystemBase {
|
||||||
|
/** Creates a new Elevateur. */
|
||||||
|
public Elevateur() {}
|
||||||
|
final SparkMax monte = new SparkMax(22, MotorType.kBrushless);
|
||||||
|
final DigitalInput limit2 = new DigitalInput(1);
|
||||||
|
GenericEntry teb = Shuffleboard.getTab("teb")
|
||||||
|
.add("elevateur encodeur",position())
|
||||||
|
.getEntry();
|
||||||
|
public double position(){
|
||||||
|
return monte.getEncoder().getPosition();
|
||||||
|
}
|
||||||
|
public void vitesse(double vitesse){
|
||||||
|
monte.set(vitesse);
|
||||||
|
}
|
||||||
|
public boolean limit2(){
|
||||||
|
return limit2.get();
|
||||||
|
}
|
||||||
|
public void reset(){
|
||||||
|
monte.getEncoder().setPosition(0);
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public void periodic() {
|
||||||
|
// This method will be called once per scheduler run
|
||||||
|
}
|
||||||
|
}
|
@ -1,40 +0,0 @@
|
|||||||
// 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.SparkMax;
|
|
||||||
import com.revrobotics.spark.SparkLowLevel.MotorType;
|
|
||||||
|
|
||||||
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;
|
|
||||||
|
|
||||||
public class Grimpeur extends SubsystemBase {
|
|
||||||
/** Creates a new 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 DigitalInput limit1 = new DigitalInput(2);
|
|
||||||
public void grimpe(double vitesse){
|
|
||||||
grimpeur.set(vitesse);
|
|
||||||
}
|
|
||||||
public boolean stop(){
|
|
||||||
return limit1.get();
|
|
||||||
}
|
|
||||||
public double encodeur(){
|
|
||||||
return grimpeur.getEncoder().getPosition();
|
|
||||||
}
|
|
||||||
public void reset(){
|
|
||||||
grimpeur.getEncoder().setPosition(0);
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public void periodic() {
|
|
||||||
// This method will be called once per scheduler run
|
|
||||||
}
|
|
||||||
}
|
|
61
src/main/java/frc/robot/subsystems/Pince.java
Normal file
61
src/main/java/frc/robot/subsystems/Pince.java
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
// 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.SparkLowLevel.MotorType;
|
||||||
|
import com.revrobotics.spark.SparkMax;
|
||||||
|
|
||||||
|
import edu.wpi.first.networktables.GenericEntry;
|
||||||
|
import edu.wpi.first.wpilibj.DigitalInput;
|
||||||
|
import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard;
|
||||||
|
import edu.wpi.first.wpilibj2.command.SubsystemBase;
|
||||||
|
|
||||||
|
public class Pince extends SubsystemBase {
|
||||||
|
/** Creates a new Pince. */
|
||||||
|
public Pince() {}
|
||||||
|
final SparkMax coral = new SparkMax(20, MotorType.kBrushless);
|
||||||
|
final SparkMax pivoti = new SparkMax(14, MotorType.kBrushless);
|
||||||
|
final SparkMax algue1 = new SparkMax(16, MotorType.kBrushless);
|
||||||
|
final SparkMax algue2 = new SparkMax(19, MotorType.kBrushless);
|
||||||
|
final DigitalInput limit6 = new DigitalInput(0);
|
||||||
|
GenericEntry teb = Shuffleboard.getTab("teb")
|
||||||
|
.add("pince encodeur",encodeurpivot())
|
||||||
|
.getEntry();
|
||||||
|
public void aspirecoral(double vitesse){
|
||||||
|
coral.set(vitesse);
|
||||||
|
}
|
||||||
|
public void pivote(double vitesse){
|
||||||
|
pivoti.set(vitesse);
|
||||||
|
}
|
||||||
|
public void aspirealgue(double vitesse){
|
||||||
|
algue2.set(vitesse);
|
||||||
|
algue1.set(-vitesse);
|
||||||
|
}
|
||||||
|
public double encodeurpivot(){
|
||||||
|
return pivoti.getEncoder().getPosition();
|
||||||
|
}
|
||||||
|
public boolean position(){
|
||||||
|
return limit6.get();
|
||||||
|
}
|
||||||
|
public void reset(){
|
||||||
|
pivoti.getEncoder().setPosition(0);
|
||||||
|
}
|
||||||
|
public double emperagecoral(){
|
||||||
|
return coral.getOutputCurrent();
|
||||||
|
}
|
||||||
|
public double emperagealgue(){
|
||||||
|
return algue1.getOutputCurrent();
|
||||||
|
}
|
||||||
|
public void algue1Test(double vitesse){
|
||||||
|
algue1.set(vitesse);
|
||||||
|
}
|
||||||
|
public void algue2Test(double vitesse){
|
||||||
|
algue2.set(vitesse);
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public void periodic() {
|
||||||
|
// This method will be called once per scheduler run
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user