54 lines
1.8 KiB
C
54 lines
1.8 KiB
C
|
/*----------------------------------------------------------------------------*/
|
||
|
/* Copyright (c) FIRST 2011-2016. 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. */
|
||
|
/*----------------------------------------------------------------------------*/
|
||
|
|
||
|
#ifndef __TRIGGER_H__
|
||
|
#define __TRIGGER_H__
|
||
|
|
||
|
#include "SmartDashboard/Sendable.h"
|
||
|
#include <memory>
|
||
|
|
||
|
class Command;
|
||
|
|
||
|
/**
|
||
|
* This class provides an easy way to link commands to inputs.
|
||
|
*
|
||
|
* It is very easy to link a polled input to a command. For instance, you could
|
||
|
* link the trigger button of a joystick to a "score" command or an encoder
|
||
|
* reaching
|
||
|
* a particular value.
|
||
|
*
|
||
|
* It is encouraged that teams write a subclass of Trigger if they want to have
|
||
|
* something unusual (for instance, if they want to react to the user holding
|
||
|
* a button while the robot is reading a certain sensor input). For this, they
|
||
|
* only have to write the {@link Trigger#Get()} method to get the full
|
||
|
* functionality
|
||
|
* of the Trigger class.
|
||
|
*
|
||
|
* @author Brad Miller, Joe Grinstead
|
||
|
*/
|
||
|
class Trigger : public Sendable {
|
||
|
public:
|
||
|
Trigger() = default;
|
||
|
virtual ~Trigger() = default;
|
||
|
bool Grab();
|
||
|
virtual bool Get() = 0;
|
||
|
void WhenActive(Command *command);
|
||
|
void WhileActive(Command *command);
|
||
|
void WhenInactive(Command *command);
|
||
|
void CancelWhenActive(Command *command);
|
||
|
void ToggleWhenActive(Command *command);
|
||
|
|
||
|
virtual void InitTable(std::shared_ptr<ITable> table);
|
||
|
virtual std::shared_ptr<ITable> GetTable() const;
|
||
|
virtual std::string GetSmartDashboardType() const;
|
||
|
|
||
|
protected:
|
||
|
std::shared_ptr<ITable> m_table;
|
||
|
};
|
||
|
|
||
|
#endif
|