Files
RiseOfRidgebotics2020/src/main/java/frc4388/robot/commands/DriveWithJoystick.java
T

111 lines
3.6 KiB
Java
Raw Normal View History

2020-01-17 16:59:48 -07:00
/*----------------------------------------------------------------------------*/
/* Copyright (c) 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 frc4388.robot.commands;
2020-02-27 17:14:32 -07:00
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
2020-01-17 16:59:48 -07:00
import edu.wpi.first.wpilibj2.command.CommandBase;
import frc4388.robot.subsystems.Drive;
import frc4388.robot.subsystems.Pneumatics;
2020-01-17 16:59:48 -07:00
import frc4388.utility.controller.IHandController;
public class DriveWithJoystick extends CommandBase {
private Drive m_drive;
private IHandController m_controller;
private Pneumatics m_pneumatics;
2020-01-17 16:59:48 -07:00
/**
2020-01-30 22:11:48 -07:00
* Creates a new DriveWithJoystick to control the drivetrain with an Xbox controller.
* Applies a curved ramp to the input from the controllers to make the robot less "touchy".
* @param subsystem pass the Drive subsystem from {@link frc4388.robot.RobotContainer#RobotContainer() RobotContainer}
* @param controller pass the Driver {@link frc4388.utility.controller.IHandController#getClass() IHandController} using the
* {@link frc4388.robot.RobotContainer#getDriverJoystick() getDriverJoystick()} method in
* {@link frc4388.robot.RobotContainer#RobotContainer() RobotContainer}
2020-01-17 16:59:48 -07:00
*/
public DriveWithJoystick(Drive subsystem, Pneumatics subsystem2, IHandController controller) {
2020-01-17 16:59:48 -07:00
// Use addRequirements() here to declare subsystem dependencies.
m_drive = subsystem;
m_pneumatics = subsystem2;
2020-01-17 16:59:48 -07:00
m_controller = controller;
addRequirements(m_drive);
}
// 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() {
double moveInput = -m_controller.getLeftYAxis();
double steerInput = m_controller.getRightXAxis();
2020-01-17 16:59:48 -07:00
double moveOutput = 0;
double steerOutput = 0;
if (moveInput >= 0){
moveOutput = -Math.cos(1.571*moveInput)+1;
2020-01-17 16:59:48 -07:00
} else {
moveOutput = Math.cos(1.571*moveInput)-1;
2020-01-17 16:59:48 -07:00
}
2020-02-27 17:14:32 -07:00
double cosMultiplier = 1.0;
2020-02-25 20:45:29 -07:00
double deadzone = .1;
if (m_pneumatics.m_isSpeedShiftHigh) {
cosMultiplier = 0.8;
} else {
cosMultiplier = 1.0;
}
if (steerInput > 0){
steerOutput = -(cosMultiplier - deadzone) * Math.cos(1.571*steerInput) + cosMultiplier;
} else if (steerInput < 0) {
steerOutput = (cosMultiplier - deadzone) * Math.cos(1.571*steerInput) - cosMultiplier;
2020-02-25 17:12:56 -07:00
} else {
steerOutput = 0;
2020-01-17 16:59:48 -07:00
}
/*
double outputLimit = 0.8;
boolean isMoveOutputLimited = false;
boolean isSteerOutputLimited = false;
if (m_pneumatics.m_isSpeedShiftHigh) {
if (isMoveOutputLimited) {
if (moveOutput > outputLimit) {
moveOutput = outputLimit;
} else if(moveOutput < -outputLimit) {
moveOutput = -outputLimit;
}
}
if (isSteerOutputLimited) {
if (steerOutput > outputLimit) {
steerOutput = outputLimit;
} else if(steerOutput < -outputLimit) {
steerOutput = -outputLimit;
}
}
}
*/
2020-01-17 16:59:48 -07:00
m_drive.driveWithInput(moveOutput, steerOutput);
}
// 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;
}
}