Power System Platform  2026w10a-beta
Loading...
Searching...
No Matches
Element Class Referenceabstract

Base class of all elements of the program. This class is responsible for manage graphical and his data. More...

#include <Element.h>

Inheritance diagram for Element:

Public Member Functions

 Element ()
 Constructor.
 
virtual ~Element ()
 Destructor.
 
void SetDragging (bool dragging=true)
 Set if the element are being dragged.
 
void SetHeight (double height)
 Set element height.
 
void SetPosition (const wxPoint2DDouble position)
 Set the element position and update the rectangle.
 
void SetSelected (bool selected=true)
 Set element selection.
 
void SetWidth (double width)
 Set element width.
 
void SetAngle (double angle)
 Set element angle.
 
void ShowPickbox (bool showPickbox=true)
 Set if the pickbox is shown.
 
void SetBorderSize (double borderSize)
 Set the size of the border (shown in selected elements).
 
bool SetOnline (bool online=true)
 Set if the element is online or offline.
 
virtual void SetPointList (std::vector< wxPoint2DDouble > pointList)
 Set the list of points that connect the element to the bus.
 
ElementType GetElementType ()
 
wxRect2DDouble GetRect () const
 Get the element rectangle.
 
wxPoint2DDouble GetPosition () const
 Get the element position.
 
bool IsDragging () const
 Checks if the element is being dragged.
 
double GetHeight () const
 Get the element height.
 
bool IsSelected () const
 Checks if the element is selected.
 
double GetWidth () const
 Get the element width.
 
double GetAngle () const
 Get the element angle.
 
double GetRotationAngle () const
 Get the angle of rotation.
 
bool IsPickboxShown () const
 Checks if the pickbox is shown.
 
bool IsOnline () const
 Checks if the element is online or offline.
 
virtual std::vector< wxPoint2DDouble > GetPointList () const
 Get the list of points that connect the element to bus.
 
virtual bool AddParent (Element *parent, wxPoint2DDouble position)
 Add a parent to the element. This method must be used on power elements that connect to a bus, so the parent must be a bus. The element basic points are calculated in this method, so apply this when the element is being inserted.
 
virtual void AddParent (Element *parent)
 Add a parent to the element.
 
virtual bool Contains (wxPoint2DDouble position) const =0
 Checks if the element contains a position.
 
virtual bool Intersects (wxRect2DDouble rect) const =0
 Check if the element's rect intersects other rect.
 
virtual ElementGetCopy ()
 Get a the element copy.
 
virtual void SetID (int id)
 Set the element ID.
 
virtual int GetID () const
 Get the element ID.
 
virtual void AddChild (Element *child)
 Add a child to the child list.
 
virtual void RemoveChild (Element *child)
 Remove a child from the list.
 
virtual void ReplaceChild (Element *oldChild, Element *newChild)
 Replace a child from the list.
 
virtual wxString GetTipText () const
 Get the tip text.
 
virtual void DrawDC (wxPoint2DDouble translation, double scale, wxGraphicsContext *gc) const
 Draw the element using GDI+.
 
virtual void DrawDC (wxPoint2DDouble translation, double scale, wxDC &dc) const
 Draw the element using wxDC.
 
virtual void Rotate (bool clockwise=true)
 Rotate the element.
 
virtual bool GetContextMenu (wxMenu &menu)
 Get the element contex menu.
 
virtual void AddPoint (wxPoint2DDouble point)
 Add point to the list of points that connect the element to the bus.
 
virtual void StartMove (wxPoint2DDouble position)
 Update the element attributes related to the movement.
 
virtual void Move (wxPoint2DDouble position)
 Move the element other position.
 
virtual void MoveNode (Element *parent, wxPoint2DDouble position)
 Move a node. StartMove(wxPoint2DDouble position) before start moving.
 
virtual bool NodeContains (wxPoint2DDouble position)
 Check if a node contains a point. If contains, set the attributes related to node movement.
 
virtual void UpdateNodes ()
 Update the nodes according to the parents. If a parent is removed, use this method.
 
void SetParent (Element *parent, int num)
 
void SetChild (Element *child, int num)
 
virtual bool SetNodeParent (Element *parent)
 Set a perent to the node. If all conditions are met, a new parent are added to the element and the points related to the nodes will be calculated.
 
virtual void RemoveParent (Element *parent)
 Remove a parent.
 
virtual void ReplaceParent (Element *oldParent, Element *newParent)
 Replace a parent.
 
virtual void RotateNode (Element *parent, bool clockwise=true)
 Rotate a node.
 
virtual bool PickboxContains (wxPoint2DDouble position)
 Check if a pickbox contains a point. If contains the attributes related to pickbox movement will be calculated.
 
virtual void MovePickbox (wxPoint2DDouble position)
 Move the pickbox.
 
virtual wxCursor GetBestPickboxCursor () const
 Get the best cursor to shown to the user when the mouse is above a pickbox.
 
virtual void ResetPickboxes ()
 Remove the pickboxes.
 
virtual void ResetNodes ()
 Remove the active nodes.
 
virtual wxPoint2DDouble WorldToScreen (wxPoint2DDouble translation, double scale, double offsetX=0.0, double offsetY=0.0) const
 Convert the element position to screen position.
 
virtual wxPoint2DDouble WorldToScreen (wxPoint2DDouble position, wxPoint2DDouble translation, double scale, double offsetX=0.0, double offsetY=0.0) const
 Convert a generic position to screen position.
 
virtual bool RotatedRectanglesIntersects (wxRect2DDouble rect1, wxRect2DDouble rect2, double angle1, double angle2) const
 Check if two roteted rectangles intersect.
 
virtual void DrawDCRectangle (wxPoint2DDouble position, double width, double height, double angle, wxDC &dc) const
 Draw a circle.
 
virtual void DrawDCRoundedRectRotated (wxDC &dc, const wxPoint2DDouble &center, double width, double height, double radius, double angleDeg, int arcSegments=8) const
 
virtual void DrawDCCircle (wxPoint2DDouble position, double radius, int numSegments, wxGraphicsContext *gc) const
 Draw a circle using device context.
 
virtual void DrawDCCircle (wxPoint2DDouble position, double radius, wxDC &dc) const
 
virtual void DrawDCArc (wxPoint2DDouble position, double radius, double initAngle, double finalAngle, int numSegments, wxGraphicsContext *gc) const
 
virtual void DrawDCArc (wxPoint2DDouble position, double radius, double initAngle, double finalAngle, wxDC &dc) const
 
virtual void DrawDCTriangle (std::vector< wxPoint2DDouble > points, wxGraphicsContext *gc) const
 Draw rectangle.
 
virtual void DrawDCTriangle (std::vector< wxPoint > points, wxDC &dc) const
 
virtual void DrawDCPickbox (wxPoint2DDouble position, wxGraphicsContext *gc) const
 Draw a point.
 
virtual wxPoint2DDouble RotateAtPosition (wxPoint2DDouble pointToRotate, double angle, bool degrees=true) const
 Rotate a point as element position being the origin.
 
virtual wxPoint2DDouble RotateLocal (wxPoint2DDouble local, double angleDeg) const
 
virtual wxPoint RotateAround (const wxPoint2DDouble &p, const wxPoint2DDouble &center, double angleDeg) const
 
virtual std::vector< Element * > GetParentList () const
 Get the parent list.
 
virtual std::vector< Element * > GetChildList () const
 Get the Child list.
 
virtual void CalculateBoundaries (wxPoint2DDouble &leftUp, wxPoint2DDouble &rightBottom) const
 Calculate the element boundaries.
 
virtual void GeneralMenuItens (wxMenu &menu)
 Insert general itens to context menu.
 
virtual bool ShowForm (wxWindow *parent, Element *element)
 Show element data form.
 
virtual double PointToLineDistance (wxPoint2DDouble point, int *segmentNumber=nullptr) const
 Calculate the distance between a line (formed by point list) and a point.
 
bool IsInserted () const
 Check if the element is properly inserted in the workspace.
 
void SetInserted (bool inserted=true)
 Set if the element is properly inserted in the workspace.
 
virtual rapidxml::xml_node * SaveElement (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *elementListNode)
 
virtual bool OpenElement (rapidxml::xml_node<> *elementNode)
 
void SaveCADProperties (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *elementNode)
 
bool OpenCADProperties (rapidxml::xml_node<> *elementNode)
 

Static Public Member Functions

static bool DoubleFromString (wxWindow *parent, wxString strValue, double &value, wxString errorMsg)
 Get a double value from a string. Show a error message if the conversion fail.
 
static bool IntFromString (wxWindow *parent, wxString strValue, int &value, wxString errorMsg)
 Convert a string to int. Show a error message if the conversion fail.
 
static wxString StringFromDouble (double value, int minDecimal=1, int maxDecimals=13)
 Convert a double value to string.
 

Protected Attributes

ElementType m_elementType = ElementType::TYPE_NONE
 
int m_elementID = 0
 
std::vector< Element * > m_parentList
 
std::vector< Element * > m_childList
 
wxRect2DDouble m_rect
 
wxPoint2DDouble m_position
 
double m_width = 0.0
 
double m_height = 0.0
 
double m_angle = 0.0
 
double m_borderSize = 2.0
 
double m_rotationAngle = 45.0
 
double m_switchSize = 10.0
 
std::vector< wxRect2DDouble > m_switchRect
 
bool m_selected = false
 
bool m_dragging = false
 
bool m_showPickbox = false
 
bool m_inserted = false
 
int m_activePickboxID = ID_PB_NONE
 
int m_activeNodeID = 0
 
std::vector< wxPoint2DDouble > m_pointList
 
std::vector< wxPoint2DDouble > m_movePts
 
wxPoint2DDouble m_moveStartPt
 
wxPoint2DDouble m_movePos
 
bool m_online = true
 
wxColour m_selectionColour
 

Detailed Description

Base class of all elements of the program. This class is responsible for manage graphical and his data.

Author
Thales Lima Oliveira thale.nosp@m.s@uf.nosp@m.u.br
Date
19/09/2017
Warning
Don't use this base class directly. Always create a derivative element to use it.

Definition at line 111 of file Element.h.

Constructor & Destructor Documentation

◆ Element()

Element::Element ( )

Constructor.

Definition at line 26 of file Element.cpp.

26{ m_selectionColour.Set(0, 128, 255, 128); }

◆ ~Element()

virtual Element::~Element ( )
inlinevirtual

Destructor.

Definition at line 122 of file Element.h.

122{}

Member Function Documentation

◆ AddChild()

void Element::AddChild ( Element child)
virtual

Add a child to the child list.

Parameters
childNew child.

Definition at line 566 of file Element.cpp.

566{ m_childList.push_back(child); }
Here is the caller graph for this function:

◆ AddParent() [1/2]

virtual void Element::AddParent ( Element parent)
inlinevirtual

Add a parent to the element.

Parameters
parentElement parent.

Definition at line 244 of file Element.h.

244{ m_parentList.push_back(parent); }

◆ AddParent() [2/2]

virtual bool Element::AddParent ( Element parent,
wxPoint2DDouble  position 
)
inlinevirtual

Add a parent to the element. This method must be used on power elements that connect to a bus, so the parent must be a bus. The element basic points are calculated in this method, so apply this when the element is being inserted.

Parameters
parentElement parent.
positionNode position in the parent.

Reimplemented in Bus, Capacitor, EMTElement, HarmCurrent, Inductor, Line, Load, Machines, Transformer, and Text.

Definition at line 239 of file Element.h.

239{ return false; }

◆ AddPoint()

virtual void Element::AddPoint ( wxPoint2DDouble  point)
inlinevirtual

Add point to the list of points that connect the element to the bus.

Parameters
pointPoint to be added.

Reimplemented in Branch, and Line.

Definition at line 327 of file Element.h.

327{}

◆ CalculateBoundaries()

void Element::CalculateBoundaries ( wxPoint2DDouble &  leftUp,
wxPoint2DDouble &  rightBottom 
) const
virtual

Calculate the element boundaries.

Parameters
leftUpTop-left position of the element.
rightBottomBottom-right position of the element.

Reimplemented in Line.

Definition at line 478 of file Element.cpp.

479{
480 // Check rect corners boundaries.
481
482 // Get rectangle corners
483 wxPoint2DDouble rectCorner[4] = { m_rect.GetLeftTop(), m_rect.GetLeftBottom(), m_rect.GetRightBottom(),
484 m_rect.GetRightTop() };
485 // Rotate corners.
486 for (int i = 0; i < 4; ++i) { rectCorner[i] = RotateAtPosition(rectCorner[i], m_angle); }
487 leftUp = rectCorner[0];
488 rightBottom = rectCorner[0];
489 for (int i = 1; i < 4; ++i) {
490 if (rectCorner[i].m_x < leftUp.m_x) leftUp.m_x = rectCorner[i].m_x;
491 if (rectCorner[i].m_y < leftUp.m_y) leftUp.m_y = rectCorner[i].m_y;
492 if (rectCorner[i].m_x > rightBottom.m_x) rightBottom.m_x = rectCorner[i].m_x;
493 if (rectCorner[i].m_y > rightBottom.m_y) rightBottom.m_y = rectCorner[i].m_y;
494 }
495
496 // Check points list boundaries.
497 for (int i = 0; i < (int)m_pointList.size(); i++) {
498 if (m_pointList[i].m_x < leftUp.m_x) leftUp.m_x = m_pointList[i].m_x;
499 if (m_pointList[i].m_y < leftUp.m_y) leftUp.m_y = m_pointList[i].m_y;
500 if (m_pointList[i].m_x > rightBottom.m_x) rightBottom.m_x = m_pointList[i].m_x;
501 if (m_pointList[i].m_y > rightBottom.m_y) rightBottom.m_y = m_pointList[i].m_y;
502 }
503}
virtual wxPoint2DDouble RotateAtPosition(wxPoint2DDouble pointToRotate, double angle, bool degrees=true) const
Rotate a point as element position being the origin.
Definition Element.cpp:292
Here is the call graph for this function:

◆ Contains()

virtual bool Element::Contains ( wxPoint2DDouble  position) const
pure virtual

Checks if the element contains a position.

Parameters
positionPosition to be checked.

Implemented in ConnectionLine, Constant, Exponential, Gain, IOControl, Limiter, MathExpression, MathOperation, RateLimiter, Sum, TransferFunction, Branch, Bus, Capacitor, EMTElement, HarmCurrent, Inductor, Line, Machines, Shunt, Transformer, and Text.

Here is the caller graph for this function:

◆ DoubleFromString()

bool Element::DoubleFromString ( wxWindow *  parent,
wxString  strValue,
double &  value,
wxString  errorMsg 
)
static

Get a double value from a string. Show a error message if the conversion fail.

Parameters
parentMessage box parent.
strValueString value to be converted.
valueDouble value converted.
errorMsgError message.

Definition at line 505 of file Element.cpp.

506{
507 double dValue = 0.0;
508
509 if (!strValue.ToDouble(&dValue)) {
510 wxMessageDialog msgDialog(parent, errorMsg, _("Error"), wxOK | wxCENTRE | wxICON_ERROR);
511 msgDialog.ShowModal();
512 return false;
513 }
514
515 value = dValue;
516 return true;
517}

◆ DrawDC() [1/2]

virtual void Element::DrawDC ( wxPoint2DDouble  translation,
double  scale,
wxDC &  dc 
) const
inlinevirtual

Draw the element using wxDC.

Parameters
translationTranslation of the system.
scaleScale of the system.
dcDevice context.

Reimplemented in Bus, Capacitor, EMTElement, HarmCurrent, Inductor, Line, Load, Machines, and Transformer.

Definition at line 311 of file Element.h.

311{}

◆ DrawDC() [2/2]

virtual void Element::DrawDC ( wxPoint2DDouble  translation,
double  scale,
wxGraphicsContext *  gc 
) const
inlinevirtual

Draw the element using GDI+.

Parameters
translationTranslation of the system.
scaleScale of the system.
gcGraphics context

Reimplemented in ConnectionLine, Constant, Exponential, Gain, IOControl, Limiter, MathExpression, MathOperation, RateLimiter, Sum, TransferFunction, Bus, Capacitor, EMTElement, HarmCurrent, Inductor, Line, Load, Machines, and Transformer.

Definition at line 304 of file Element.h.

304{}

◆ DrawDCArc() [1/2]

void Element::DrawDCArc ( wxPoint2DDouble  position,
double  radius,
double  initAngle,
double  finalAngle,
int  numSegments,
wxGraphicsContext *  gc 
) const
virtual

Definition at line 211 of file Element.cpp.

212{
213 double initAngRad = wxDegToRad(initAngle);
214 double finalAngRad = wxDegToRad(finalAngle);
215 wxPoint2DDouble* points = new wxPoint2DDouble[numSegments + 2];
216 for (int i = 0; i <= numSegments; i++) {
217 double theta = initAngRad + (finalAngRad - initAngRad) * double(i) / double(numSegments);
218 points[i] = wxPoint2DDouble(radius * std::cos(theta) + position.m_x, radius * std::sin(theta) + position.m_y);
219 }
220
221 gc->StrokeLines(numSegments + 1, points);
222 delete[] points;
223}

◆ DrawDCArc() [2/2]

void Element::DrawDCArc ( wxPoint2DDouble  position,
double  radius,
double  initAngle,
double  finalAngle,
wxDC &  dc 
) const
virtual

Definition at line 225 of file Element.cpp.

226{
227 dc.DrawEllipticArc(wxRound(position.m_x - radius), wxRound(position.m_y - radius), wxRound(2 * radius), wxRound(2 * radius), initAngle, finalAngle);
228}

◆ DrawDCCircle() [1/2]

void Element::DrawDCCircle ( wxPoint2DDouble  position,
double  radius,
int  numSegments,
wxGraphicsContext *  gc 
) const
virtual

Draw a circle using device context.

Parameters
positionCircle position.
radiusCircle radius
numSegmentsNum of segments of the circle.
glDevice context.

Definition at line 177 of file Element.cpp.

178{
179 wxPoint2DDouble* pts = new wxPoint2DDouble[numSegments + 1];
180 for (int i = 0; i < numSegments; i++) {
181 double theta = 2.0 * 3.1415926 * double(i) / double(numSegments);
182 pts[i] = wxPoint2DDouble(radius * std::cos(theta) + position.m_x, radius * std::sin(theta) + position.m_y);
183 }
184 pts[numSegments] = pts[0];
185 gc->DrawLines(numSegments + 1, pts);
186 delete[] pts;
187}
Here is the caller graph for this function:

◆ DrawDCCircle() [2/2]

void Element::DrawDCCircle ( wxPoint2DDouble  position,
double  radius,
wxDC &  dc 
) const
virtual

Definition at line 189 of file Element.cpp.

190{
191 dc.DrawCircle(wxRound(position.m_x), wxRound(position.m_y), wxRound(radius));
192}

◆ DrawDCPickbox()

void Element::DrawDCPickbox ( wxPoint2DDouble  position,
wxGraphicsContext *  gc 
) const
virtual

Draw a point.

Parameters
positionPoint position.
sizePoint size.

Draw line.

Parameters
pointsLine vertices.
modeOpenGl primitive.

Draw pickbox.

Parameters
positionPickbox position.

Draw pickbox using direct context.

Parameters
positionPickbox position.
gcDirect context.

Definition at line 285 of file Element.cpp.

286{
287 gc->SetPen(wxPen(wxColour(0, 0, 0, 255)));
288 gc->SetBrush(wxBrush(wxColour(255, 255, 255, 204)));
289 gc->DrawRectangle(position.m_x, position.m_y, 8, 8);
290}
Here is the caller graph for this function:

◆ DrawDCRectangle()

void Element::DrawDCRectangle ( wxPoint2DDouble  position,
double  width,
double  height,
double  angle,
wxDC &  dc 
) const
virtual

Draw a circle.

Parameters
positionCircle position.
radiusCircle radius
numSegmentsNum of segments of the circle.
modeOpenGl primitive.

Definition at line 45 of file Element.cpp.

46{
47 if (angle == 0.0) {
48 wxPoint poly[4] = {
49 wxPoint((int)(position.m_x - width / 2.0), (int)(position.m_y - height / 2.0)),
50 wxPoint((int)(position.m_x + width / 2.0), (int)(position.m_y - height / 2.0)),
51 wxPoint((int)(position.m_x + width / 2.0), (int)(position.m_y + height / 2.0)),
52 wxPoint((int)(position.m_x - width / 2.0), (int)(position.m_y + height / 2.0))
53 };
54 dc.DrawPolygon(4, poly);
55 return;
56 }
57
58 double hw = width / 2.0;
59 double hh = height / 2.0;
60 double angleRad = wxDegToRad(angle);
61
62 // Retângulo centrado na origem
63 wxPoint2DDouble pts[4] = {
64 {-hw, -hh},
65 { hw, -hh},
66 { hw, hh},
67 {-hw, hh}
68 };
69
70 wxPoint poly[4];
71
72 for (int i = 0; i < 4; ++i)
73 {
74 double x = pts[i].m_x;
75 double y = pts[i].m_y;
76
77 // Rotação
78 double xr = x * cos(angleRad) - y * sin(angleRad);
79 double yr = x * sin(angleRad) + y * cos(angleRad);
80
81 // Translação para centro
82 poly[i].x = (int)(xr + position.m_x);
83 poly[i].y = (int)(yr + position.m_y);
84 }
85
86 dc.DrawPolygon(4, poly);
87
88}
Here is the caller graph for this function:

◆ DrawDCRoundedRectRotated()

void Element::DrawDCRoundedRectRotated ( wxDC &  dc,
const wxPoint2DDouble &  center,
double  width,
double  height,
double  radius,
double  angleDeg,
int  arcSegments = 8 
) const
virtual

Definition at line 90 of file Element.cpp.

91{
92 radius = std::min(radius, std::min(width, height) / 2.0);
93
94 double hw = width / 2.0;
95 double hh = height / 2.0;
96
97 double rad = wxDegToRad(angleDeg);
98 double c = std::cos(rad);
99 double s = std::sin(rad);
100
101 auto rotate = [&](double x, double y)
102 {
103 double xr = c * x - s * y + center.m_x;
104 double yr = s * x + c * y + center.m_y;
105 return wxPoint2DDouble(xr, yr);
106 };
107
108 auto drawArc = [&](double cx, double cy,
109 double startDeg)
110 {
111 wxPoint2DDouble arcCenterLocal(cx, cy);
112 wxPoint2DDouble arcCenter = rotate(arcCenterLocal.m_x,
113 arcCenterLocal.m_y);
114
115 double start = startDeg + angleDeg;
116 double end = start + 90.0;
117
118 dc.DrawEllipticArc(
119 wxRound(arcCenter.m_x - radius),
120 wxRound(arcCenter.m_y - radius),
121 wxRound(radius * 2),
122 wxRound(radius * 2),
123 start,
124 end
125 );
126 };
127
128 auto line = [&](double x1, double y1,
129 double x2, double y2,
130 wxPoint& p1, wxPoint& p2)
131 {
132 wxPoint2DDouble p1d = rotate(x1, y1);
133 wxPoint2DDouble p2d = rotate(x2, y2);
134 p1 = wxPoint(wxRound(p1d.m_x), wxRound(p1d.m_y));
135 p2 = wxPoint(wxRound(p2d.m_x), wxRound(p2d.m_y));
136
137 //dc.DrawLine(p1.x, p1.y, p2.x, p2.y);
138 };
139
140 wxPen pen = dc.GetPen();
141
142 wxPoint pts[4];
143 line(-hw + radius, -hh,
144 hw - radius, -hh,
145 pts[0], pts[1]);
146
147 line(hw - radius, hh,
148 -hw + radius, hh,
149 pts[2], pts[3]);
150
151 dc.SetPen(*wxTRANSPARENT_PEN);
152 dc.DrawPolygon(4, pts);
153 dc.SetPen(pen);
154 dc.DrawLine(pts[0].x, pts[0].y, pts[1].x, pts[1].y);
155 dc.DrawLine(pts[2].x, pts[2].y, pts[3].x, pts[3].y);
156
157 line(hw, -hh + radius,
158 hw, hh - radius,
159 pts[0], pts[1]);
160
161 line(-hw, hh - radius,
162 -hw, -hh + radius,
163 pts[2], pts[3]);
164
165 dc.SetPen(*wxTRANSPARENT_PEN);
166 dc.DrawPolygon(4, pts);
167 dc.SetPen(pen);
168 dc.DrawLine(pts[0].x, pts[0].y, pts[1].x, pts[1].y);
169 dc.DrawLine(pts[2].x, pts[2].y, pts[3].x, pts[3].y);
170
171 drawArc(hw - radius, -hh + radius, 0 - angleDeg * 2);
172 drawArc(hw - radius, hh - radius, 270 - angleDeg * 2);
173 drawArc(-hw + radius, hh - radius, 180 - angleDeg * 2);
174 drawArc(-hw + radius, -hh + radius, 90 - angleDeg * 2);
175}

◆ DrawDCTriangle() [1/2]

void Element::DrawDCTriangle ( std::vector< wxPoint >  points,
wxDC &  dc 
) const
virtual

Definition at line 243 of file Element.cpp.

244{
245 points.emplace_back(points[0]);
246 dc.DrawPolygon(4, &points[0]);
247}

◆ DrawDCTriangle() [2/2]

void Element::DrawDCTriangle ( std::vector< wxPoint2DDouble >  points,
wxGraphicsContext *  gc 
) const
virtual

Draw rectangle.

Parameters
positionRectangle position.
widthRectangle width.
heightRectangle height.
modeOpenGl primitive.

Draw rectangle.

Parameters
pointsRectangle vertices.
modeOpenGl primitive.

Draw a triangle.

Parameters
pointsTriangle vertices.
modeOpenGl primitive.

Draw a triangle.

Parameters
pointsTriangle vertices.
gcDevice context.

Definition at line 237 of file Element.cpp.

238{
239 points.emplace_back(points[0]);
240 gc->DrawLines(4, &points[0]);
241}
Here is the caller graph for this function:

◆ GeneralMenuItens()

void Element::GeneralMenuItens ( wxMenu &  menu)
virtual

Insert general itens to context menu.

Parameters
menuMenu that will be inserted the general itens.

Definition at line 457 of file Element.cpp.

458{
459 wxFileName exeFileName(wxStandardPaths::Get().GetExecutablePath());
460 wxString exePath = exeFileName.GetPath();
461
462 wxMenuItem* clockItem = new wxMenuItem(&menu, ID_ROTATE_CLOCK, _("Rotate clockwise"));
463 clockItem->SetBitmap(
464 wxImage(exePath + wxFileName::DirName("\\..\\data\\images\\menu\\rotateClock16.png", wxPATH_WIN).GetPath()));
465 menu.Append(clockItem);
466
467 wxMenuItem* counterClockItem = new wxMenuItem(&menu, ID_ROTATE_COUNTERCLOCK, _("Rotate counter-clockwise"));
468 counterClockItem->SetBitmap(wxImage(
469 exePath + wxFileName::DirName("\\..\\data\\images\\menu\\rotateCounterClock16.png", wxPATH_WIN).GetPath()));
470 menu.Append(counterClockItem);
471
472 wxMenuItem* deleteItem = new wxMenuItem(&menu, ID_DELETE, _("Delete"));
473 deleteItem->SetBitmap(
474 wxImage(exePath + wxFileName::DirName("\\..\\data\\images\\menu\\delete16.png", wxPATH_WIN).GetPath()));
475 menu.Append(deleteItem);
476}
@ ID_DELETE
Definition Element.h:80
@ ID_ROTATE_CLOCK
Definition Element.h:78
@ ID_ROTATE_COUNTERCLOCK
Definition Element.h:79
Here is the caller graph for this function:

◆ GetAngle()

double Element::GetAngle ( ) const
inline

Get the element angle.

Returns
Angle value.

Definition at line 211 of file Element.h.

211{ return m_angle; }
Here is the caller graph for this function:

◆ GetBestPickboxCursor()

virtual wxCursor Element::GetBestPickboxCursor ( ) const
inlinevirtual

Get the best cursor to shown to the user when the mouse is above a pickbox.

Returns
Cursor.

Reimplemented in Branch, Bus, and Line.

Definition at line 401 of file Element.h.

401{ return wxCURSOR_ARROW; }

◆ GetChildList()

virtual std::vector< Element * > Element::GetChildList ( ) const
inlinevirtual

Get the Child list.

Returns
Child List.

Definition at line 564 of file Element.h.

564{ return m_childList; }

◆ GetContextMenu()

virtual bool Element::GetContextMenu ( wxMenu &  menu)
inlinevirtual

Get the element contex menu.

Parameters
menumenu that will be inserted the element itens.
Returns
True if was possible to build the menu, false otherwise.

Reimplemented in Branch, Bus, Capacitor, EMTElement, HarmCurrent, IndMotor, Inductor, Line, Load, SyncGenerator, SyncMotor, and Transformer.

Definition at line 322 of file Element.h.

322{ return false; }

◆ GetCopy()

virtual Element * Element::GetCopy ( )
inlinevirtual

Get a the element copy.

Returns
Copy of the element.

Reimplemented in ConnectionLine, Constant, Divider, Exponential, Gain, IOControl, Limiter, MathExpression, Multiplier, RateLimiter, Sum, TransferFunction, Bus, Capacitor, EMTElement, HarmCurrent, IndMotor, Inductor, Line, Load, SyncGenerator, SyncMotor, Transformer, and Text.

Definition at line 261 of file Element.h.

261{ return nullptr; }

◆ GetElementType()

ElementType Element::GetElementType ( )
inline

Definition at line 176 of file Element.h.

176{ return m_elementType; }

◆ GetHeight()

double Element::GetHeight ( ) const
inline

Get the element height.

Returns
Element height.

Definition at line 196 of file Element.h.

196{ return m_height; }

◆ GetID()

virtual int Element::GetID ( ) const
inlinevirtual

Get the element ID.

Returns
Element ID.

Definition at line 271 of file Element.h.

271{ return m_elementID; }

◆ GetParentList()

virtual std::vector< Element * > Element::GetParentList ( ) const
inlinevirtual

Get the parent list.

Returns
Parent list.

Definition at line 559 of file Element.h.

559{ return m_parentList; }
Here is the caller graph for this function:

◆ GetPointList()

virtual std::vector< wxPoint2DDouble > Element::GetPointList ( ) const
inlinevirtual

Get the list of points that connect the element to bus.

Returns
List of points.

Definition at line 231 of file Element.h.

231{ return m_pointList; }

◆ GetPosition()

wxPoint2DDouble Element::GetPosition ( ) const
inline

Get the element position.

Returns
Element position.

Definition at line 186 of file Element.h.

186{ return m_position; }
Here is the caller graph for this function:

◆ GetRect()

wxRect2DDouble Element::GetRect ( ) const
inline

Get the element rectangle.

Returns
Element rectangle.

Definition at line 181 of file Element.h.

181{ return m_rect; }

◆ GetRotationAngle()

double Element::GetRotationAngle ( ) const
inline

Get the angle of rotation.

Returns
Rotation angle.

Definition at line 216 of file Element.h.

216{ return m_rotationAngle; }

◆ GetTipText()

virtual wxString Element::GetTipText ( ) const
inlinevirtual

Get the tip text.

Returns
Tip text.

Reimplemented in Bus, Capacitor, EMTElement, HarmCurrent, IndMotor, Inductor, Line, Load, SyncGenerator, SyncMotor, and Transformer.

Definition at line 295 of file Element.h.

295{ return wxEmptyString; }

◆ GetWidth()

double Element::GetWidth ( ) const
inline

Get the element width.

Returns
Element width.

Definition at line 206 of file Element.h.

206{ return m_width; }

◆ Intersects()

virtual bool Element::Intersects ( wxRect2DDouble  rect) const
pure virtual

Check if the element's rect intersects other rect.

Parameters
rectRect to check intersection.

Implemented in ConnectionLine, Constant, Exponential, Gain, IOControl, Limiter, MathExpression, MathOperation, RateLimiter, Sum, TransferFunction, Branch, Bus, Capacitor, EMTElement, HarmCurrent, Inductor, Line, Machines, Shunt, Transformer, and Text.

Here is the caller graph for this function:

◆ IntFromString()

bool Element::IntFromString ( wxWindow *  parent,
wxString  strValue,
int &  value,
wxString  errorMsg 
)
static

Convert a string to int. Show a error message if the conversion fail.

Parameters
parentMessage box parent.
strValueString value to be converted.
valueInt value converted.
errorMsgError message.

Definition at line 519 of file Element.cpp.

520{
521 long int iValue = 0;
522
523 if (!strValue.ToLong(&iValue)) {
524 wxMessageDialog msgDialog(parent, errorMsg, _("Error"), wxOK | wxCENTRE | wxICON_ERROR);
525 msgDialog.ShowModal();
526 return false;
527 }
528
529 value = iValue;
530 return true;
531}

◆ IsDragging()

bool Element::IsDragging ( ) const
inline

Checks if the element is being dragged.

Returns
True if is being dragged, false otherwise.

Definition at line 191 of file Element.h.

191{ return m_dragging; }

◆ IsInserted()

bool Element::IsInserted ( ) const
inline

Check if the element is properly inserted in the workspace.

Returns
true if is inserted properly, false otherwise

Definition at line 625 of file Element.h.

625{ return m_inserted; }

◆ IsOnline()

bool Element::IsOnline ( ) const
inline

Checks if the element is online or offline.

Returns
True if online, false if offline.

Definition at line 226 of file Element.h.

226{ return m_online; }
Here is the caller graph for this function:

◆ IsPickboxShown()

bool Element::IsPickboxShown ( ) const
inline

Checks if the pickbox is shown.

Returns
True if the pickbox is show, false otherwise.

Definition at line 221 of file Element.h.

221{ return m_showPickbox; }

◆ IsSelected()

bool Element::IsSelected ( ) const
inline

Checks if the element is selected.

Returns
True if selected, false otherwise.

Definition at line 201 of file Element.h.

201{ return m_selected; }

◆ Move()

void Element::Move ( wxPoint2DDouble  position)
virtual

Move the element other position.

Parameters
positionPosition that the element will be moved. Use StartMove(wxPoint2DDouble position) before start moving.

Reimplemented in ConnectionLine, ControlElement, Gain, Branch, Line, Machines, Shunt, and Transformer.

Definition at line 335 of file Element.cpp.

335{ SetPosition(m_movePos + position - m_moveStartPt); }
void SetPosition(const wxPoint2DDouble position)
Set the element position and update the rectangle.
Definition Element.cpp:27
Here is the call graph for this function:

◆ MoveNode()

virtual void Element::MoveNode ( Element parent,
wxPoint2DDouble  position 
)
inlinevirtual

Move a node. StartMove(wxPoint2DDouble position) before start moving.

Parameters
parentNode's parent.
positionNew node position.

Reimplemented in Machines, Shunt, Branch, Line, and Transformer.

Definition at line 346 of file Element.h.

346{}

◆ MovePickbox()

virtual void Element::MovePickbox ( wxPoint2DDouble  position)
inlinevirtual

Move the pickbox.

Parameters
positionposition that the pickbox will be moved.

Reimplemented in Branch, Bus, and Line.

Definition at line 396 of file Element.h.

396{}

◆ NodeContains()

virtual bool Element::NodeContains ( wxPoint2DDouble  position)
inlinevirtual

Check if a node contains a point. If contains, set the attributes related to node movement.

Parameters
positionPosition tested.
Returns
True if at least one node contains the position, false otherwise.

Reimplemented in Branch, Machines, and Shunt.

Definition at line 352 of file Element.h.

352{ return false; }

◆ OpenCADProperties()

bool Element::OpenCADProperties ( rapidxml::xml_node<> *  elementNode)

Definition at line 655 of file Element.cpp.

656{
657 auto cadPropNode = elementNode->first_node("CADProperties");
658 if (!cadPropNode) return false;
659
660 auto position = cadPropNode->first_node("Position");
661 double posX = XMLParser::GetNodeValueDouble(position, "X");
662 double posY = XMLParser::GetNodeValueDouble(position, "Y");
663 auto size = cadPropNode->first_node("Size");
664 m_width = XMLParser::GetNodeValueDouble(size, "Width");
665 m_height = XMLParser::GetNodeValueDouble(size, "Height");
666 m_angle = XMLParser::GetNodeValueDouble(cadPropNode, "Angle");
667 SetPosition(wxPoint2DDouble(posX, posY));
668 return true;
669}

◆ OpenElement()

virtual bool Element::OpenElement ( rapidxml::xml_node<> *  elementNode)
inlinevirtual

Definition at line 634 of file Element.h.

634{ return true; }

◆ PickboxContains()

virtual bool Element::PickboxContains ( wxPoint2DDouble  position)
inlinevirtual

Check if a pickbox contains a point. If contains the attributes related to pickbox movement will be calculated.

Parameters
positionPosition to be checked.
Returns
True if the element constains the pickbox, false otherwise.

Reimplemented in Branch, Bus, and Line.

Definition at line 391 of file Element.h.

391{ return false; }

◆ PointToLineDistance()

double Element::PointToLineDistance ( wxPoint2DDouble  point,
int *  segmentNumber = nullptr 
) const
virtual

Calculate the distance between a line (formed by point list) and a point.

Parameters
pointorigin point.
segmentNumberSotores the segment number clicked
Returns
The distance between the point and the line.

Definition at line 601 of file Element.cpp.

602{
603 //[Ref] http://geomalgorithms.com/a02-_lines.html
604 double distance = 100.0; // Big initial distance.
605 wxPoint2DDouble p0 = point;
606
607 for (int i = 1; i < (int)m_pointList.size() - 2; i++) {
608 double d = 0.0;
609
610 wxPoint2DDouble p1 = m_pointList[i];
611 wxPoint2DDouble p2 = m_pointList[i + 1];
612
613 wxPoint2DDouble v = p2 - p1;
614 wxPoint2DDouble w = p0 - p1;
615
616 double c1 = w.m_x * v.m_x + w.m_y * v.m_y;
617 double c2 = v.m_x * v.m_x + v.m_y * v.m_y;
618
619 if (c1 <= 0.0) {
620 d = std::sqrt(std::pow(p0.m_y - p1.m_y, 2) + std::pow(p0.m_x - p1.m_x, 2));
621 }
622 else if (c2 <= c1) {
623 d = std::sqrt(std::pow(p0.m_y - p2.m_y, 2) + std::pow(p0.m_x - p2.m_x, 2));
624 }
625 else {
626 d = std::abs((p2.m_y - p1.m_y) * p0.m_x - (p2.m_x - p1.m_x) * p0.m_y + p2.m_x * p1.m_y - p2.m_y * p1.m_x) /
627 std::sqrt(std::pow(p2.m_y - p1.m_y, 2) + std::pow(p2.m_x - p1.m_x, 2));
628 }
629 if (d < distance) {
630 distance = d;
631 if (segmentNumber) *segmentNumber = i;
632 }
633 }
634
635 return distance;
636}
Here is the caller graph for this function:

◆ RemoveChild()

void Element::RemoveChild ( Element child)
virtual

Remove a child from the list.

Parameters
childChild to remove.

Definition at line 567 of file Element.cpp.

568{
569 for (auto it = m_childList.begin(); it != m_childList.end();) {
570 if (*it == child) it = m_childList.erase(it);
571 else ++it;
572 }
573}

◆ RemoveParent()

virtual void Element::RemoveParent ( Element parent)
inlinevirtual

Remove a parent.

Parameters
parentParent to be removed.

Reimplemented in ConnectionLine, Branch, Machines, and Shunt.

Definition at line 371 of file Element.h.

371{}

◆ ReplaceChild()

void Element::ReplaceChild ( Element oldChild,
Element newChild 
)
virtual

Replace a child from the list.

Parameters
oldChildOld child.
newChildNew child.

Definition at line 575 of file Element.cpp.

576{
577 for (int i = 0; i < (int)m_childList.size(); i++) {
578 if (m_childList[i] == oldChild) m_childList[i] = newChild;
579 }
580}

◆ ReplaceParent()

void Element::ReplaceParent ( Element oldParent,
Element newParent 
)
virtual

Replace a parent.

Parameters
oldParentParent to be replaced.
newParentNew parent.

Definition at line 559 of file Element.cpp.

560{
561 for (int i = 0; i < (int)m_parentList.size(); i++) {
562 if (m_parentList[i] == oldParent) m_parentList[i] = newParent;
563 }
564}

◆ ResetNodes()

virtual void Element::ResetNodes ( )
inlinevirtual

Remove the active nodes.

Definition at line 409 of file Element.h.

409{ m_activeNodeID = 0; }

◆ ResetPickboxes()

virtual void Element::ResetPickboxes ( )
inlinevirtual

Remove the pickboxes.

Definition at line 405 of file Element.h.

405{ m_activePickboxID = ID_PB_NONE; }
@ ID_PB_NONE
Definition Element.h:61

◆ Rotate()

virtual void Element::Rotate ( bool  clockwise = true)
inlinevirtual

Rotate the element.

Parameters
clockwiseTrue to rotate clockwise, false to rotate counter-clockwise.

Reimplemented in Constant, Exponential, Gain, IOControl, Limiter, MathExpression, MathOperation, RateLimiter, Sum, TransferFunction, Bus, Capacitor, EMTElement, HarmCurrent, Inductor, Load, Machines, Transformer, and Text.

Definition at line 316 of file Element.h.

316{}

◆ RotateAround()

wxPoint Element::RotateAround ( const wxPoint2DDouble &  p,
const wxPoint2DDouble &  center,
double  angleDeg 
) const
virtual

Definition at line 314 of file Element.cpp.

315{
316 double rad = wxDegToRad(angleDeg);
317 double c = std::cos(rad);
318 double s = std::sin(rad);
319
320 double dx = p.m_x - center.m_x;
321 double dy = p.m_y - center.m_y;
322
323 double xr = c * dx - s * dy + center.m_x;
324 double yr = s * dx + c * dy + center.m_y;
325
326 return wxPoint(wxRound(xr), wxRound(yr));
327}

◆ RotateAtPosition()

wxPoint2DDouble Element::RotateAtPosition ( wxPoint2DDouble  pointToRotate,
double  angle,
bool  degrees = true 
) const
virtual

Rotate a point as element position being the origin.

Parameters
pointToRotatePoint that will be rotated.
angleAngle of rotation.
degreesTrue if the angle is in degrees, false if radians.

Definition at line 292 of file Element.cpp.

293{
294 double radAngle = angle;
295 if (degrees) radAngle = wxDegToRad(angle);
296 return wxPoint2DDouble(std::cos(radAngle) * (pointToRotate.m_x - m_position.m_x) -
297 std::sin(radAngle) * (pointToRotate.m_y - m_position.m_y) + m_position.m_x,
298 std::sin(radAngle) * (pointToRotate.m_x - m_position.m_x) +
299 std::cos(radAngle) * (pointToRotate.m_y - m_position.m_y) + m_position.m_y);
300}
Here is the caller graph for this function:

◆ RotatedRectanglesIntersects()

bool Element::RotatedRectanglesIntersects ( wxRect2DDouble  rect1,
wxRect2DDouble  rect2,
double  angle1,
double  angle2 
) const
virtual

Check if two roteted rectangles intersect.

Parameters
rect1First rect.
rect2Second rect.
angle1Rotation algle of first rectangle.
angle2Rotation angle of second rectangle.

Definition at line 359 of file Element.cpp.

363{
364 wxPoint2DDouble rect1Corners[4] = { rect1.GetLeftTop(), rect1.GetLeftBottom(), rect1.GetRightBottom(),
365 rect1.GetRightTop() };
366 wxPoint2DDouble rect2Corners[4] = { rect2.GetLeftTop(), rect2.GetLeftBottom(), rect2.GetRightBottom(),
367 rect2.GetRightTop() };
368 wxPoint2DDouble rect1Center(rect1.m_x + rect1.m_width / 2.0, rect1.m_y + rect1.m_height / 2.0);
369 wxPoint2DDouble rect2Center(rect2.m_x + rect2.m_width / 2.0, rect2.m_y + rect2.m_height / 2.0);
370
371 // Rotate the corners.
372 double radAngle1 = wxDegToRad(angle1);
373 double radAngle2 = wxDegToRad(angle2);
374
375 for (int i = 0; i < 4; i++) {
376 rect1Corners[i] =
377 wxPoint2DDouble(std::cos(radAngle1) * (rect1Corners[i].m_x - rect1Center.m_x) -
378 std::sin(radAngle1) * (rect1Corners[i].m_y - rect1Center.m_y) + rect1Center.m_x,
379 std::sin(radAngle1) * (rect1Corners[i].m_x - rect1Center.m_x) +
380 std::cos(radAngle1) * (rect1Corners[i].m_y - rect1Center.m_y) + rect1Center.m_y);
381
382 rect2Corners[i] =
383 wxPoint2DDouble(std::cos(radAngle2) * (rect2Corners[i].m_x - rect2Center.m_x) -
384 std::sin(radAngle2) * (rect2Corners[i].m_y - rect2Center.m_y) + rect2Center.m_x,
385 std::sin(radAngle2) * (rect2Corners[i].m_x - rect2Center.m_x) +
386 std::cos(radAngle2) * (rect2Corners[i].m_y - rect2Center.m_y) + rect2Center.m_y);
387 }
388
389 //[Ref] http://www.gamedev.net/page/resources/_/technical/game-programming/2d-rotated-rectangle-collision-r2604
390
391 // Find the rectangles axis to project
392 wxPoint2DDouble axis[4] = { rect1Corners[3] - rect1Corners[0], rect1Corners[3] - rect1Corners[2],
393 rect2Corners[3] - rect2Corners[0], rect2Corners[3] - rect2Corners[2] };
394
395 // Calculate the projected points to each axis
396 wxPoint2DDouble rect1ProjPts[4][4]; // [axis][corner]
397 wxPoint2DDouble rect2ProjPts[4][4]; // [axis][corner]
398 for (int i = 0; i < 4; i++) {
399 double den = axis[i].m_x * axis[i].m_x + axis[i].m_y * axis[i].m_y;
400 for (int j = 0; j < 4; j++) {
401 double m_rectProj = (rect1Corners[j].m_x * axis[i].m_x + rect1Corners[j].m_y * axis[i].m_y) / den;
402 double rectProj = (rect2Corners[j].m_x * axis[i].m_x + rect2Corners[j].m_y * axis[i].m_y) / den;
403
404 rect1ProjPts[i][j] = wxPoint2DDouble(m_rectProj * axis[i].m_x, m_rectProj * axis[i].m_y);
405 rect2ProjPts[i][j] = wxPoint2DDouble(rectProj * axis[i].m_x, rectProj * axis[i].m_y);
406 }
407 }
408
409 // Calculate the scalar value to identify the max and min values on projections
410 double rect1Scalar[4][4]; //[axis][corner]
411 double rect2Scalar[4][4]; //[axis][corner]
412 for (int i = 0; i < 4; i++) {
413 for (int j = 0; j < 4; j++) {
414 rect1Scalar[i][j] = rect1ProjPts[i][j].m_x * axis[i].m_x + rect1ProjPts[i][j].m_y * axis[i].m_y;
415 rect2Scalar[i][j] = rect2ProjPts[i][j].m_x * axis[i].m_x + rect2ProjPts[i][j].m_y * axis[i].m_y;
416 }
417 }
418 // Identify the max and min scalar values
419 double rect1Min[4];
420 double rect1Max[4];
421 double rect2Min[4];
422 double rect2Max[4];
423
424 for (int i = 0; i < 4; i++) {
425 rect1Max[i] = rect1Scalar[i][0];
426 rect2Max[i] = rect2Scalar[i][0];
427 rect1Min[i] = rect1Scalar[i][0];
428 rect2Min[i] = rect2Scalar[i][0];
429
430 for (int j = 1; j < 4; j++) {
431 if (rect1Max[i] < rect1Scalar[i][j]) rect1Max[i] = rect1Scalar[i][j];
432 if (rect2Max[i] < rect2Scalar[i][j]) rect2Max[i] = rect2Scalar[i][j];
433
434 if (rect1Min[i] > rect1Scalar[i][j]) rect1Min[i] = rect1Scalar[i][j];
435 if (rect2Min[i] > rect2Scalar[i][j]) rect2Min[i] = rect2Scalar[i][j];
436 }
437 }
438
439 // Check if any segment don't overlap
440 for (int i = 0; i < 4; i++) {
441 if (!(rect2Min[i] <= rect1Max[i] && rect2Max[i] >= rect1Min[i])) return false;
442 }
443
444 return true;
445}
Here is the caller graph for this function:

◆ RotateLocal()

wxPoint2DDouble Element::RotateLocal ( wxPoint2DDouble  local,
double  angleDeg 
) const
virtual

Definition at line 302 of file Element.cpp.

303{
304 double rad = wxDegToRad(angleDeg);
305 double c = std::cos(rad);
306 double s = std::sin(rad);
307
308 return wxPoint2DDouble(
309 c * local.m_x - s * local.m_y,
310 s * local.m_x + c * local.m_y
311 );
312}

◆ RotateNode()

virtual void Element::RotateNode ( Element parent,
bool  clockwise = true 
)
inlinevirtual

Rotate a node.

Parameters
parentNode's parent.
clockwiseTrue to rotate clockwise, false to rotate counter-clockwise.

Reimplemented in Transformer, Branch, Line, Machines, and Shunt.

Definition at line 384 of file Element.h.

384{}

◆ SaveCADProperties()

void Element::SaveCADProperties ( rapidxml::xml_document<> &  doc,
rapidxml::xml_node<> *  elementNode 
)

Definition at line 638 of file Element.cpp.

639{
640 auto cadProp = XMLParser::AppendNode(doc, elementNode, "CADProperties");
641 auto position = XMLParser::AppendNode(doc, cadProp, "Position");
642 auto posX = XMLParser::AppendNode(doc, position, "X");
643 XMLParser::SetNodeValue(doc, posX, m_position.m_x);
644 auto posY = XMLParser::AppendNode(doc, position, "Y");
645 XMLParser::SetNodeValue(doc, posY, m_position.m_y);
646 auto size = XMLParser::AppendNode(doc, cadProp, "Size");
647 auto width = XMLParser::AppendNode(doc, size, "Width");
648 XMLParser::SetNodeValue(doc, width, m_width);
649 auto height = XMLParser::AppendNode(doc, size, "Height");
650 XMLParser::SetNodeValue(doc, height, m_height);
651 auto angle = XMLParser::AppendNode(doc, cadProp, "Angle");
652 XMLParser::SetNodeValue(doc, angle, m_angle);
653}

◆ SaveElement()

virtual rapidxml::xml_node * Element::SaveElement ( rapidxml::xml_document<> &  doc,
rapidxml::xml_node<> *  elementListNode 
)
inlinevirtual

Definition at line 633 of file Element.h.

633{ return nullptr; }

◆ SetAngle()

void Element::SetAngle ( double  angle)
inline

Set element angle.

Parameters
angleAngle value in degrees.

Definition at line 154 of file Element.h.

154{ m_angle = angle; }

◆ SetBorderSize()

void Element::SetBorderSize ( double  borderSize)
inline

Set the size of the border (shown in selected elements).

Parameters
borderSizeBorder size.

Definition at line 164 of file Element.h.

164{ m_borderSize = borderSize; }

◆ SetChild()

void Element::SetChild ( Element child,
int  num 
)
inline

Definition at line 359 of file Element.h.

359{ m_childList[num] = child; }

◆ SetDragging()

void Element::SetDragging ( bool  dragging = true)
inline

Set if the element are being dragged.

Parameters
draggingTrue if is dragging, false otherwise.

Definition at line 128 of file Element.h.

128{ m_dragging = dragging; }

◆ SetHeight()

void Element::SetHeight ( double  height)
inline

Set element height.

Parameters
heightHeight value.

Definition at line 133 of file Element.h.

133{ m_height = height; }

◆ SetID()

virtual void Element::SetID ( int  id)
inlinevirtual

Set the element ID.

Parameters
idElement ID.

Definition at line 266 of file Element.h.

266{ m_elementID = id; }

◆ SetInserted()

void Element::SetInserted ( bool  inserted = true)
inline

Set if the element is properly inserted in the workspace.

Parameters
insertedtrue if is inserted properly, false otherwise

Definition at line 631 of file Element.h.

631{ m_inserted = inserted; }
Here is the caller graph for this function:

◆ SetNodeParent()

virtual bool Element::SetNodeParent ( Element parent)
inlinevirtual

Set a perent to the node. If all conditions are met, a new parent are added to the element and the points related to the nodes will be calculated.

Parameters
parentNode parent.
Returns
True if was possible to set the parent.

Reimplemented in Branch, Line, Machines, Shunt, and Transformer.

Definition at line 366 of file Element.h.

366{ return false; }

◆ SetOnline()

bool Element::SetOnline ( bool  online = true)

Set if the element is online or offline.

Parameters
onlineTrue if online, false if offline.

Definition at line 447 of file Element.cpp.

448{
449 // Check if any parent is null.
450 for (auto it = m_parentList.begin(); it != m_parentList.end(); it++) {
451 if (!(*it)) return false;
452 }
453 m_online = online;
454 return true;
455}

◆ SetParent()

void Element::SetParent ( Element parent,
int  num 
)
inline

Definition at line 358 of file Element.h.

358{ m_parentList[num] = parent; }

◆ SetPointList()

virtual void Element::SetPointList ( std::vector< wxPoint2DDouble >  pointList)
inlinevirtual

Set the list of points that connect the element to the bus.

Parameters
pointListList of points.

Reimplemented in Line.

Definition at line 175 of file Element.h.

175{ m_pointList = pointList; }

◆ SetPosition()

void Element::SetPosition ( const wxPoint2DDouble  position)

Set the element position and update the rectangle.

Parameters
positionPosition value.

Definition at line 27 of file Element.cpp.

28{
29 m_position = position;
30 m_rect =
31 wxRect2DDouble(m_position.m_x - m_width / 2.0 - m_borderSize, m_position.m_y - m_height / 2.0 - m_borderSize,
32 m_width + 2.0 * m_borderSize, m_height + 2.0 * m_borderSize);
33}
Here is the caller graph for this function:

◆ SetSelected()

void Element::SetSelected ( bool  selected = true)
inline

Set element selection.

Parameters
selectedTrue if selected, false otherwise.

Definition at line 144 of file Element.h.

144{ m_selected = selected; }

◆ SetWidth()

void Element::SetWidth ( double  width)
inline

Set element width.

Parameters
widthWidth value.

Definition at line 149 of file Element.h.

149{ m_width = width; }

◆ ShowForm()

virtual bool Element::ShowForm ( wxWindow *  parent,
Element element 
)
inlinevirtual

Show element data form.

Parameters
parentForm parent
elementElement that will be edited.
Returns
True if the form is shown, false otherwise.

Reimplemented in Constant, Exponential, Gain, IOControl, Limiter, MathExpression, MathOperation, RateLimiter, Sum, TransferFunction, Bus, Capacitor, EMTElement, HarmCurrent, IndMotor, Inductor, Line, Load, SyncGenerator, SyncMotor, and Transformer.

Definition at line 587 of file Element.h.

587{ return false; }

◆ ShowPickbox()

void Element::ShowPickbox ( bool  showPickbox = true)
inline

Set if the pickbox is shown.

Parameters
showPickboxTrue if show, false otherwise.

Definition at line 159 of file Element.h.

159{ m_showPickbox = showPickbox; }

◆ StartMove()

void Element::StartMove ( wxPoint2DDouble  position)
virtual

Update the element attributes related to the movement.

Parameters
positionStart move position.

Reimplemented in ConnectionLine, ControlElement, Branch, Line, Machines, Shunt, and Transformer.

Definition at line 329 of file Element.cpp.

330{
331 this->m_moveStartPt = position;
332 this->m_movePos = m_position;
333}

◆ StringFromDouble()

wxString Element::StringFromDouble ( double  value,
int  minDecimal = 1,
int  maxDecimals = 13 
)
static

Convert a double value to string.

Parameters
valueValue to be converted.
minDecimalMinimum number of decimal places.

Definition at line 533 of file Element.cpp.

534{
535 wxString str = wxString::FromCDouble(value, maxDecimals);
536 int cutNumber = 0;
537 int numDecimal = 0;
538 bool foundCut = false;
539 for (int i = (int)str.length() - 1; i >= 0; i--) {
540 if (str[i] != '0' && !foundCut) {
541 cutNumber = i;
542 foundCut = true;
543 }
544 if (str[i] == '.') {
545 numDecimal = i;
546 break;
547 }
548 }
549
550 wxString formatedStr = "";
551 if (cutNumber - numDecimal > minDecimal)
552 formatedStr = wxString::FromDouble(value, cutNumber - numDecimal);
553 else
554 formatedStr = wxString::FromDouble(value, minDecimal);
555
556 return formatedStr;
557}
Here is the caller graph for this function:

◆ UpdateNodes()

virtual void Element::UpdateNodes ( )
inlinevirtual

Update the nodes according to the parents. If a parent is removed, use this method.

Reimplemented in Branch, Machines, and Shunt.

Definition at line 356 of file Element.h.

356{}

◆ WorldToScreen() [1/2]

wxPoint2DDouble Element::WorldToScreen ( wxPoint2DDouble  position,
wxPoint2DDouble  translation,
double  scale,
double  offsetX = 0.0,
double  offsetY = 0.0 
) const
virtual

Convert a generic position to screen position.

Parameters
positionPosition to be converted.
translationSystem translation.
scaleSystem scale.
offsetXOffset in X axis.
offsetYOffset in Y axis.

Definition at line 342 of file Element.cpp.

347{
348 return wxPoint2DDouble(position.m_x + offsetX + translation.m_x, position.m_y + offsetY + translation.m_y) * scale;
349}

◆ WorldToScreen() [2/2]

wxPoint2DDouble Element::WorldToScreen ( wxPoint2DDouble  translation,
double  scale,
double  offsetX = 0.0,
double  offsetY = 0.0 
) const
virtual

Convert the element position to screen position.

Parameters
translationSystem translation.
scaleSystem scale
offsetXOffset in X axis.
offsetYOffset if Y axis.

Definition at line 336 of file Element.cpp.

337{
338 return wxPoint2DDouble(m_position.m_x + offsetX + translation.m_x, m_position.m_y + offsetY + translation.m_y) *
339 scale;
340}
Here is the caller graph for this function:

Member Data Documentation

◆ m_activeNodeID

int Element::m_activeNodeID = 0
protected

Definition at line 661 of file Element.h.

◆ m_activePickboxID

int Element::m_activePickboxID = ID_PB_NONE
protected

Definition at line 660 of file Element.h.

◆ m_angle

double Element::m_angle = 0.0
protected

Definition at line 648 of file Element.h.

◆ m_borderSize

double Element::m_borderSize = 2.0
protected

Definition at line 649 of file Element.h.

◆ m_childList

std::vector<Element*> Element::m_childList
protected

Definition at line 642 of file Element.h.

◆ m_dragging

bool Element::m_dragging = false
protected

Definition at line 656 of file Element.h.

◆ m_elementID

int Element::m_elementID = 0
protected

Definition at line 640 of file Element.h.

◆ m_elementType

ElementType Element::m_elementType = ElementType::TYPE_NONE
protected

Definition at line 639 of file Element.h.

◆ m_height

double Element::m_height = 0.0
protected

Definition at line 647 of file Element.h.

◆ m_inserted

bool Element::m_inserted = false
protected

Definition at line 658 of file Element.h.

◆ m_movePos

wxPoint2DDouble Element::m_movePos
protected

Definition at line 667 of file Element.h.

◆ m_movePts

std::vector<wxPoint2DDouble> Element::m_movePts
protected

Definition at line 664 of file Element.h.

◆ m_moveStartPt

wxPoint2DDouble Element::m_moveStartPt
protected

Definition at line 666 of file Element.h.

◆ m_online

bool Element::m_online = true
protected

Definition at line 669 of file Element.h.

◆ m_parentList

std::vector<Element*> Element::m_parentList
protected

Definition at line 641 of file Element.h.

◆ m_pointList

std::vector<wxPoint2DDouble> Element::m_pointList
protected

Definition at line 663 of file Element.h.

◆ m_position

wxPoint2DDouble Element::m_position
protected

Definition at line 645 of file Element.h.

◆ m_rect

wxRect2DDouble Element::m_rect
protected

Definition at line 644 of file Element.h.

◆ m_rotationAngle

double Element::m_rotationAngle = 45.0
protected

Definition at line 650 of file Element.h.

◆ m_selected

bool Element::m_selected = false
protected

Definition at line 655 of file Element.h.

◆ m_selectionColour

wxColour Element::m_selectionColour
protected

Definition at line 672 of file Element.h.

◆ m_showPickbox

bool Element::m_showPickbox = false
protected

Definition at line 657 of file Element.h.

◆ m_switchRect

std::vector<wxRect2DDouble> Element::m_switchRect
protected

Definition at line 653 of file Element.h.

◆ m_switchSize

double Element::m_switchSize = 10.0
protected

Definition at line 651 of file Element.h.

◆ m_width

double Element::m_width = 0.0
protected

Definition at line 646 of file Element.h.


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