2
0
mirror of https://github.com/team2059/Dent synced 2025-01-07 22:14:14 -05:00

Merge branch 'develop'

This commit is contained in:
Austen Adler 2015-02-16 07:10:36 -05:00
commit 76c7f7ce1a
29 changed files with 244 additions and 194 deletions

View File

@ -1,20 +1,32 @@
#include "AutoDrive.h" #include "AutoDrive.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
// Drive for a short while then stop. Just for testing // Drive for a short while then stop. Just for testing
AutoDrive::AutoDrive() : Command("AutoDrive"){ AutoDrive::AutoDrive(double wait) : Command("AutoDrive"){
Requires(DentRobot::drivetrain); Requires(DentRobot::drivetrain);
SetTimeout(0.5); SetTimeout(wait);
power=5;
}
AutoDrive::AutoDrive(double wait, double p) : Command("AutoDrive"){
Requires(DentRobot::drivetrain);
SetTimeout(wait);
power=p;
} }
void AutoDrive::Initialize(){ void AutoDrive::Initialize(){
} }
void AutoDrive::Execute(){ void AutoDrive::Execute(){
//X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle), gyro //X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle), gyro
//if(power==NULL){
if(power==5){
DentRobot::drivetrain->DriveMecanum(0.0,-.75,0.0,0.9,0.0); DentRobot::drivetrain->DriveMecanum(0.0,-.75,0.0,0.9,0.0);
}else{
DentRobot::drivetrain->DriveMecanum(0.0,power,0.0,0.9,0.0);
}
} }
bool AutoDrive::IsFinished(){ bool AutoDrive::IsFinished(){
return IsTimedOut(); return IsTimedOut();
} }
void AutoDrive::End(){ void AutoDrive::End(){
DentRobot::drivetrain->DriveMecanum(0.0,0.0,0.0,0.9,0.0);
} }
void AutoDrive::Interrupted(){ void AutoDrive::Interrupted(){
End(); End();

View File

@ -7,8 +7,11 @@
#include "WPILib.h" #include "WPILib.h"
class AutoDrive: public Command{ class AutoDrive: public Command{
private:
double power;
public: public:
AutoDrive(); AutoDrive(double);
AutoDrive(double, double);
void Initialize(); void Initialize();
void Execute(); void Execute();
bool IsFinished(); bool IsFinished();

View File

@ -4,19 +4,46 @@
#include "../Elevator/Lower.h" #include "../Elevator/Lower.h"
#include "AutoDrive.h" #include "AutoDrive.h"
#include "Turn.h" #include "Turn.h"
#include "../Collector/CloseCollector.h" #include "../Collector/RollIn.h"
#include "../Collector/OpenCollector.h"
#include "../Collector/CollectTote.h" #include "../Collector/CollectTote.h"
Autonomous::Autonomous(){ Autonomous::Autonomous(int seq){
//SmartDashboard::GetNumber("Auto Wait Time");
switch(seq){
case 0:
// Just for testing
AddSequential(new CollectTote());
AddSequential(new Turn());
//AddSequential(new Raise()); //AddSequential(new Raise());
//AddSequential(new Lower()); //AddSequential(new Lower());
//AddSequential(new AutoDrive()); //AddSequential(new Turn());
//AddParallel(new AutoDrive(0.5));
//AddSequential(new RollIn());
//AddSequential(new Turn());
break;
case 1:
// Drive forward a bit, turn around, collect tote then bin
AddSequential(new AutoDrive(0.5));
AddSequential(new Turn());
AddSequential(new Turn());
AddSequential(new RollIn());
AddSequential(new Raise()); AddSequential(new Raise());
AddSequential(new Lower()); break;
case 2:
// Drive forward a bit, turn around, collect tote then bin
AddParallel(new Raise());
AddParallel(new AutoDrive(0.5));
AddSequential(new Turn()); AddSequential(new Turn());
AddParallel(new AutoDrive());
AddParallel(new CloseCollector());
AddParallel(new CollectTote());
AddSequential(new Turn()); AddSequential(new Turn());
AddSequential(new RollIn());
break;
case 3:
// Wait a desigated value, drive to Auto Zone (TM)
//Wait(SmartDashboard::GetNumber("Auto Wait Time"));
AddSequential(new AutoDrive(2.0));
break;
default:
printf("Invalid seq: %d\n", seq);
break;
}
} }
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -8,7 +8,7 @@
class Autonomous: public CommandGroup{ class Autonomous: public CommandGroup{
public: public:
Autonomous(); Autonomous(int);
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -3,18 +3,20 @@
// Drive for a short while then stop. Just for testing // Drive for a short while then stop. Just for testing
Turn::Turn() : Command("Turn"){ Turn::Turn() : Command("Turn"){
Requires(DentRobot::drivetrain); Requires(DentRobot::drivetrain);
SetTimeout(0.25); SetTimeout(0.85);
} }
void Turn::Initialize(){ void Turn::Initialize(){
} }
void Turn::Execute(){ void Turn::Execute(){
//X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle), gyro //X axis, Y axis, Z axis, sensitivity, speed threshold (usually throttle), gyro
DentRobot::drivetrain->DriveMecanum(0.0,0.0,0.5,0.9,0.0); DentRobot::drivetrain->DriveMecanum(0.0,0.0,1.0,0.9,0.0);
} }
bool Turn::IsFinished(){ bool Turn::IsFinished(){
return IsTimedOut(); return IsTimedOut();
} }
void Turn::End(){ void Turn::End(){
// Stop driving
DentRobot::drivetrain->DriveMecanum(0.0,0.0,0.0,0.9,0.0);
} }
void Turn::Interrupted(){ void Turn::Interrupted(){
End(); End();

View File

@ -10,7 +10,7 @@ void BinLower::Execute(){
DentRobot::binElevator->Run(-1.0); DentRobot::binElevator->Run(-1.0);
} }
bool BinLower::IsFinished(){ bool BinLower::IsFinished(){
if (!DentRobot::binElevator->GetElevatorBottom()||IsTimedOut()){ if (/*!DentRobot::binElevator->GetElevatorBottom()||*/IsTimedOut()){
printf("Robot stoped BinLowering. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorBottom()); printf("Robot stoped BinLowering. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorBottom());
return true; return true;
}else{ }else{

View File

@ -10,7 +10,7 @@ void BinRaise::Execute(){
DentRobot::binElevator->Run(1.0); DentRobot::binElevator->Run(1.0);
} }
bool BinRaise::IsFinished(){ bool BinRaise::IsFinished(){
if (!DentRobot::binElevator->GetElevatorTop()||IsTimedOut()){ if (/*!DentRobot::binElevator->GetElevatorTop()||*/IsTimedOut()){
printf("Robot stoped raising. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorTop()); printf("Robot stoped raising. Sensor based? %d\n", !DentRobot::binElevator->GetElevatorTop());
return true; return true;
}else{ }else{

View File

@ -1,28 +0,0 @@
#include "CloseCollector.h"
CloseCollector::CloseCollector() : Command("CloseCollector"){
Requires(DentRobot::collector);
}
void CloseCollector::Initialize(){
printf("Initialized collector: 0.5\n");
SetTimeout(2.5);
}
void CloseCollector::Execute(){
//printf("Closing collector: -0.5f\n");
DentRobot::collector->MoveArms(-0.5);
//DentRobot::collector->MoveArms(-(-DentRobot::oi->GetRightStick()->GetRawAxis(3)+1)/2*.3/.5);
}
bool CloseCollector::IsFinished(){
if(DentRobot::collector->ArmSensor()||IsTimedOut()){
printf("Stopped Closing: %d, %d\n",DentRobot::collector->ArmSensor(), IsTimedOut());
return true;
}else{
return false;
}
}
void CloseCollector::End(){
DentRobot::collector->MoveArms(0.0f);
}
void CloseCollector::Interrupted(){
End();
}
// vim: ts=2:sw=2:et

View File

@ -1,22 +1,9 @@
#include "CollectTote.h" #include "CollectTote.h"
CollectTote::CollectTote() : Command("CollectTote"){ #include "../../DentRobot.h"
Requires(DentRobot::collector); #include "../Autonomous/AutoDrive.h"
} #include "RollIn.h"
void CollectTote::Initialize(){ CollectTote::CollectTote(){
printf("Initialized CollectTote\n"); AddParallel(new AutoDrive(1.0, -0.75));
SetTimeout(2.0); AddSequential(new RollIn());
}
void CollectTote::Execute(){
//TODO check this value to move the motors in the right direction
DentRobot::collector->MoveRollers(-(-DentRobot::oi->GetLeftStick()->GetRawAxis(3)+1.0)/2);
}
bool CollectTote::IsFinished(){
return DentRobot::collector->BoxCollected()||IsTimedOut();
}
void CollectTote::End(){
DentRobot::collector->MoveRollers(0.0);
}
void CollectTote::Interrupted(){
End();
} }
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,20 +1,14 @@
#ifndef COLLECTTOTE_H #ifndef COLLECTTOTE_H
#define COLLECTTOTE_H #define COLLECTTOTE_H
#include "Commands/Command.h" #include "Commands/CommandGroup.h"
#include "../../CommandBase.h" #include "../../CommandBase.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
class CollectTote: public Command{ class CollectTote: public CommandGroup{
public: public:
CollectTote(); CollectTote();
void Initialize();
void Execute();
bool IsFinished();
void End();
void Interrupted();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,22 +0,0 @@
#include "OpenCollector.h"
OpenCollector::OpenCollector() : Command("OpenCollector"){
Requires(DentRobot::collector);
}
void OpenCollector::Initialize(){
SetTimeout(0.5);
}
void OpenCollector::Execute(){
DentRobot::collector->MoveArms(0.35);
//DentRobot::collector->MoveArms((-DentRobot::oi->GetRightStick()->GetRawAxis(3)+1)/2*.3/.5);
}
bool OpenCollector::IsFinished(){
//return DentRobot::collector->ArmSensor();
return IsTimedOut();
}
void OpenCollector::End(){
DentRobot::collector->MoveArms(0.0f);
}
void OpenCollector::Interrupted(){
End();
}
// vim: ts=2:sw=2:et

View File

@ -1,22 +1,9 @@
#include "ReleaseTote.h" #include "ReleaseTote.h"
ReleaseTote::ReleaseTote() : Command("ReleaseTote"){ #include "../../DentRobot.h"
Requires(DentRobot::collector); #include "RollOut.h"
} #include "../Autonomous/AutoDrive.h"
void ReleaseTote::Initialize(){ ReleaseTote::ReleaseTote(){
SetTimeout(2.0); AddParallel(new RollOut());
} AddParallel(new AutoDrive(0.5, 0.75));
void ReleaseTote::Execute(){
//TODO check this value to move the motors in the right direction
// Devide by 2 twice because this speed should be half the collector speed
DentRobot::collector->MoveRollers((-DentRobot::oi->GetLeftStick()->GetRawAxis(3)+1.0)/2/2);
}
bool ReleaseTote::IsFinished(){
return DentRobot::collector->BoxCollected();
}
void ReleaseTote::End(){
DentRobot::collector->MoveRollers(0.0f);
}
void ReleaseTote::Interrupted(){
End();
} }
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,20 +1,14 @@
#ifndef RELEASETOTE_H #ifndef RELEASETOTE_H
#define RELEASETOTE_H #define RELEASETOTE_H
#include "Commands/Command.h" #include "Commands/CommandGroup.h"
#include "../../CommandBase.h" #include "../../CommandBase.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
class ReleaseTote: public Command{ class ReleaseTote: public CommandGroup{
public: public:
ReleaseTote(); ReleaseTote();
void Initialize();
void Execute();
bool IsFinished();
void End();
void Interrupted();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -0,0 +1,26 @@
#include "RollIn.h"
RollIn::RollIn() : Command("RollIn"){
}
void RollIn::Initialize(){
printf("Initialized RollIn\n");
SetTimeout(2.0);
}
void RollIn::Execute(){
double throttle=DentRobot::oi->GetLeftThrottle();
double cvt=throttle*DentRobot::collector->GetSonarDistance()/0.4;
if(cvt>=1.0){
DentRobot::collector->MoveRollers(1.0);
}else{
DentRobot::collector->MoveRollers(cvt);
}
}
bool RollIn::IsFinished(){
return IsTimedOut();
}
void RollIn::End(){
DentRobot::collector->MoveRollers(0.0);
}
void RollIn::Interrupted(){
End();
}
// vim: ts=2:sw=2:et

View File

@ -1,14 +1,14 @@
#ifndef OPENCOLLECTOR_H #ifndef ROLLIN_H
#define OPENCOLLECTOR_H #define ROLLIN_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../CommandBase.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
class OpenCollector: public Command{ class RollIn: public Command{
public: public:
OpenCollector(); RollIn();
void Initialize(); void Initialize();
void Execute(); void Execute();
bool IsFinished(); bool IsFinished();

View File

@ -0,0 +1,22 @@
#include "RollOut.h"
RollOut::RollOut() : Command("RollOut"){
Requires(DentRobot::collector);
}
void RollOut::Initialize(){
SetTimeout(2.0);
}
void RollOut::Execute(){
//TODO check this value to move the motors in the right direction
// Devide by 2 twice because this speed should be half the collector speed
DentRobot::collector->MoveRollers(-DentRobot::oi->GetLeftThrottle());
}
bool RollOut::IsFinished(){
return IsTimedOut();
}
void RollOut::End(){
DentRobot::collector->MoveRollers(0.0f);
}
void RollOut::Interrupted(){
End();
}
// vim: ts=2:sw=2:et

View File

@ -1,14 +1,14 @@
#ifndef CLOSECOLLECTOR_H #ifndef ROLLOUT_H
#define CLOSECOLLECTOR_H #define ROLLOUT_H
#include "Commands/Command.h" #include "Commands/Command.h"
#include "../../CommandBase.h" #include "../../CommandBase.h"
#include "../../DentRobot.h" #include "../../DentRobot.h"
#include "WPILib.h" #include "WPILib.h"
class CloseCollector: public Command{ class RollOut: public Command{
public: public:
CloseCollector(); RollOut();
void Initialize(); void Initialize();
void Execute(); void Execute();
bool IsFinished(); bool IsFinished();

View File

@ -21,7 +21,7 @@ void Drive::Execute(){
DentRobot::drivetrain->DriveMecanum(x,y,z,0.9,0); DentRobot::drivetrain->DriveMecanum(x,y,z,0.9,0);
} }
bool Drive::IsFinished(){ bool Drive::IsFinished(){
return false; return IsTimedOut();
} }
void Drive::End(){ void Drive::End(){
} }

View File

@ -10,14 +10,26 @@ void Raise::Execute(){
DentRobot::elevator->Run(1.0); DentRobot::elevator->Run(1.0);
} }
bool Raise::IsFinished(){ bool Raise::IsFinished(){
if (!DentRobot::elevator->GetElevatorTop()||IsTimedOut()){ //if(!DentRobot::elevator->GetElevatorMiddle()){
printf("Robot stoped raising. Sensor based? %d\n", !DentRobot::elevator->GetElevatorTop()); // DentRobot::elevator->stoppedAtSensor=true;
//}
//if ((DentRobot::elevator->stoppedAtSensor)){
// printf("Stopped at the middle sensor\n");
// DentRobot::elevator->stoppedAtSensor=false;
// return true;
//}else if (!DentRobot::elevator->GetElevatorTop()) {
if (!DentRobot::elevator->GetElevatorTop()||!DentRobot::elevator->GetElevatorMiddle()||IsTimedOut()){
printf("Robot stopped raising. Sensor based? %d\n", !DentRobot::elevator->GetElevatorTop()||!DentRobot::elevator->GetElevatorMiddle());
return true; return true;
}else{ }else{
return false; return false;
} }
} }
void Raise::End(){ void Raise::End(){
// If the elevator is at the top
if(DentRobot::elevator->GetElevatorTop()){
DentRobot::elevator->SetUseEncoder(true);
}
DentRobot::elevator->Run(0.0f); DentRobot::elevator->Run(0.0f);
} }
void Raise::Interrupted(){ void Raise::Interrupted(){

View File

@ -1,4 +1,5 @@
#include "DentRobot.h" #include "DentRobot.h"
#include "OI.h"
#include "Commands/Autonomous/Autonomous.h" #include "Commands/Autonomous/Autonomous.h"
OI* DentRobot::oi=NULL; OI* DentRobot::oi=NULL;
Collector* DentRobot::collector=NULL; Collector* DentRobot::collector=NULL;
@ -12,13 +13,15 @@ DentRobot::DentRobot(){
drivetrain=new Drivetrain(); drivetrain=new Drivetrain();
elevator=new Elevator(); elevator=new Elevator();
binElevator=new BinElevator(); binElevator=new BinElevator();
aut=new Autonomous(); aut=new Autonomous(0);
CameraServer::GetInstance()->SetQuality(25); CameraServer::GetInstance()->SetQuality(25);
CameraServer::GetInstance()->StartAutomaticCapture("cam0"); CameraServer::GetInstance()->StartAutomaticCapture("cam0");
printf("Initialized"); //SmartDashboard::PutNumber("Auto Wait Time", 1.0);
//SmartDashboard::PutNumber("Auto Sequence", 0);
printf("Initialized\n");
} }
void DentRobot::RobotInit(){ void DentRobot::RobotInit(){
SmartDashboard::PutNumber("CodeVersion",0.001); //SmartDashboard::PutNumber("CodeVersion",1.0);
} }
void DentRobot::DisabledPeriodic(){ void DentRobot::DisabledPeriodic(){
Scheduler::GetInstance()->Run(); Scheduler::GetInstance()->Run();
@ -32,12 +35,17 @@ void DentRobot::AutonomousPeriodic(){
Scheduler::GetInstance()->Run(); Scheduler::GetInstance()->Run();
} }
void DentRobot::TeleopInit(){ void DentRobot::TeleopInit(){
//if (aut != NULL){ if (aut != NULL){
// aut->Cancel(); aut->Cancel();
//} }
} }
void DentRobot::TeleopPeriodic(){ void DentRobot::TeleopPeriodic(){
Scheduler::GetInstance()->Run(); Scheduler::GetInstance()->Run();
// TODO: Calibrate 1.0 to the height we want the elevator to automatically raise
if(elevator->GetUseEncoder()&&elevator->GetHeight()<=-1.0){
// Raise the elevator if it dips below elevatorTop
oi->raise->Start();
}
} }
void DentRobot::TestPeriodic(){ void DentRobot::TestPeriodic(){
} }

View File

@ -9,6 +9,7 @@ EXEC=bin/FRCUserProgram
CLEANSER=rm -r CLEANSER=rm -r
all : $(OBJECTS) all : $(OBJECTS)
if [ ! -d bin ];then mkdir bin; fi
$(CC) -L$(WPILIB)/lib $(LDFLAGS) -o $(EXEC) $(OBJECTS) -lwpi $(CC) -L$(WPILIB)/lib $(LDFLAGS) -o $(EXEC) $(OBJECTS) -lwpi
%.o : %.cpp %.o : %.cpp
@ -17,10 +18,10 @@ all : $(OBJECTS)
clean: clean:
$(CLEANSER) $(OBJECTS) bin/FRCUserProgram $(CLEANSER) $(OBJECTS) bin/FRCUserProgram
deploy: deploy: all
@cat bin/FRCUserProgram | ssh admin@$(REMOTEIP) 'cat > /home/lvuser/FRCUserProgram2&&rm /home/lvuser/FRCUserProgram;mv /home/lvuser/FRCUserProgram2 /home/lvuser/FRCUserProgram&&. /etc/profile.d/natinst-path.sh;chmod a+x /home/lvuser/FRCUserProgram' @cat bin/FRCUserProgram | ssh admin@$(REMOTEIP) 'cat > /home/lvuser/FRCUserProgram2&&rm /home/lvuser/FRCUserProgram;mv /home/lvuser/FRCUserProgram2 /home/lvuser/FRCUserProgram&&. /etc/profile.d/natinst-path.sh;chmod a+x /home/lvuser/FRCUserProgram'
debug: debug: all
@cat bin/FRCUserProgram | ssh admin@$(REMOTEIP) 'cat > /home/lvuser/FRCUserProgram2&&rm /home/lvuser/FRCUserProgram;mv /home/lvuser/FRCUserProgram2 /home/lvuser/FRCUserProgram&&. /etc/profile.d/natinst-path.sh;chmod a+x /home/lvuser/FRCUserProgram;/home/lvuser/run.sh' @cat bin/FRCUserProgram | ssh admin@$(REMOTEIP) 'cat > /home/lvuser/FRCUserProgram2&&rm /home/lvuser/FRCUserProgram;mv /home/lvuser/FRCUserProgram2 /home/lvuser/FRCUserProgram&&. /etc/profile.d/natinst-path.sh;chmod a+x /home/lvuser/FRCUserProgram;/home/lvuser/run.sh'
putkey: putkey:

43
OI.cpp
View File

@ -1,43 +1,44 @@
#include "OI.h" #include "OI.h"
#include "Commands/Elevator/Lower.h" #include "Commands/Elevator/Lower.h"
#include "Commands/Elevator/Raise.h" #include "Commands/Elevator/Raise.h"
#include "Commands/Collector/OpenCollector.h" #include "Commands/Collector/RollIn.h"
#include "Commands/Collector/CloseCollector.h" #include "Commands/Collector/RollOut.h"
#include "Commands/Collector/CollectTote.h" #include "Commands/BinElevator/BinLower.h"
#include "Commands/Collector/ReleaseTote.h" #include "Commands/BinElevator/BinRaise.h"
OI::OI() { OI::OI() {
// Joysticks // Joysticks
leftStick=new Joystick(0); leftStick=new Joystick(0);
rightStick=new Joystick(1); rightStick=new Joystick(1);
// Collector // Collector
JoystickButton *right1=new JoystickButton(rightStick, 1);
JoystickButton *right2=new JoystickButton(rightStick, 2);
JoystickButton *left1=new JoystickButton(leftStick, 1); JoystickButton *left1=new JoystickButton(leftStick, 1);
JoystickButton *left2=new JoystickButton(leftStick, 2); JoystickButton *left2=new JoystickButton(leftStick, 2);
right1->WhileHeld(new CloseCollector()); left1->WhileHeld(new RollIn());
right2->WhileHeld(new OpenCollector()); left2->WhileHeld(new RollOut());
left1->WhileHeld(new CollectTote());
left2->WhileHeld(new ReleaseTote());
// Elevator // Elevator
Raise* raise=new Raise(); raise=new Raise();
Lower* lower=new Lower(); lower=new Lower();
JoystickButton *right3=new JoystickButton(rightStick, 3);
JoystickButton *right4=new JoystickButton(rightStick, 4); JoystickButton *right4=new JoystickButton(rightStick, 4);
JoystickButton *right5=new JoystickButton(rightStick, 5);
JoystickButton *right6=new JoystickButton(rightStick, 6); JoystickButton *right6=new JoystickButton(rightStick, 6);
right3->WhenPressed(lower);
right4->WhenPressed(lower); right4->WhenPressed(lower);
right3->CancelWhenPressed(raise);
right4->CancelWhenPressed(raise); right4->CancelWhenPressed(raise);
right5->WhenPressed(raise);
right6->WhenPressed(raise); right6->WhenPressed(raise);
right5->CancelWhenPressed(lower);
right6->CancelWhenPressed(lower); right6->CancelWhenPressed(lower);
// BinElevator
JoystickButton *right3=new JoystickButton(rightStick, 3);
JoystickButton *right5=new JoystickButton(rightStick, 5);
binRaise=new BinRaise();
binLower=new BinLower();
right3->WhenPressed(binLower);
right3->CancelWhenPressed(binRaise);
right5->WhenPressed(binRaise);
right5->CancelWhenPressed(binLower);
// Cancel // Cancel
JoystickButton *right12=new JoystickButton(rightStick, 12); JoystickButton *right12=new JoystickButton(rightStick, 12);
right12->CancelWhenPressed(raise); right12->CancelWhenPressed(raise);
right12->CancelWhenPressed(lower); right12->CancelWhenPressed(lower);
right12->CancelWhenPressed(binRaise);
right12->CancelWhenPressed(binLower);
} }
Joystick* OI::GetRightStick(){ Joystick* OI::GetRightStick(){
return rightStick; return rightStick;
@ -45,4 +46,10 @@ Joystick* OI::GetRightStick(){
Joystick* OI::GetLeftStick(){ Joystick* OI::GetLeftStick(){
return leftStick; return leftStick;
} }
double OI::GetRightThrottle(){
return (-rightStick->GetRawAxis(3)+1.0)/2;
}
double OI::GetLeftThrottle(){
return (-leftStick->GetRawAxis(3)+1.0)/2;
}
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

4
OI.h
View File

@ -2,6 +2,7 @@
#define OI_H #define OI_H
#include "WPILib.h" #include "WPILib.h"
#include "Commands/Command.h"
class OI class OI
{ {
@ -9,8 +10,11 @@ class OI
Joystick *leftStick, *rightStick; Joystick *leftStick, *rightStick;
public: public:
OI(); OI();
Command *raise, *lower, *binLower, *binRaise;
Joystick* GetRightStick(); Joystick* GetRightStick();
Joystick* GetLeftStick(); Joystick* GetLeftStick();
double GetLeftThrottle();
double GetRightThrottle();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -5,20 +5,19 @@
// Elevator // Elevator
#define ELEVATOR_CAN 1 #define ELEVATOR_CAN 1
#define ELEVATOR_BOTTOM_DIO 0 #define ELEVATOR_BOTTOM_DIO 9
#define ELEVATOR_COLELCT_TOTE_DIO 1 #define ELEVATOR_MIDDLE_DIO 8
#define ELEVATOR_READY_TOTE_DIO 2 #define ELEVATOR_TOP_DIO 7
#define ELEVATOR_TOP_DIO 5 #define ELEVATOR_ENCODERA 4
#define ELEVATOR_ENCODERA 0 #define ELEVATOR_ENCODERB 9
#define ELEVATOR_ENCODERB 1
// BinElevator // BinElevator
#define BINELEVATOR_CAN 11 #define BINELEVATOR_CAN 11
#define BINELEVATOR_BOTTOM_DIO 6 #define BINELEVATOR_BOTTOM_DIO 6
#define BINELEVATOR_COLELCT_BIN_DIO 7 #define BINELEVATOR_COLELCT_BIN_DIO 7
#define BINELEVATOR_TOP_DIO 8 #define BINELEVATOR_TOP_DIO 8
#define BINELEVATOR_ENCODERA 2 #define BINELEVATOR_ENCODERA 10
#define BINELEVATOR_ENCODERB 3 #define BINELEVATOR_ENCODERB 11
// Drivetrain // Drivetrain
#define DRIVE_FRONT_LEFT_CAN 2 #define DRIVE_FRONT_LEFT_CAN 2
@ -27,11 +26,11 @@
#define DRIVE_BACK_RIGHT_CAN 5 #define DRIVE_BACK_RIGHT_CAN 5
// Collector // Collector
#define COLLECTOR_WINDOW_LEFT_CAN 6 #define COLLECTOR_RAMP_CAN 7
#define COLLECTOR_WINDOW_RIGHT_CAN 7
#define COLLECTOR_LEFT_CAN 8 #define COLLECTOR_LEFT_CAN 8
#define COLLECTOR_BOTTOM_CAN 10 #define COLLECTOR_BOTTOM_CAN 10
#define COLLECTOR_RIGHT_CAN 9 #define COLLECTOR_RIGHT_CAN 9
#define COLLECTOR_SONAR_ANALOG 3
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -1,30 +1,23 @@
#include "Collector.h" #include "Collector.h"
#include "../RobotMap.h" #include "../RobotMap.h"
Collector::Collector() : Subsystem("Collector") { Collector::Collector() : Subsystem("Collector"){
windowMotorLeft=new CANTalon(COLLECTOR_WINDOW_LEFT_CAN);
windowMotorRight=new CANTalon(COLLECTOR_WINDOW_RIGHT_CAN);
collectorMotorLeft=new CANTalon(COLLECTOR_LEFT_CAN); collectorMotorLeft=new CANTalon(COLLECTOR_LEFT_CAN);
collectorMotorBottom=new CANTalon(COLLECTOR_BOTTOM_CAN); collectorMotorBottom=new CANTalon(COLLECTOR_BOTTOM_CAN);
collectorMotorRamp=new CANTalon(COLLECTOR_RAMP_CAN);
collectorMotorRight=new CANTalon(COLLECTOR_RIGHT_CAN); collectorMotorRight=new CANTalon(COLLECTOR_RIGHT_CAN);
sonarAnalog=new AnalogInput(COLLECTOR_SONAR_ANALOG);
} }
void Collector::InitDefaultCommand() { void Collector::InitDefaultCommand(){
}
void Collector::MoveArms(double a){
windowMotorLeft->Set(a);
windowMotorRight->Set(-a);
} }
void Collector::MoveRollers(double a){ void Collector::MoveRollers(double a){
collectorMotorLeft->Set(a); collectorMotorLeft->Set(a);
collectorMotorBottom->Set(a); collectorMotorBottom->Set(-a);
collectorMotorRamp->Set(a);
collectorMotorRight->Set(-a); collectorMotorRight->Set(-a);
printf("Roller power: %f\n",a);
} }
bool Collector::ArmSensor(){ double Collector::GetSonarDistance(){
// TODO: include limit switch code return sonarAnalog->GetAverageVoltage();
return false;
}
bool Collector::BoxCollected(){
return false;
//return boxSwitch->Get();
} }
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -5,14 +5,14 @@
class Collector: public Subsystem class Collector: public Subsystem
{ {
private: private:
CANTalon *windowMotorLeft, *windowMotorRight, *collectorMotorLeft, *collectorMotorBottom, *collectorMotorRight; CANTalon *collectorMotorLeft, *collectorMotorBottom, *collectorMotorRamp, *collectorMotorRight;
AnalogInput *sonarAnalog;
DigitalOutput *sonarDigital;
public: public:
Collector(); Collector();
void InitDefaultCommand(); void InitDefaultCommand();
void MoveArms(double);
void MoveRollers(double); void MoveRollers(double);
bool ArmSensor(); double GetSonarDistance();
bool BoxCollected();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -4,11 +4,19 @@ Elevator::Elevator(){
motor=new CANTalon(ELEVATOR_CAN); motor=new CANTalon(ELEVATOR_CAN);
elevatorEncoder=new Encoder(ELEVATOR_ENCODERA,ELEVATOR_ENCODERB,false); elevatorEncoder=new Encoder(ELEVATOR_ENCODERA,ELEVATOR_ENCODERB,false);
elevatorBottom=new DigitalInput(ELEVATOR_BOTTOM_DIO); elevatorBottom=new DigitalInput(ELEVATOR_BOTTOM_DIO);
elevatorMiddle=new DigitalInput(ELEVATOR_MIDDLE_DIO);
elevatorTop=new DigitalInput(ELEVATOR_TOP_DIO); elevatorTop=new DigitalInput(ELEVATOR_TOP_DIO);
// Checks if the elevator is drifting
useEncoder=false;
stoppedAtSensor=false;
} }
void Elevator::InitDefaultCommand(){ void Elevator::InitDefaultCommand(){
} }
void Elevator::Run(double power){ void Elevator::Run(double power){
// If we're not telling it to stop
if(power != 0.0){
SetUseEncoder(false);
}
motor->Set(power); motor->Set(power);
} }
void Elevator::ResetEncoder(){ void Elevator::ResetEncoder(){
@ -20,7 +28,16 @@ double Elevator::GetHeight(){
bool Elevator::GetElevatorBottom(){ bool Elevator::GetElevatorBottom(){
return elevatorBottom->Get(); return elevatorBottom->Get();
} }
bool Elevator::GetElevatorMiddle(){
return elevatorMiddle->Get();
}
bool Elevator::GetElevatorTop(){ bool Elevator::GetElevatorTop(){
return elevatorTop->Get(); return elevatorTop->Get();
} }
void Elevator::SetUseEncoder(bool param){
useEncoder=param;
}
bool Elevator::GetUseEncoder(){
return useEncoder;
}
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File

@ -8,15 +8,20 @@ class Elevator{
CANTalon *motor; CANTalon *motor;
Encoder *elevatorEncoder; Encoder *elevatorEncoder;
static constexpr double kP_real=4, kI_real=.0f, kP_simulation=18, kI_simulation=.2; static constexpr double kP_real=4, kI_real=.0f, kP_simulation=18, kI_simulation=.2;
DigitalInput *elevatorBottom, *elevatorTop; DigitalInput *elevatorBottom, *elevatorMiddle, *elevatorTop;
bool useEncoder;
public: public:
Elevator(); Elevator();
bool stoppedAtSensor;
void InitDefaultCommand(); void InitDefaultCommand();
void Run(double); void Run(double);
void ResetEncoder(); void ResetEncoder();
double GetHeight(); double GetHeight();
bool GetElevatorTop(); bool GetElevatorTop();
bool GetElevatorMiddle();
bool GetElevatorBottom(); bool GetElevatorBottom();
void SetUseEncoder(bool);
bool GetUseEncoder();
}; };
#endif #endif
// vim: ts=2:sw=2:et // vim: ts=2:sw=2:et

View File