-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathDrivetrainDriveCommand.java
79 lines (63 loc) · 2.6 KB
/
DrivetrainDriveCommand.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*----------------------------------------------------------------------------*/
/* Copyright (c) 2018-2019 FIRST. All Rights Reserved. */
/* Open Source Software - may be modified and shared by FRC teams. The code */
/* must be accompanied by the FIRST BSD license file in the root directory of */
/* the project. */
/*----------------------------------------------------------------------------*/
package frc.robot.commands;
import com.stuypulse.stuylib.input.Gamepad;
import com.stuypulse.stuylib.streams.filters.*;
import edu.wpi.first.wpilibj2.command.CommandBase;
import frc.robot.subsystems.Drivetrain;
/**
* ----- PLEASE READ -----
* This is an example implementation of the drivetrain drive command.
*
* This is pretty much what we use for competitions.
*
* This version includes the use of Filters.
*
* Filters are complicated, but can be used to make driving much smooter and more reliable.
*/
public class DrivetrainDriveCommand extends CommandBase {
private Drivetrain drivetrain;
private Gamepad driver;
// These filters help smooth out driving
// But they are also optional
private IFilter speedFilter = new LowPassFilter(0.4);
private IFilter turnFilter = new LowPassFilter(0.1);
public DrivetrainDriveCommand(Drivetrain subsystem, Gamepad gamepad) {
drivetrain = subsystem;
driver = gamepad;
// This makes sure that two commands that need the same subsystem dont mess eachother up.
// Example, if a command activated by a button needs to take control away from a default command.
addRequirements(subsystem);
}
// Called when the command is initially scheduled.
@Override
public void initialize() {
}
// Called 50 times a second if the robot is running
@Override
public void execute() {
// Get the speed from the triggers
double speed = driver.getRightTrigger() - driver.getLeftTrigger();
// Get the turn value from the left stick
double turn = driver.getLeftX();
// Filter the Speed and Turn value
// This is optional, but it leads to a smoother driving experience.
speed = speedFilter.get(speed);
turn = turnFilter.get(turn);
// Send values to drivetrain
drivetrain.arcadeDrive(speed, turn);
}
// 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;
}
}