diff options
author | Thales Lima Oliveira <thaleslima.ufu@gmail.com> | 2017-04-24 17:39:03 -0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-04-24 17:39:03 -0300 |
commit | 7804c1bd2c0bd2a5f135c30b20991e8187581cc6 (patch) | |
tree | 725e524253d6fd714460402194b408cb33b80b3f /Project/ControlElementContainer.cpp | |
parent | 69131a727782090ffd7cb467f449e8f26d3d2949 (diff) | |
parent | 9529a6ed44645842adc6f938478acc1dfa17a284 (diff) | |
download | PSP.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.cpp | 54 |
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; +} |