Loading [MathJax]/extensions/tex2jax.js
CTRE Phoenix 6 C++ 25.4.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
ctre::phoenix6::controls::LarsonAnimation Class Reference

Animation that bounces a pocket of light across the LED strip. More...

#include <ctre/phoenix6/controls/LarsonAnimation.hpp>

Inheritance diagram for ctre::phoenix6::controls::LarsonAnimation:
ctre::phoenix6::controls::ControlRequest

Public Member Functions

 LarsonAnimation (int LEDStartIndex, int LEDEndIndex)
 Animation that bounces a pocket of light across the LED strip.
 
LarsonAnimationWithLEDStartIndex (int newLEDStartIndex)
 Modifies this Control Request's LEDStartIndex parameter and returns itself for method-chaining and easier to use request API.
 
LarsonAnimationWithLEDEndIndex (int newLEDEndIndex)
 Modifies this Control Request's LEDEndIndex parameter and returns itself for method-chaining and easier to use request API.
 
LarsonAnimationWithSlot (int newSlot)
 Modifies this Control Request's Slot parameter and returns itself for method-chaining and easier to use request API.
 
LarsonAnimationWithColor (signals::RGBWColor newColor)
 Modifies this Control Request's Color parameter and returns itself for method-chaining and easier to use request API.
 
LarsonAnimationWithSize (int newSize)
 Modifies this Control Request's Size parameter and returns itself for method-chaining and easier to use request API.
 
LarsonAnimationWithBounceMode (signals::LarsonBounceValue newBounceMode)
 Modifies this Control Request's BounceMode parameter and returns itself for method-chaining and easier to use request API.
 
LarsonAnimationWithFrameRate (units::frequency::hertz_t newFrameRate)
 Modifies this Control Request's FrameRate parameter and returns itself for method-chaining and easier to use request API.
 
LarsonAnimationWithUpdateFreqHz (units::frequency::hertz_t newUpdateFreqHz)
 Sets the period at which this control will update at.
 
std::string ToString () const override
 Returns a string representation of the object.
 
std::map< std::string, std::string > GetControlInfo () const override
 Gets information about this control request.
 
- Public Member Functions inherited from ctre::phoenix6::controls::ControlRequest
 ControlRequest (std::string name)
 Constructs a new Control Request with the given name.
 
std::string const & GetName () const
 
virtual ~ControlRequest ()=default
 

Public Attributes

int LEDStartIndex
 The index of the first LED this animation controls (inclusive).
 
int LEDEndIndex
 The index of the last LED this animation controls (inclusive).
 
int Slot = 0
 The slot of this animation, within [0, 7].
 
signals::RGBWColor Color = signals::RGBWColor{}
 The color to use in the animation.
 
int Size = 3
 The number of LEDs in the pocket of light, up to 15.
 
signals::LarsonBounceValue BounceMode = signals::LarsonBounceValue::Front
 The behavior of the pocket of light when it reaches the end of the strip.
 
units::frequency::hertz_t FrameRate = 25_Hz
 The frame rate of the animation, from [2, 1000] Hz.
 
units::frequency::hertz_t UpdateFreqHz {20_Hz}
 The period at which this control will update at.
 

Additional Inherited Members

- Protected Member Functions inherited from ctre::phoenix6::controls::ControlRequest
 ControlRequest (ControlRequest const &)=default
 
 ControlRequest (ControlRequest &&)=default
 
ControlRequestoperator= (ControlRequest const &)=default
 
ControlRequestoperator= (ControlRequest &&)=default
 
- Protected Attributes inherited from ctre::phoenix6::controls::ControlRequest
std::string name
 

Detailed Description

Animation that bounces a pocket of light across the LED strip.

Constructor & Destructor Documentation

◆ LarsonAnimation()

ctre::phoenix6::controls::LarsonAnimation::LarsonAnimation ( int LEDStartIndex,
int LEDEndIndex )
inline

Animation that bounces a pocket of light across the LED strip.

Parameters
LEDStartIndexThe index of the first LED this animation controls (inclusive). Indices 0-7 control the onboard LEDs, and 8-399 control an attached LED strip.
LEDEndIndexThe index of the last LED this animation controls (inclusive). Indices 0-7 control the onboard LEDs, and 8-399 control an attached LED strip.

Member Function Documentation

◆ GetControlInfo()

std::map< std::string, std::string > ctre::phoenix6::controls::LarsonAnimation::GetControlInfo ( ) const
inlineoverridevirtual

Gets information about this control request.

Returns
Map of control parameter names and corresponding applied values

Implements ctre::phoenix6::controls::ControlRequest.

◆ ToString()

std::string ctre::phoenix6::controls::LarsonAnimation::ToString ( ) const
inlineoverridevirtual

Returns a string representation of the object.

Returns
a string representation of the object.

Implements ctre::phoenix6::controls::ControlRequest.

◆ WithBounceMode()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithBounceMode ( signals::LarsonBounceValue newBounceMode)
inline

Modifies this Control Request's BounceMode parameter and returns itself for method-chaining and easier to use request API.

The behavior of the pocket of light when it reaches the end of the strip.

Parameters
newBounceModeParameter to modify
Returns
Itself

◆ WithColor()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithColor ( signals::RGBWColor newColor)
inline

Modifies this Control Request's Color parameter and returns itself for method-chaining and easier to use request API.

The color to use in the animation.

Parameters
newColorParameter to modify
Returns
Itself

◆ WithFrameRate()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithFrameRate ( units::frequency::hertz_t newFrameRate)
inline

Modifies this Control Request's FrameRate parameter and returns itself for method-chaining and easier to use request API.

The frame rate of the animation, from [2, 1000] Hz. This determines the speed of the animation.

A frame is defined as a transition in the state of the LEDs, advancing the pocket of light by one LED.

  • Units: Hz
Parameters
newFrameRateParameter to modify
Returns
Itself

◆ WithLEDEndIndex()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithLEDEndIndex ( int newLEDEndIndex)
inline

Modifies this Control Request's LEDEndIndex parameter and returns itself for method-chaining and easier to use request API.

The index of the last LED this animation controls (inclusive). Indices 0-7 control the onboard LEDs, and 8-399 control an attached LED strip.

Parameters
newLEDEndIndexParameter to modify
Returns
Itself

◆ WithLEDStartIndex()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithLEDStartIndex ( int newLEDStartIndex)
inline

Modifies this Control Request's LEDStartIndex parameter and returns itself for method-chaining and easier to use request API.

The index of the first LED this animation controls (inclusive). Indices 0-7 control the onboard LEDs, and 8-399 control an attached LED strip.

Parameters
newLEDStartIndexParameter to modify
Returns
Itself

◆ WithSize()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithSize ( int newSize)
inline

Modifies this Control Request's Size parameter and returns itself for method-chaining and easier to use request API.

The number of LEDs in the pocket of light, up to 15.

Parameters
newSizeParameter to modify
Returns
Itself

◆ WithSlot()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithSlot ( int newSlot)
inline

Modifies this Control Request's Slot parameter and returns itself for method-chaining and easier to use request API.

The slot of this animation, within [0, 7]. Each slot on the CANdle can store and run one animation.

Parameters
newSlotParameter to modify
Returns
Itself

◆ WithUpdateFreqHz()

LarsonAnimation & ctre::phoenix6::controls::LarsonAnimation::WithUpdateFreqHz ( units::frequency::hertz_t newUpdateFreqHz)
inline

Sets the period at which this control will update at.

This is designated in Hertz, with a minimum of 20 Hz (every 50 ms) and a maximum of 1000 Hz (every 1 ms).

If this field is set to 0 Hz, the control request will be sent immediately as a one-shot frame. This may be useful for advanced applications that require outputs to be synchronized with data acquisition. In this case, we recommend not exceeding 50 ms between control calls.

Parameters
newUpdateFreqHzParameter to modify
Returns
Itself

Member Data Documentation

◆ BounceMode

signals::LarsonBounceValue ctre::phoenix6::controls::LarsonAnimation::BounceMode = signals::LarsonBounceValue::Front

The behavior of the pocket of light when it reaches the end of the strip.

◆ Color

signals::RGBWColor ctre::phoenix6::controls::LarsonAnimation::Color = signals::RGBWColor{}

The color to use in the animation.

◆ FrameRate

units::frequency::hertz_t ctre::phoenix6::controls::LarsonAnimation::FrameRate = 25_Hz

The frame rate of the animation, from [2, 1000] Hz.

This determines the speed of the animation.

A frame is defined as a transition in the state of the LEDs, advancing the pocket of light by one LED.

  • Units: Hz

◆ LEDEndIndex

int ctre::phoenix6::controls::LarsonAnimation::LEDEndIndex

The index of the last LED this animation controls (inclusive).

Indices 0-7 control the onboard LEDs, and 8-399 control an attached LED strip.

◆ LEDStartIndex

int ctre::phoenix6::controls::LarsonAnimation::LEDStartIndex

The index of the first LED this animation controls (inclusive).

Indices 0-7 control the onboard LEDs, and 8-399 control an attached LED strip.

◆ Size

int ctre::phoenix6::controls::LarsonAnimation::Size = 3

The number of LEDs in the pocket of light, up to 15.

◆ Slot

int ctre::phoenix6::controls::LarsonAnimation::Slot = 0

The slot of this animation, within [0, 7].

Each slot on the CANdle can store and run one animation.

◆ UpdateFreqHz

units::frequency::hertz_t ctre::phoenix6::controls::LarsonAnimation::UpdateFreqHz {20_Hz}

The period at which this control will update at.

This is designated in Hertz, with a minimum of 20 Hz (every 50 ms) and a maximum of 1000 Hz (every 1 ms).

If this field is set to 0 Hz, the control request will be sent immediately as a one-shot frame. This may be useful for advanced applications that require outputs to be synchronized with data acquisition. In this case, we recommend not exceeding 50 ms between control calls.


The documentation for this class was generated from the following file: