WPILibC++ 2025.2.1
|
Visual 2D representation of arms, elevators, and general mechanisms through a node-based API. More...
#include <frc/smartdashboard/Mechanism2d.h>
Public Member Functions | |
Mechanism2d (double width, double height, const Color8Bit &backgroundColor={0, 0, 32}) | |
Create a new Mechanism2d with the given dimensions and background color. | |
MechanismRoot2d * | GetRoot (std::string_view name, double x, double y) |
Get or create a root in this Mechanism2d with the given name and position. | |
void | SetBackgroundColor (const Color8Bit &color) |
Set the Mechanism2d background color. | |
void | InitSendable (nt::NTSendableBuilder &builder) override |
Initializes this Sendable object. | |
Public Member Functions inherited from nt::NTSendable | |
void | InitSendable (wpi::SendableBuilder &builder) override |
Initializes this Sendable object. | |
Public Member Functions inherited from wpi::Sendable | |
virtual constexpr | ~Sendable ()=default |
Public Member Functions inherited from wpi::SendableHelper< Mechanism2d > | |
constexpr | SendableHelper (const SendableHelper &rhs)=default |
constexpr | SendableHelper (SendableHelper &&rhs) |
constexpr SendableHelper & | operator= (const SendableHelper &rhs)=default |
constexpr SendableHelper & | operator= (SendableHelper &&rhs) |
Additional Inherited Members | |
Protected Member Functions inherited from wpi::SendableHelper< Mechanism2d > | |
constexpr | SendableHelper ()=default |
constexpr | ~SendableHelper () |
Visual 2D representation of arms, elevators, and general mechanisms through a node-based API.
A Mechanism2d object is published and contains at least one root node. A root is the anchor point of other nodes (such as ligaments). Other nodes are recursively appended based on other nodes.
Except for the Mechanism2d container object, none of the objects should be passed or interacted with by value! Obtain pointers from factory methods such as Mechanism2d.GetRoot() and MechanismObject2d.Append<>(). The Mechanism2d container object owns the root nodes, and each node internally owns the nodes based on it. Beware not to let the Mechanism2d object out of scope - all nodes will be recursively destructed!
frc::Mechanism2d::Mechanism2d | ( | double | width, |
double | height, | ||
const Color8Bit & | backgroundColor = {0, 0, 32} ) |
Create a new Mechanism2d with the given dimensions and background color.
The dimensions represent the canvas that all the nodes are drawn on. The default color is dark blue.
width | the width |
height | the height |
backgroundColor | the background color |
MechanismRoot2d * frc::Mechanism2d::GetRoot | ( | std::string_view | name, |
double | x, | ||
double | y ) |
Get or create a root in this Mechanism2d with the given name and position.
If a root with the given name already exists, the given x and y coordinates are not used.
name | the root name |
x | the root x coordinate |
y | the root y coordinate |
|
overridevirtual |
void frc::Mechanism2d::SetBackgroundColor | ( | const Color8Bit & | color | ) |
Set the Mechanism2d background color.
color | the new background color |