Power System Platform  2026w11a-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 27 of file Element.cpp.

27{ 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 494 of file Element.cpp.

494{ 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 406 of file Element.cpp.

407{
408 // Check rect corners boundaries.
409
410 // Get rectangle corners
411 wxPoint2DDouble rectCorner[4] = { m_rect.GetLeftTop(), m_rect.GetLeftBottom(), m_rect.GetRightBottom(),
412 m_rect.GetRightTop() };
413 // Rotate corners.
414 for (int i = 0; i < 4; ++i) { rectCorner[i] = RotateAtPosition(rectCorner[i], m_angle); }
415 leftUp = rectCorner[0];
416 rightBottom = rectCorner[0];
417 for (int i = 1; i < 4; ++i) {
418 if (rectCorner[i].m_x < leftUp.m_x) leftUp.m_x = rectCorner[i].m_x;
419 if (rectCorner[i].m_y < leftUp.m_y) leftUp.m_y = rectCorner[i].m_y;
420 if (rectCorner[i].m_x > rightBottom.m_x) rightBottom.m_x = rectCorner[i].m_x;
421 if (rectCorner[i].m_y > rightBottom.m_y) rightBottom.m_y = rectCorner[i].m_y;
422 }
423
424 // Check points list boundaries.
425 for (int i = 0; i < (int)m_pointList.size(); i++) {
426 if (m_pointList[i].m_x < leftUp.m_x) leftUp.m_x = m_pointList[i].m_x;
427 if (m_pointList[i].m_y < leftUp.m_y) leftUp.m_y = m_pointList[i].m_y;
428 if (m_pointList[i].m_x > rightBottom.m_x) rightBottom.m_x = m_pointList[i].m_x;
429 if (m_pointList[i].m_y > rightBottom.m_y) rightBottom.m_y = m_pointList[i].m_y;
430 }
431}
virtual wxPoint2DDouble RotateAtPosition(wxPoint2DDouble pointToRotate, double angle, bool degrees=true) const
Rotate a point as element position being the origin.
Definition Element.cpp:223
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 433 of file Element.cpp.

434{
435 double dValue = 0.0;
436
437 if (!strValue.ToDouble(&dValue)) {
438 wxMessageDialog msgDialog(parent, errorMsg, _("Error"), wxOK | wxCENTRE | wxICON_ERROR);
439 msgDialog.ShowModal();
440 return false;
441 }
442
443 value = dValue;
444 return true;
445}

◆ 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 185 of file Element.cpp.

186{
187 double initAngRad = wxDegToRad(initAngle);
188 double finalAngRad = wxDegToRad(finalAngle);
189 wxPoint2DDouble* points = new wxPoint2DDouble[numSegments + 2];
190 for (int i = 0; i <= numSegments; i++) {
191 double theta = initAngRad + (finalAngRad - initAngRad) * double(i) / double(numSegments);
192 points[i] = wxPoint2DDouble(radius * std::cos(theta) + position.m_x, radius * std::sin(theta) + position.m_y);
193 }
194
195 gc->StrokeLines(numSegments + 1, points);
196 delete[] points;
197}

◆ DrawDCArc() [2/2]

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

Definition at line 199 of file Element.cpp.

200{
201 dc.DrawEllipticArc(wxRound(position.m_x - radius), wxRound(position.m_y - radius), wxRound(2 * radius), wxRound(2 * radius), initAngle, finalAngle);
202}

◆ 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 168 of file Element.cpp.

169{
170 wxPoint2DDouble* pts = new wxPoint2DDouble[numSegments + 1];
171 for (int i = 0; i < numSegments; i++) {
172 double theta = 2.0 * 3.1415926 * double(i) / double(numSegments);
173 pts[i] = wxPoint2DDouble(radius * std::cos(theta) + position.m_x, radius * std::sin(theta) + position.m_y);
174 }
175 pts[numSegments] = pts[0];
176 gc->DrawLines(numSegments + 1, pts);
177 delete[] pts;
178}
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 180 of file Element.cpp.

181{
182 dc.DrawCircle(wxRound(position.m_x), wxRound(position.m_y), wxRound(radius));
183}

◆ 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 216 of file Element.cpp.

217{
218 gc->SetPen(wxPen(wxColour(0, 0, 0, 255)));
219 gc->SetBrush(wxBrush(wxColour(255, 255, 255, 204)));
220 gc->DrawRectangle(position.m_x, position.m_y, 8, 8);
221}
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 36 of file Element.cpp.

37{
38 if (angle == 0.0) {
39 wxPoint poly[4] = {
40 wxPoint((int)(position.m_x - width / 2.0), (int)(position.m_y - height / 2.0)),
41 wxPoint((int)(position.m_x + width / 2.0), (int)(position.m_y - height / 2.0)),
42 wxPoint((int)(position.m_x + width / 2.0), (int)(position.m_y + height / 2.0)),
43 wxPoint((int)(position.m_x - width / 2.0), (int)(position.m_y + height / 2.0))
44 };
45 dc.DrawPolygon(4, poly);
46 return;
47 }
48
49 double hw = width / 2.0;
50 double hh = height / 2.0;
51 double angleRad = wxDegToRad(angle);
52
53 // Retângulo centrado na origem
54 wxPoint2DDouble pts[4] = {
55 {-hw, -hh},
56 { hw, -hh},
57 { hw, hh},
58 {-hw, hh}
59 };
60
61 wxPoint poly[4];
62
63 for (int i = 0; i < 4; ++i)
64 {
65 double x = pts[i].m_x;
66 double y = pts[i].m_y;
67
68 // Rotação
69 double xr = x * cos(angleRad) - y * sin(angleRad);
70 double yr = x * sin(angleRad) + y * cos(angleRad);
71
72 // Translação para centro
73 poly[i].x = (int)(xr + position.m_x);
74 poly[i].y = (int)(yr + position.m_y);
75 }
76
77 dc.DrawPolygon(4, poly);
78
79}
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 81 of file Element.cpp.

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

◆ DrawDCTriangle() [1/2]

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

Definition at line 210 of file Element.cpp.

211{
212 points.emplace_back(points[0]);
213 dc.DrawPolygon(4, &points[0]);
214}

◆ 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 204 of file Element.cpp.

205{
206 points.emplace_back(points[0]);
207 gc->DrawLines(4, &points[0]);
208}
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 388 of file Element.cpp.

389{
390 wxFileName exeFileName(wxStandardPaths::Get().GetExecutablePath());
391 //wxString exePath = exeFileName.GetPath();
392
393 wxMenuItem* clockItem = new wxMenuItem(&menu, ID_ROTATE_CLOCK, _("Rotate clockwise"));
394 clockItem->SetBitmap(wxImage(Paths::GetDataPath() + "/images/menu/rotateClock16.png"));
395 menu.Append(clockItem);
396
397 wxMenuItem* counterClockItem = new wxMenuItem(&menu, ID_ROTATE_COUNTERCLOCK, _("Rotate counter-clockwise"));
398 counterClockItem->SetBitmap(wxImage(Paths::GetDataPath() + "/images/menu/rotateCounterClock16.png"));
399 menu.Append(counterClockItem);
400
401 wxMenuItem* deleteItem = new wxMenuItem(&menu, ID_DELETE, _("Delete"));
402 deleteItem->SetBitmap(wxImage(Paths::GetDataPath() + "/images/menu/delete16.png"));
403 menu.Append(deleteItem);
404}
@ 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 447 of file Element.cpp.

448{
449 long int iValue = 0;
450
451 if (!strValue.ToLong(&iValue)) {
452 wxMessageDialog msgDialog(parent, errorMsg, _("Error"), wxOK | wxCENTRE | wxICON_ERROR);
453 msgDialog.ShowModal();
454 return false;
455 }
456
457 value = iValue;
458 return true;
459}

◆ 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 266 of file Element.cpp.

266{ SetPosition(m_movePos + position - m_moveStartPt); }
void SetPosition(const wxPoint2DDouble position)
Set the element position and update the rectangle.
Definition Element.cpp:28
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 583 of file Element.cpp.

584{
585 auto cadPropNode = elementNode->first_node("CADProperties");
586 if (!cadPropNode) return false;
587
588 auto position = cadPropNode->first_node("Position");
589 double posX = XMLParser::GetNodeValueDouble(position, "X");
590 double posY = XMLParser::GetNodeValueDouble(position, "Y");
591 auto size = cadPropNode->first_node("Size");
592 m_width = XMLParser::GetNodeValueDouble(size, "Width");
593 m_height = XMLParser::GetNodeValueDouble(size, "Height");
594 m_angle = XMLParser::GetNodeValueDouble(cadPropNode, "Angle");
595 SetPosition(wxPoint2DDouble(posX, posY));
596 return true;
597}

◆ 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 529 of file Element.cpp.

530{
531 //[Ref] http://geomalgorithms.com/a02-_lines.html
532 double distance = 100.0; // Big initial distance.
533 wxPoint2DDouble p0 = point;
534
535 for (int i = 1; i < (int)m_pointList.size() - 2; i++) {
536 double d = 0.0;
537
538 wxPoint2DDouble p1 = m_pointList[i];
539 wxPoint2DDouble p2 = m_pointList[i + 1];
540
541 wxPoint2DDouble v = p2 - p1;
542 wxPoint2DDouble w = p0 - p1;
543
544 double c1 = w.m_x * v.m_x + w.m_y * v.m_y;
545 double c2 = v.m_x * v.m_x + v.m_y * v.m_y;
546
547 if (c1 <= 0.0) {
548 d = std::sqrt(std::pow(p0.m_y - p1.m_y, 2) + std::pow(p0.m_x - p1.m_x, 2));
549 }
550 else if (c2 <= c1) {
551 d = std::sqrt(std::pow(p0.m_y - p2.m_y, 2) + std::pow(p0.m_x - p2.m_x, 2));
552 }
553 else {
554 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) /
555 std::sqrt(std::pow(p2.m_y - p1.m_y, 2) + std::pow(p2.m_x - p1.m_x, 2));
556 }
557 if (d < distance) {
558 distance = d;
559 if (segmentNumber) *segmentNumber = i;
560 }
561 }
562
563 return distance;
564}
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 495 of file Element.cpp.

496{
497 for (auto it = m_childList.begin(); it != m_childList.end();) {
498 if (*it == child) it = m_childList.erase(it);
499 else ++it;
500 }
501}

◆ 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 503 of file Element.cpp.

504{
505 for (int i = 0; i < (int)m_childList.size(); i++) {
506 if (m_childList[i] == oldChild) m_childList[i] = newChild;
507 }
508}

◆ ReplaceParent()

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

Replace a parent.

Parameters
oldParentParent to be replaced.
newParentNew parent.

Definition at line 487 of file Element.cpp.

488{
489 for (int i = 0; i < (int)m_parentList.size(); i++) {
490 if (m_parentList[i] == oldParent) m_parentList[i] = newParent;
491 }
492}

◆ 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 245 of file Element.cpp.

246{
247 double rad = wxDegToRad(angleDeg);
248 double c = std::cos(rad);
249 double s = std::sin(rad);
250
251 double dx = p.m_x - center.m_x;
252 double dy = p.m_y - center.m_y;
253
254 double xr = c * dx - s * dy + center.m_x;
255 double yr = s * dx + c * dy + center.m_y;
256
257 return wxPoint(wxRound(xr), wxRound(yr));
258}

◆ 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 223 of file Element.cpp.

224{
225 double radAngle = angle;
226 if (degrees) radAngle = wxDegToRad(angle);
227 return wxPoint2DDouble(std::cos(radAngle) * (pointToRotate.m_x - m_position.m_x) -
228 std::sin(radAngle) * (pointToRotate.m_y - m_position.m_y) + m_position.m_x,
229 std::sin(radAngle) * (pointToRotate.m_x - m_position.m_x) +
230 std::cos(radAngle) * (pointToRotate.m_y - m_position.m_y) + m_position.m_y);
231}
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 290 of file Element.cpp.

294{
295 wxPoint2DDouble rect1Corners[4] = { rect1.GetLeftTop(), rect1.GetLeftBottom(), rect1.GetRightBottom(),
296 rect1.GetRightTop() };
297 wxPoint2DDouble rect2Corners[4] = { rect2.GetLeftTop(), rect2.GetLeftBottom(), rect2.GetRightBottom(),
298 rect2.GetRightTop() };
299 wxPoint2DDouble rect1Center(rect1.m_x + rect1.m_width / 2.0, rect1.m_y + rect1.m_height / 2.0);
300 wxPoint2DDouble rect2Center(rect2.m_x + rect2.m_width / 2.0, rect2.m_y + rect2.m_height / 2.0);
301
302 // Rotate the corners.
303 double radAngle1 = wxDegToRad(angle1);
304 double radAngle2 = wxDegToRad(angle2);
305
306 for (int i = 0; i < 4; i++) {
307 rect1Corners[i] =
308 wxPoint2DDouble(std::cos(radAngle1) * (rect1Corners[i].m_x - rect1Center.m_x) -
309 std::sin(radAngle1) * (rect1Corners[i].m_y - rect1Center.m_y) + rect1Center.m_x,
310 std::sin(radAngle1) * (rect1Corners[i].m_x - rect1Center.m_x) +
311 std::cos(radAngle1) * (rect1Corners[i].m_y - rect1Center.m_y) + rect1Center.m_y);
312
313 rect2Corners[i] =
314 wxPoint2DDouble(std::cos(radAngle2) * (rect2Corners[i].m_x - rect2Center.m_x) -
315 std::sin(radAngle2) * (rect2Corners[i].m_y - rect2Center.m_y) + rect2Center.m_x,
316 std::sin(radAngle2) * (rect2Corners[i].m_x - rect2Center.m_x) +
317 std::cos(radAngle2) * (rect2Corners[i].m_y - rect2Center.m_y) + rect2Center.m_y);
318 }
319
320 //[Ref] http://www.gamedev.net/page/resources/_/technical/game-programming/2d-rotated-rectangle-collision-r2604
321
322 // Find the rectangles axis to project
323 wxPoint2DDouble axis[4] = { rect1Corners[3] - rect1Corners[0], rect1Corners[3] - rect1Corners[2],
324 rect2Corners[3] - rect2Corners[0], rect2Corners[3] - rect2Corners[2] };
325
326 // Calculate the projected points to each axis
327 wxPoint2DDouble rect1ProjPts[4][4]; // [axis][corner]
328 wxPoint2DDouble rect2ProjPts[4][4]; // [axis][corner]
329 for (int i = 0; i < 4; i++) {
330 double den = axis[i].m_x * axis[i].m_x + axis[i].m_y * axis[i].m_y;
331 for (int j = 0; j < 4; j++) {
332 double m_rectProj = (rect1Corners[j].m_x * axis[i].m_x + rect1Corners[j].m_y * axis[i].m_y) / den;
333 double rectProj = (rect2Corners[j].m_x * axis[i].m_x + rect2Corners[j].m_y * axis[i].m_y) / den;
334
335 rect1ProjPts[i][j] = wxPoint2DDouble(m_rectProj * axis[i].m_x, m_rectProj * axis[i].m_y);
336 rect2ProjPts[i][j] = wxPoint2DDouble(rectProj * axis[i].m_x, rectProj * axis[i].m_y);
337 }
338 }
339
340 // Calculate the scalar value to identify the max and min values on projections
341 double rect1Scalar[4][4]; //[axis][corner]
342 double rect2Scalar[4][4]; //[axis][corner]
343 for (int i = 0; i < 4; i++) {
344 for (int j = 0; j < 4; j++) {
345 rect1Scalar[i][j] = rect1ProjPts[i][j].m_x * axis[i].m_x + rect1ProjPts[i][j].m_y * axis[i].m_y;
346 rect2Scalar[i][j] = rect2ProjPts[i][j].m_x * axis[i].m_x + rect2ProjPts[i][j].m_y * axis[i].m_y;
347 }
348 }
349 // Identify the max and min scalar values
350 double rect1Min[4];
351 double rect1Max[4];
352 double rect2Min[4];
353 double rect2Max[4];
354
355 for (int i = 0; i < 4; i++) {
356 rect1Max[i] = rect1Scalar[i][0];
357 rect2Max[i] = rect2Scalar[i][0];
358 rect1Min[i] = rect1Scalar[i][0];
359 rect2Min[i] = rect2Scalar[i][0];
360
361 for (int j = 1; j < 4; j++) {
362 if (rect1Max[i] < rect1Scalar[i][j]) rect1Max[i] = rect1Scalar[i][j];
363 if (rect2Max[i] < rect2Scalar[i][j]) rect2Max[i] = rect2Scalar[i][j];
364
365 if (rect1Min[i] > rect1Scalar[i][j]) rect1Min[i] = rect1Scalar[i][j];
366 if (rect2Min[i] > rect2Scalar[i][j]) rect2Min[i] = rect2Scalar[i][j];
367 }
368 }
369
370 // Check if any segment don't overlap
371 for (int i = 0; i < 4; i++) {
372 if (!(rect2Min[i] <= rect1Max[i] && rect2Max[i] >= rect1Min[i])) return false;
373 }
374
375 return true;
376}
Here is the caller graph for this function:

◆ RotateLocal()

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

Definition at line 233 of file Element.cpp.

234{
235 double rad = wxDegToRad(angleDeg);
236 double c = std::cos(rad);
237 double s = std::sin(rad);
238
239 return wxPoint2DDouble(
240 c * local.m_x - s * local.m_y,
241 s * local.m_x + c * local.m_y
242 );
243}

◆ 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 566 of file Element.cpp.

567{
568 auto cadProp = XMLParser::AppendNode(doc, elementNode, "CADProperties");
569 auto position = XMLParser::AppendNode(doc, cadProp, "Position");
570 auto posX = XMLParser::AppendNode(doc, position, "X");
571 XMLParser::SetNodeValue(doc, posX, m_position.m_x);
572 auto posY = XMLParser::AppendNode(doc, position, "Y");
573 XMLParser::SetNodeValue(doc, posY, m_position.m_y);
574 auto size = XMLParser::AppendNode(doc, cadProp, "Size");
575 auto width = XMLParser::AppendNode(doc, size, "Width");
576 XMLParser::SetNodeValue(doc, width, m_width);
577 auto height = XMLParser::AppendNode(doc, size, "Height");
578 XMLParser::SetNodeValue(doc, height, m_height);
579 auto angle = XMLParser::AppendNode(doc, cadProp, "Angle");
580 XMLParser::SetNodeValue(doc, angle, m_angle);
581}

◆ 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 378 of file Element.cpp.

379{
380 // Check if any parent is null.
381 for (auto it = m_parentList.begin(); it != m_parentList.end(); it++) {
382 if (!(*it)) return false;
383 }
384 m_online = online;
385 return true;
386}

◆ 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 28 of file Element.cpp.

29{
30 m_position = position;
31 m_rect =
32 wxRect2DDouble(m_position.m_x - m_width / 2.0 - m_borderSize, m_position.m_y - m_height / 2.0 - m_borderSize,
33 m_width + 2.0 * m_borderSize, m_height + 2.0 * m_borderSize);
34}
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 260 of file Element.cpp.

261{
262 this->m_moveStartPt = position;
263 this->m_movePos = m_position;
264}

◆ 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 461 of file Element.cpp.

462{
463 wxString str = wxString::FromCDouble(value, maxDecimals);
464 int cutNumber = 0;
465 int numDecimal = 0;
466 bool foundCut = false;
467 for (int i = (int)str.length() - 1; i >= 0; i--) {
468 if (str[i] != '0' && !foundCut) {
469 cutNumber = i;
470 foundCut = true;
471 }
472 if (str[i] == '.') {
473 numDecimal = i;
474 break;
475 }
476 }
477
478 wxString formatedStr = "";
479 if (cutNumber - numDecimal > minDecimal)
480 formatedStr = wxString::FromDouble(value, cutNumber - numDecimal);
481 else
482 formatedStr = wxString::FromDouble(value, minDecimal);
483
484 return formatedStr;
485}
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 273 of file Element.cpp.

278{
279 return wxPoint2DDouble(position.m_x + offsetX + translation.m_x, position.m_y + offsetY + translation.m_y) * scale;
280}

◆ 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 267 of file Element.cpp.

268{
269 return wxPoint2DDouble(m_position.m_x + offsetX + translation.m_x, m_position.m_y + offsetY + translation.m_y) *
270 scale;
271}
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: