elevateur

This commit is contained in:
Antoine PerreaultE 2025-01-27 19:51:46 -05:00
parent 0577ce368a
commit e7b4b47928
6 changed files with 109 additions and 12 deletions

View 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.command;
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 Depart extends Command {
private Elevateur elevateur;
/** Creates a new L2. */
public Depart(Elevateur elevateur) {
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.reset();
}
else{
elevateur.vitesse(-.5);
}
}
// 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 elevateur.limit2()==true;
}
}

View 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.command;
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());
}
// 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;
}
}

View File

@ -24,11 +24,11 @@ public class L2 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(elevateur.position(500)>=500){ if(elevateur.position()>=500){
elevateur.vitesse(0); elevateur.vitesse(0);
} }
else{ else{
elevateur.vitesse(.5); elevateur.vitesse(.3);
} }
} }
@ -41,6 +41,6 @@ public class L2 extends Command {
// Returns true when the command should end. // Returns true when the command should end.
@Override @Override
public boolean isFinished() { public boolean isFinished() {
return elevateur.position(500)>=500; return elevateur.position()>=500;
} }
} }

View File

@ -24,7 +24,7 @@ public class L3 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(elevateur.position(700)>=700){ if(elevateur.position()>=700){
elevateur.vitesse(0); elevateur.vitesse(0);
} }
else{ else{
@ -41,6 +41,6 @@ public class L3 extends Command {
// Returns true when the command should end. // Returns true when the command should end.
@Override @Override
public boolean isFinished() { public boolean isFinished() {
return elevateur.position(700)>=700; return elevateur.position()>=700;
} }
} }

View File

@ -24,7 +24,7 @@ public class L4 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(elevateur.position(800)>=800){ if(elevateur.position()>=800){
elevateur.vitesse(0); elevateur.vitesse(0);
} }
else{ else{
@ -41,6 +41,6 @@ public class L4 extends Command {
// Returns true when the command should end. // Returns true when the command should end.
@Override @Override
public boolean isFinished() { public boolean isFinished() {
return elevateur.position(800)>=800; return elevateur.position()>=800;
} }
} }

View File

@ -13,16 +13,18 @@ public class Elevateur extends SubsystemBase {
public Elevateur() {} public Elevateur() {}
final SparkMax monte = new SparkMax(0, MotorType.kBrushless); final SparkMax monte = new SparkMax(0, MotorType.kBrushless);
final DigitalInput limit2 = new DigitalInput(0); final DigitalInput limit2 = new DigitalInput(0);
public double position(double position){ public double position(){
return monte.getEncoder().getPosition(); return monte.getEncoder().getPosition();
} }
public void vitesse(double vitesse){ public void vitesse(double vitesse){
monte.set(vitesse); monte.set(vitesse);
} }
public boolean limit2(){
return limit2.get();
}
public void reset(){
monte.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