2
0
mirror of https://github.com/team2059/Dent synced 2024-12-28 21:02:30 -05:00
dent/Subsystems/Drivetrain.cpp
2015-09-17 19:59:58 +00:00

52 lines
1.5 KiB
C++

#include "Drivetrain.h"
#include "../RobotMap.h"
#include "../Commands/Drivetrain/Drive.h"
Drivetrain::Drivetrain(): Subsystem("Drivetrain") {
rightRear = new CANTalon(DRIVE_BACK_RIGHT_CAN);
leftRear = new CANTalon(DRIVE_BACK_LEFT_CAN);
gyro = new Gyro(DRIVE_GYRO_ANALOG);
}
void Drivetrain::InitDefaultCommand() {
SetDefaultCommand(new Drive());
}
void Drivetrain::DriveArcade(double x, double y, double z, double sensitivity, bool driveStraight) {
double kP = SmartDashboard::GetNumber("Gyro kP");
double correctX = -(sensitivity*(pow(x, 3))+(1-sensitivity)*x);
double correctY = -(sensitivity*(pow(y, 3))+(1-sensitivity)*y);
double correctZ = z;
if(driveStraight) {
printf("Driving straight at: %f\n", -gyro->GetAngle()*kP);
correctZ = -gyro->GetAngle()*kP;
} else {
correctZ = -z * 0.5;
}
if(DentRobot::oi->GetLeftStick()->GetRawButton(9)) {
correctY /= 2.0;
}
int leftPower=((correctY+(correctX+correctZ))/2+1)*127+1;
int rightPower=((correctY-(correctX+correctZ))/2+1)*127+1;
printf("rightPower:%d\n",rightPower);
printf("leftPower:%d\n",leftPower);
leftRear->Set(leftPower);
rightRear->Set(rightPower);
}
//Used in pretest
void Drivetrain::TestMotor(e_motors motor, double power) {
switch(motor) {
case BACKRIGHT:
rightRear->Set(power);
break;
case BACKLEFT:
leftRear->Set(power);
break;
default:
break;
}
}
void Drivetrain::ResetGyro() {
gyro->Reset();
}
// vim: ts=2:sw=2:et