summaryrefslogtreecommitdiffstats
path: root/Project/Shunt.h
diff options
context:
space:
mode:
authorThales1330 <thaleslima.ufu@gmail.com>2016-12-06 13:26:46 -0200
committerThales1330 <thaleslima.ufu@gmail.com>2016-12-06 13:26:46 -0200
commite282ec268db0d17a1d53f813c5fff9473d25e797 (patch)
tree517e01b8685248f04548513091e7040a1b36ec0b /Project/Shunt.h
parentd4efffcdedbb41596eecd0882a1cef76f6afc435 (diff)
parente266f5811403beea13c9cc5399c55db4a34fdd3c (diff)
downloadPSP.git-e282ec268db0d17a1d53f813c5fff9473d25e797.tar.gz
PSP.git-e282ec268db0d17a1d53f813c5fff9473d25e797.tar.xz
PSP.git-e282ec268db0d17a1d53f813c5fff9473d25e797.zip
Merge remote-tracking branch 'refs/remotes/origin/wip/currentState'
Diffstat (limited to 'Project/Shunt.h')
-rw-r--r--Project/Shunt.h31
1 files changed, 31 insertions, 0 deletions
diff --git a/Project/Shunt.h b/Project/Shunt.h
new file mode 100644
index 0000000..cf1681d
--- /dev/null
+++ b/Project/Shunt.h
@@ -0,0 +1,31 @@
+#ifndef SHUNT_H
+#define SHUNT_H
+
+#include "Element.h"
+
+class Shunt : public Element
+{
+public:
+ Shunt();
+ ~Shunt();
+
+ virtual bool Contains(wxPoint2DDouble position) const { return m_rect.Contains(position); }
+ virtual bool Intersects(wxRect2DDouble rect) const { return m_rect.Intersects(rect); }
+ virtual void Move(wxPoint2DDouble position);
+ virtual void MoveNode(Element* element, wxPoint2DDouble position);
+ virtual void StartMove(wxPoint2DDouble position);
+ virtual void RotateNode(Element* parent, bool clockwise = true);
+ virtual void RemoveParent(Element* parent);
+ virtual bool NodeContains(wxPoint2DDouble position);
+ virtual bool SetNodeParent(Element* parent);
+ virtual void UpdateNodes();
+
+ protected:
+ void UpdateSwitchesPosition();
+ void UpdatePowerFlowArrowsPosition();
+ void DrawGround(wxPoint2DDouble position) const;
+ bool m_inserted = false;
+
+};
+
+#endif // SHUNT_H