Power System Platform  2026w10a-beta
Loading...
Searching...
No Matches
PowerElement Class Reference

Abstract class of power elements. More...

#include <PowerElement.h>

Inheritance diagram for PowerElement:
Collaboration diagram for PowerElement:

Public Member Functions

 PowerElement ()
 Constructor.
 
virtual ~PowerElement ()
 Destructor.
 
virtual wxPoint2DDouble GetSwitchPoint (Element *parent, wxPoint2DDouble parentPoint, wxPoint2DDouble secondPoint) const
 Get the correct switch position.
 
virtual bool SwitchesContains (wxPoint2DDouble position) const
 Check if switch contains position.
 
virtual void UpdateSwitches ()
 Update the switch position.
 
virtual void DrawDCSwitches (wxGraphicsContext *gc) const
 Draw switch.
 
virtual void DrawDCSwitches (wxDC &dc) const
 
virtual void CalculatePowerFlowPts (std::vector< wxPoint2DDouble > edges)
 Calculate the points of the power flow arrows.
 
virtual void DrawDCPowerFlowPts (wxGraphicsContext *gc) const
 Draw power flow arrows.
 
virtual void DrawDCPowerFlowPts (wxDC &dc) const
 
virtual void SetNominalVoltage (std::vector< double > nominalVoltage, std::vector< ElectricalUnit > nominalVoltageUnit)
 Set nominal voltage of the element.
 
virtual void SetSwitchingData (SwitchingData data)
 Set the switching data of the element.
 
virtual SwitchingData GetSwitchingData ()
 Returns the switching data of the element.
 
virtual void SetPowerFlowDirection (PowerFlowDirection pfDirection)
 Set the direction of the power flow.
 
virtual PowerFlowDirection GetPowerFlowDirection () const
 Return the direction of the power flow.
 
virtual bool GetPlotData (ElementPlotData &plotData, PlotStudy study=PlotStudy::STABILITY)
 Fill the plot data.
 
virtual bool HaveDynamicEvent () const
 Check if the power element have dynamic event.
 
virtual void SetDynamicEvent (bool dynEvent=true)
 Set if the power element have dynamic event.
 
virtual double GetValueFromUnit (double value, ElectricalUnit valueUnit)
 
virtual void SaveCADProperties (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *elementNode)
 
virtual void SaveSwitchingData (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *electricalNode)
 
virtual bool OpenElement (rapidxml::xml_node<> *elementNode, std::vector< Element * > parentList)
 
virtual bool OpenCADProperties (rapidxml::xml_node<> *elementNode, std::vector< Element * > parentList)
 
virtual bool OpenSwitchingData (rapidxml::xml_node<> *electricalNode)
 
- Public Member Functions inherited from Element
 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)
 

Protected Attributes

SwitchingData m_swData
 
std::vector< std::vector< wxPoint2DDouble > > m_powerFlowArrow
 
PowerFlowDirection m_pfDirection = PowerFlowDirection::PF_NONE
 
wxColour m_busColour
 
wxColour m_onlineElementColour
 
wxColour m_offlineElementColour
 
wxColour m_closedSwitchColour
 
wxColour m_openedSwitchColour
 
wxColour m_powerFlowArrowColour
 
wxColour m_dynamicEventColour
 
bool m_dynEvent = false
 
- Protected Attributes inherited from Element
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
 

Additional Inherited Members

- Static Public Member Functions inherited from Element
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.
 

Detailed Description

Abstract class of power elements.

Author
Thales Lima Oliveira thale.nosp@m.s@uf.nosp@m.u.br
Date
18/01/2017

Definition at line 123 of file PowerElement.h.

Constructor & Destructor Documentation

◆ PowerElement()

PowerElement::PowerElement ( )

Constructor.

Definition at line 24 of file PowerElement.cpp.

24 : Element()
25{
26 m_busColour.Set(0, 78, 255, 255);
27 m_onlineElementColour.Set(51, 51, 51, 255);
28 m_offlineElementColour.Set(128, 128, 128, 255);
29 m_closedSwitchColour.Set(0, 102, 0, 255);
30 m_openedSwitchColour.Set(255, 26, 26, 255);
31 m_powerFlowArrowColour.Set(255, 130, 0, 255);
32 m_dynamicEventColour.Set(255, 130, 0, 255);
33}
Element()
Constructor.
Definition Element.cpp:26

◆ ~PowerElement()

virtual PowerElement::~PowerElement ( )
inlinevirtual

Destructor.

Definition at line 133 of file PowerElement.h.

133{}

Member Function Documentation

◆ CalculatePowerFlowPts()

void PowerElement::CalculatePowerFlowPts ( std::vector< wxPoint2DDouble >  edges)
virtual

Calculate the points of the power flow arrows.

Parameters
edgesPoints of the element that arrows point.

Definition at line 173 of file PowerElement.cpp.

174{
175 double arrowRate = 100.0; // One arrow to each "arrowRate" distance in pixels.
176
177 if(edges.size() < 2) return;
178
179 // Clear all power flow points
180 for(int i = 0; i < (int)m_powerFlowArrow.size(); i++) m_powerFlowArrow[i].clear();
181 m_powerFlowArrow.clear();
182
183 for(int i = 1; i < (int)edges.size(); i++) {
184 wxPoint2DDouble pt1 = edges[i - 1];
185 wxPoint2DDouble pt2 = edges[i];
186
187 double angle = std::atan2(pt2.m_y - pt1.m_y, pt2.m_x - pt1.m_x);
188
189 wxPoint2DDouble rotPt2(
190 std::cos(-angle) * (pt2.m_x - pt1.m_x) - std::sin(-angle) * (pt2.m_y - pt1.m_y) + pt1.m_x,
191 std::sin(-angle) * (pt2.m_x - pt1.m_x) + std::cos(-angle) * (pt2.m_y - pt1.m_y) + pt1.m_y);
192
193 int numArrows = std::abs(pt1.m_x - rotPt2.m_x) / arrowRate;
194 if(numArrows == 0) numArrows = 1;
195
196 for(int i = 0; i < numArrows; i++) {
197 wxPoint2DDouble arrowCenter(pt1.m_x + ((rotPt2.m_x - pt1.m_x) / double(numArrows + 1)) * double(i + 1),
198 pt1.m_y + ((rotPt2.m_y - pt1.m_y) / double(numArrows + 1)) * double(i + 1));
199
200 std::vector<wxPoint2DDouble> triPts;
201 triPts.push_back(arrowCenter + wxPoint2DDouble(5.0, 0.0));
202 triPts.push_back(arrowCenter + wxPoint2DDouble(-5.0, 5.0));
203 triPts.push_back(arrowCenter + wxPoint2DDouble(-5.0, -5.0));
204
205 // Rotate back.
206 for(int i = 0; i < 3; i++) {
207 triPts[i] = wxPoint2DDouble(
208 std::cos(angle) * (triPts[i].m_x - pt1.m_x) - std::sin(angle) * (triPts[i].m_y - pt1.m_y) + pt1.m_x,
209 std::sin(angle) * (triPts[i].m_x - pt1.m_x) + std::cos(angle) * (triPts[i].m_y - pt1.m_y) +
210 pt1.m_y);
211 }
212 m_powerFlowArrow.push_back(triPts);
213 }
214 }
215}

◆ DrawDCPowerFlowPts() [1/2]

void PowerElement::DrawDCPowerFlowPts ( wxDC &  dc) const
virtual

Definition at line 234 of file PowerElement.cpp.

235{
236 dc.SetPen(*wxTRANSPARENT_PEN);
237 if (m_online) {
238 dc.SetBrush(wxBrush(m_powerFlowArrowColour));
239 for (auto arrow : m_powerFlowArrow) {
240 std::vector<wxPoint> arrowPts;
241 for (auto& pt : arrow) {
242 arrowPts.emplace_back(static_cast<int>(pt.m_x), static_cast<int>(pt.m_y));
243 }
244 DrawDCTriangle(arrowPts, dc);
245 }
246 }
247}
virtual void DrawDCTriangle(std::vector< wxPoint2DDouble > points, wxGraphicsContext *gc) const
Draw rectangle.
Definition Element.cpp:237

◆ DrawDCPowerFlowPts() [2/2]

void PowerElement::DrawDCPowerFlowPts ( wxGraphicsContext *  gc) const
virtual

Draw power flow arrows.

Draw power flow arrows using device context.

Parameters
gcDevice context.

Definition at line 225 of file PowerElement.cpp.

226{
227 gc->SetPen(*wxTRANSPARENT_PEN);
228 if (m_online) {
229 gc->SetBrush(wxBrush(m_powerFlowArrowColour));
230 for (auto arrow : m_powerFlowArrow) { DrawDCTriangle(arrow, gc); }
231 }
232}
Here is the call graph for this function:
Here is the caller graph for this function:

◆ DrawDCSwitches() [1/2]

void PowerElement::DrawDCSwitches ( wxDC &  dc) const
virtual

Definition at line 140 of file PowerElement.cpp.

141{
142 dc.SetPen(*wxTRANSPARENT_PEN);
143
144 int i = 0;
145 for (auto parent : m_parentList) {
146 if (parent) {
147 if (m_online) {
148 dc.SetBrush(wxBrush(m_closedSwitchColour));
149 }
150 else {
151 dc.SetBrush(wxBrush(m_openedSwitchColour));
152 }
153
154 //gc->PushState();
155 //gc->Translate(m_switchRect[i].GetPosition().m_x + m_switchSize / 2.0,
156 // m_switchRect[i].GetPosition().m_y + m_switchSize / 2.0);
157 //gc->Rotate(wxDegToRad(parent->GetAngle()));
158 //gc->Translate(-m_switchRect[i].GetPosition().m_x - m_switchSize / 2.0,
159 // -m_switchRect[i].GetPosition().m_y - m_switchSize / 2.0);
160 //
161 //wxPoint2DDouble switchPos = m_switchRect[i].GetPosition();
162 //gc->DrawRectangle(switchPos.m_x, switchPos.m_y, m_switchSize, m_switchSize);
163 //
164 //gc->PopState();
165
166 DrawDCRectangle(m_switchRect[i].GetPosition() + wxPoint2DDouble(m_switchSize / 2.0, m_switchSize / 2.0),
167 m_switchSize, m_switchSize, parent->GetAngle(), dc);
168 }
169 i++;
170 }
171}
wxPoint2DDouble GetPosition() const
Get the element position.
Definition Element.h:186
virtual void DrawDCRectangle(wxPoint2DDouble position, double width, double height, double angle, wxDC &dc) const
Draw a circle.
Definition Element.cpp:45

◆ DrawDCSwitches() [2/2]

void PowerElement::DrawDCSwitches ( wxGraphicsContext *  gc) const
virtual

Draw switch.

Draw switch using device context.

Definition at line 110 of file PowerElement.cpp.

111{
112 gc->SetPen(*wxTRANSPARENT_PEN);
113
114 int i = 0;
115 for (auto parent : m_parentList) {
116 if (parent) {
117 if (m_online) {
118 gc->SetBrush(wxBrush(m_closedSwitchColour));
119 }
120 else {
121 gc->SetBrush(wxBrush(m_openedSwitchColour));
122 }
123
124 gc->PushState();
125 gc->Translate(m_switchRect[i].GetPosition().m_x + m_switchSize / 2.0,
126 m_switchRect[i].GetPosition().m_y + m_switchSize / 2.0);
127 gc->Rotate(wxDegToRad(parent->GetAngle()));
128 gc->Translate(-m_switchRect[i].GetPosition().m_x - m_switchSize / 2.0,
129 -m_switchRect[i].GetPosition().m_y - m_switchSize / 2.0);
130
131 wxPoint2DDouble switchPos = m_switchRect[i].GetPosition();
132 gc->DrawRectangle(switchPos.m_x, switchPos.m_y, m_switchSize, m_switchSize);
133
134 gc->PopState();
135 }
136 i++;
137 }
138}
Here is the call graph for this function:
Here is the caller graph for this function:

◆ GetPlotData()

virtual bool PowerElement::GetPlotData ( ElementPlotData plotData,
PlotStudy  study = PlotStudy::STABILITY 
)
inlinevirtual

Fill the plot data.

Parameters
plotDataPlot data to be filled.
Returns
true if the plot data was successfully filled, false otherwise.

Reimplemented in Bus, IndMotor, Load, and SyncGenerator.

Definition at line 219 of file PowerElement.h.

219{ return false; }

◆ GetPowerFlowDirection()

virtual PowerFlowDirection PowerElement::GetPowerFlowDirection ( ) const
inlinevirtual

Return the direction of the power flow.

Returns
Power flow direction.

Definition at line 213 of file PowerElement.h.

213{ return m_pfDirection; }

◆ GetSwitchingData()

virtual SwitchingData PowerElement::GetSwitchingData ( )
inlinevirtual

Returns the switching data of the element.

Returns
Element switching data.

Definition at line 203 of file PowerElement.h.

203{ return m_swData; }

◆ GetSwitchPoint()

wxPoint2DDouble PowerElement::GetSwitchPoint ( Element parent,
wxPoint2DDouble  parentPoint,
wxPoint2DDouble  secondPoint 
) const
virtual

Get the correct switch position.

Parameters
parentBus with switch.
parentPointPosition of node on parent.
secondPointNext point in element.

Definition at line 39 of file PowerElement.cpp.

42{
43 double swLineSize = 25.0;
44 wxPoint2DDouble swPoint = wxPoint2DDouble(parentPoint.m_x, parentPoint.m_y - swLineSize);
45
46 // Rotate the second point (to compare).
47 double angle = parent->GetAngle();
48
49 secondPoint =
50 wxPoint2DDouble(std::cos(wxDegToRad(-angle)) * (secondPoint.m_x - parentPoint.m_x) -
51 std::sin(wxDegToRad(-angle)) * (secondPoint.m_y - parentPoint.m_y) + parentPoint.m_x,
52 std::sin(wxDegToRad(-angle)) * (secondPoint.m_x - parentPoint.m_x) +
53 std::cos(wxDegToRad(-angle)) * (secondPoint.m_y - parentPoint.m_y) + parentPoint.m_y);
54
55 // Rotate
56 if(secondPoint.m_y > parentPoint.m_y) angle -= 180.0;
57 return wxPoint2DDouble(std::cos(wxDegToRad(angle)) * (swPoint.m_x - parentPoint.m_x) -
58 std::sin(wxDegToRad(angle)) * (swPoint.m_y - parentPoint.m_y) + parentPoint.m_x,
59 std::sin(wxDegToRad(angle)) * (swPoint.m_x - parentPoint.m_x) +
60 std::cos(wxDegToRad(angle)) * (swPoint.m_y - parentPoint.m_y) + parentPoint.m_y);
61}
double GetAngle() const
Get the element angle.
Definition Element.h:211
Here is the call graph for this function:
Here is the caller graph for this function:

◆ GetValueFromUnit()

double PowerElement::GetValueFromUnit ( double  value,
ElectricalUnit  valueUnit 
)
virtual

Definition at line 249 of file PowerElement.cpp.

250{
251 switch(valueUnit) {
257 return value * 1e3;
258 } break;
262 return value * 1e6;
263 }
264 default:
265 break;
266 }
267 return value;
268}

◆ HaveDynamicEvent()

virtual bool PowerElement::HaveDynamicEvent ( ) const
inlinevirtual

Check if the power element have dynamic event.

Returns
true if the element have dynamic an event, false otherwise.

Definition at line 224 of file PowerElement.h.

224{ return m_dynEvent; }

◆ OpenCADProperties()

bool PowerElement::OpenCADProperties ( rapidxml::xml_node<> *  elementNode,
std::vector< Element * >  parentList 
)
virtual

Definition at line 270 of file PowerElement.cpp.

271{
272 auto cadPropNode = elementNode->first_node("CADProperties");
273 if(!cadPropNode) return false;
274
275 auto position = cadPropNode->first_node("Position");
276 double posX = XMLParser::GetNodeValueDouble(position, "X");
277 double posY = XMLParser::GetNodeValueDouble(position, "Y");
278 auto size = cadPropNode->first_node("Size");
279 m_width = XMLParser::GetNodeValueDouble(size, "Width");
280 m_height = XMLParser::GetNodeValueDouble(size, "Height");
281 double angle = XMLParser::GetNodeValueDouble(cadPropNode, "Angle");
282 SetPosition(wxPoint2DDouble(posX, posY));
283
284 auto nodePosition = cadPropNode->first_node("NodePosition");
285 double nodePosX = XMLParser::GetNodeValueDouble(nodePosition, "X");
286 double nodePosY = XMLParser::GetNodeValueDouble(nodePosition, "Y");
287
288 int parentID = XMLParser::GetNodeValueInt(cadPropNode, "ParentID");
289 // If the opened power element has no parent, set up the basics CAD properties of the element manually, otherwise
290 // just class method AddParent to calculate properly.
291 if(parentID == -1) {
292 m_parentList.push_back(nullptr);
293 m_pointList.push_back(wxPoint2DDouble(nodePosX, nodePosY));
294 m_pointList.push_back(wxPoint2DDouble(nodePosX, nodePosY));
295 m_pointList.push_back(m_position + wxPoint2DDouble(0.0, -m_height / 2.0 - 10.0));
296 m_pointList.push_back(m_position + wxPoint2DDouble(0.0, -m_height / 2.0));
297
298 wxRect2DDouble genRect(0, 0, 0, 0);
299 m_switchRect.push_back(genRect); // Push a general rectangle.
301
302 m_online = false; // Not connected elements are always offline.
303 } else {
304 AddParent(parentList[parentID], wxPoint2DDouble(nodePosX, nodePosY));
305 }
306
307 // Set up the points properly.
308 StartMove(m_position);
309 Move(wxPoint2DDouble(posX, posY));
310
311 // Set the rotation properly.
312 int numRot = angle / m_rotationAngle;
313 bool clockwise = true;
314 if(numRot < 0) {
315 numRot = std::abs(numRot);
316 clockwise = false;
317 }
318 for(int i = 0; i < numRot; i++) Rotate(clockwise);
319
320 return true;
321}
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,...
Definition Element.h:239
virtual void StartMove(wxPoint2DDouble position)
Update the element attributes related to the movement.
Definition Element.cpp:329
void SetPosition(const wxPoint2DDouble position)
Set the element position and update the rectangle.
Definition Element.cpp:27
virtual void Move(wxPoint2DDouble position)
Move the element other position.
Definition Element.cpp:335
virtual void Rotate(bool clockwise=true)
Rotate the element.
Definition Element.h:316
virtual void UpdateSwitches()
Update the switch position.

◆ OpenElement()

virtual bool PowerElement::OpenElement ( rapidxml::xml_node<> *  elementNode,
std::vector< Element * >  parentList 
)
inlinevirtual

Definition at line 234 of file PowerElement.h.

234{ return true; }

◆ OpenSwitchingData()

bool PowerElement::OpenSwitchingData ( rapidxml::xml_node<> *  electricalNode)
virtual

Definition at line 361 of file PowerElement.cpp.

362{
363 auto switchingList = electricalNode->first_node("SwitchingList");
364 if(!switchingList) return false;
365 auto swNode = switchingList->first_node("Switching");
366 while(swNode) {
367 m_swData.swType.push_back((SwitchingType)XMLParser::GetNodeValueInt(swNode, "Type"));
368 m_swData.swTime.push_back(XMLParser::GetNodeValueDouble(swNode, "Time"));
369 swNode = swNode->next_sibling("Switching");
370 }
371 return true;
372}
SwitchingType
Type of switching.
std::vector< double > swTime
std::vector< SwitchingType > swType

◆ SaveCADProperties()

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

Definition at line 323 of file PowerElement.cpp.

324{
325 auto cadProp = XMLParser::AppendNode(doc, elementNode, "CADProperties");
326 auto position = XMLParser::AppendNode(doc, cadProp, "Position");
327 auto posX = XMLParser::AppendNode(doc, position, "X");
328 XMLParser::SetNodeValue(doc, posX, m_position.m_x);
329 auto posY = XMLParser::AppendNode(doc, position, "Y");
330 XMLParser::SetNodeValue(doc, posY, m_position.m_y);
331 auto size = XMLParser::AppendNode(doc, cadProp, "Size");
332 auto width = XMLParser::AppendNode(doc, size, "Width");
333 XMLParser::SetNodeValue(doc, width, m_width);
334 auto height = XMLParser::AppendNode(doc, size, "Height");
335 XMLParser::SetNodeValue(doc, height, m_height);
336 auto angle = XMLParser::AppendNode(doc, cadProp, "Angle");
337 XMLParser::SetNodeValue(doc, angle, m_angle);
338 auto nodePos = XMLParser::AppendNode(doc, cadProp, "NodePosition");
339 auto nodePosX = XMLParser::AppendNode(doc, nodePos, "X");
340 XMLParser::SetNodeValue(doc, nodePosX, m_pointList[0].m_x);
341 auto nodePosY = XMLParser::AppendNode(doc, nodePos, "Y");
342 XMLParser::SetNodeValue(doc, nodePosY, m_pointList[0].m_y);
343 auto parentID = XMLParser::AppendNode(doc, cadProp, "ParentID");
344 Element* parent = m_parentList[0];
345 if(parent) XMLParser::SetNodeValue(doc, parentID, parent->GetID());
346}
Base class of all elements of the program. This class is responsible for manage graphical and his dat...
Definition Element.h:112
virtual int GetID() const
Get the element ID.
Definition Element.h:271

◆ SaveSwitchingData()

void PowerElement::SaveSwitchingData ( rapidxml::xml_document<> &  doc,
rapidxml::xml_node<> *  electricalNode 
)
virtual

Definition at line 348 of file PowerElement.cpp.

349{
350 auto switchingList = XMLParser::AppendNode(doc, electricalNode, "SwitchingList");
351 for(int i = 0; i < static_cast<int>(m_swData.swType.size()); i++) {
352 auto switching = XMLParser::AppendNode(doc, switchingList, "Switching");
353 XMLParser::SetNodeAttribute(doc, switching, "ID", i);
354 auto swType = XMLParser::AppendNode(doc, switching, "Type");
355 XMLParser::SetNodeValue(doc, swType, static_cast<int>(m_swData.swType[i]));
356 auto swTime = XMLParser::AppendNode(doc, switching, "Time");
357 XMLParser::SetNodeValue(doc, swTime, m_swData.swTime[i]);
358 }
359}

◆ SetDynamicEvent()

virtual void PowerElement::SetDynamicEvent ( bool  dynEvent = true)
inlinevirtual

Set if the power element have dynamic event.

Parameters
dynEventEvent occurrence.

Definition at line 229 of file PowerElement.h.

229{ m_dynEvent = dynEvent; }

◆ SetNominalVoltage()

void PowerElement::SetNominalVoltage ( std::vector< double >  nominalVoltage,
std::vector< ElectricalUnit nominalVoltageUnit 
)
virtual

Set nominal voltage of the element.

Parameters
nominalVoltageValue of the nominal voltage.
nominalVoltageUnitUnit of the nominal voltage.

Reimplemented in Line, SyncGenerator, SyncMotor, and Transformer.

Definition at line 35 of file PowerElement.cpp.

36{
37}

◆ SetPowerFlowDirection()

virtual void PowerElement::SetPowerFlowDirection ( PowerFlowDirection  pfDirection)
inlinevirtual

Set the direction of the power flow.

Parameters
pfDirectionPower flow direction.

Reimplemented in Line, Machines, and Transformer.

Definition at line 208 of file PowerElement.h.

208{ m_pfDirection = pfDirection; }
Here is the caller graph for this function:

◆ SetSwitchingData()

virtual void PowerElement::SetSwitchingData ( SwitchingData  data)
inlinevirtual

Set the switching data of the element.

Parameters
dataSwitching data.

Definition at line 198 of file PowerElement.h.

198{ m_swData = data; }

◆ SwitchesContains()

bool PowerElement::SwitchesContains ( wxPoint2DDouble  position) const
virtual

Check if switch contains position.

Parameters
positionposition to be checked.

Definition at line 63 of file PowerElement.cpp.

64{
65 for(int i = 0; i < (int)m_switchRect.size(); i++) {
66 if(m_parentList[i]) {
67 if(m_switchRect[i].Contains(position)) return true;
68 }
69 }
70 return false;
71}
virtual bool Contains(wxPoint2DDouble position) const =0
Checks if the element contains a position.
Here is the call graph for this function:

◆ UpdateSwitches()

void PowerElement::UpdateSwitches ( )
virtual

Update the switch position.

Reimplemented in Branch.

Definition at line 73 of file PowerElement.cpp.

74{
75 // General method, to one switch only.
76 wxPoint2DDouble swCenter = wxPoint2DDouble((m_pointList[0].m_x + m_pointList[1].m_x) / 2.0,
77 (m_pointList[0].m_y + m_pointList[1].m_y) / 2.0);
78 m_switchRect[0] = wxRect2DDouble(swCenter.m_x - m_switchSize / 2.0, swCenter.m_y - m_switchSize / 2.0, m_switchSize,
79 m_switchSize);
80}
Here is the caller graph for this function:

Member Data Documentation

◆ m_busColour

wxColour PowerElement::m_busColour
protected

Definition at line 243 of file PowerElement.h.

◆ m_closedSwitchColour

wxColour PowerElement::m_closedSwitchColour
protected

Definition at line 246 of file PowerElement.h.

◆ m_dynamicEventColour

wxColour PowerElement::m_dynamicEventColour
protected

Definition at line 249 of file PowerElement.h.

◆ m_dynEvent

bool PowerElement::m_dynEvent = false
protected

Definition at line 251 of file PowerElement.h.

◆ m_offlineElementColour

wxColour PowerElement::m_offlineElementColour
protected

Definition at line 245 of file PowerElement.h.

◆ m_onlineElementColour

wxColour PowerElement::m_onlineElementColour
protected

Definition at line 244 of file PowerElement.h.

◆ m_openedSwitchColour

wxColour PowerElement::m_openedSwitchColour
protected

Definition at line 247 of file PowerElement.h.

◆ m_pfDirection

PowerFlowDirection PowerElement::m_pfDirection = PowerFlowDirection::PF_NONE
protected

Definition at line 241 of file PowerElement.h.

◆ m_powerFlowArrow

std::vector<std::vector<wxPoint2DDouble> > PowerElement::m_powerFlowArrow
protected

Definition at line 240 of file PowerElement.h.

◆ m_powerFlowArrowColour

wxColour PowerElement::m_powerFlowArrowColour
protected

Definition at line 248 of file PowerElement.h.

◆ m_swData

SwitchingData PowerElement::m_swData
protected

Definition at line 239 of file PowerElement.h.


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