summaryrefslogtreecommitdiffstats
path: root/Project/ControlElementContainer.cpp
diff options
context:
space:
mode:
authorThales Lima Oliveira <thaleslima.ufu@gmail.com>2017-04-24 17:39:03 -0300
committerGitHub <noreply@github.com>2017-04-24 17:39:03 -0300
commit7804c1bd2c0bd2a5f135c30b20991e8187581cc6 (patch)
tree725e524253d6fd714460402194b408cb33b80b3f /Project/ControlElementContainer.cpp
parent69131a727782090ffd7cb467f449e8f26d3d2949 (diff)
parent9529a6ed44645842adc6f938478acc1dfa17a284 (diff)
downloadPSP.git-7804c1bd2c0bd2a5f135c30b20991e8187581cc6.tar.gz
PSP.git-7804c1bd2c0bd2a5f135c30b20991e8187581cc6.tar.xz
PSP.git-7804c1bd2c0bd2a5f135c30b20991e8187581cc6.zip
Merge pull request #28 from Thales1330/wip/generic-controllers
Wip generic controllers. Chart view implementation required, creating new branch....
Diffstat (limited to 'Project/ControlElementContainer.cpp')
-rw-r--r--Project/ControlElementContainer.cpp54
1 files changed, 54 insertions, 0 deletions
diff --git a/Project/ControlElementContainer.cpp b/Project/ControlElementContainer.cpp
new file mode 100644
index 0000000..f5372a8
--- /dev/null
+++ b/Project/ControlElementContainer.cpp
@@ -0,0 +1,54 @@
+#include "ControlElementContainer.h"
+#include "ControlEditor.h"
+#include "ControlElement.h"
+
+ControlElementContainer::ControlElementContainer() {}
+ControlElementContainer::~ControlElementContainer() {}
+void ControlElementContainer::FillContainer(ControlEditor* editor)
+{
+ ClearContainer();
+ m_ctrlElementsList = editor->GetControlElementList();
+ m_cLineList = editor->GetConnectionLineList();
+ auto cElementList = editor->GetControlElementList();
+ for(auto it = cElementList.begin(), itEnd = cElementList.end(); it != itEnd; ++it) {
+ if(Constant* constant = dynamic_cast<Constant*>(*it)) {
+ m_constantList.push_back(constant);
+ } else if(Exponential* exponential = dynamic_cast<Exponential*>(*it)) {
+ m_exponentialList.push_back(exponential);
+ } else if(Gain* gain = dynamic_cast<Gain*>(*it)) {
+ m_gainList.push_back(gain);
+ } else if(IOControl* ioControl = dynamic_cast<IOControl*>(*it)) {
+ m_ioControlList.push_back(ioControl);
+ } else if(Limiter* limiter = dynamic_cast<Limiter*>(*it)) {
+ m_limiterList.push_back(limiter);
+ } else if(Multiplier* multiplier = dynamic_cast<Multiplier*>(*it)) {
+ m_multiplierList.push_back(multiplier);
+ } else if(RateLimiter* rateLimiter = dynamic_cast<RateLimiter*>(*it)) {
+ m_rateLimiterList.push_back(rateLimiter);
+ } else if(Sum* sum = dynamic_cast<Sum*>(*it)) {
+ m_sumList.push_back(sum);
+ } else if(TransferFunction* tf = dynamic_cast<TransferFunction*>(*it)) {
+ m_tfList.push_back(tf);
+ }
+ }
+}
+
+void ControlElementContainer::ClearContainer()
+{
+ m_cLineList.clear();
+ m_constantList.clear();
+ m_exponentialList.clear();
+ m_gainList.clear();
+ m_ioControlList.clear();
+ m_limiterList.clear();
+ m_multiplierList.clear();
+ m_rateLimiterList.clear();
+ m_sumList.clear();
+ m_tfList.clear();
+}
+
+void ControlElementContainer::FillContainer(std::vector<ControlElement*> controlElementList, std::vector<ConnectionLine*> connectionLineList)
+{
+ m_ctrlElementsList = controlElementList;
+ m_cLineList = connectionLineList;
+}