diff options
author | Thales Lima Oliveira <thaleslima.ufu@gmail.com> | 2017-04-07 17:49:47 -0300 |
---|---|---|
committer | Thales Lima Oliveira <thaleslima.ufu@gmail.com> | 2017-04-07 17:49:47 -0300 |
commit | d13b7013afa5ba1d40ee52e77eabd43bfd1b4acd (patch) | |
tree | 204ed52f4a2328abeab137285a4a50e63fedf2c3 /Project/ControlElementContainer.cpp | |
parent | ed36957d2d06ce9484e39be699bc41b521bdb090 (diff) | |
download | PSP.git-d13b7013afa5ba1d40ee52e77eabd43bfd1b4acd.tar.gz PSP.git-d13b7013afa5ba1d40ee52e77eabd43bfd1b4acd.tar.xz PSP.git-d13b7013afa5ba1d40ee52e77eabd43bfd1b4acd.zip |
generic controls gui implemented
Diffstat (limited to 'Project/ControlElementContainer.cpp')
-rw-r--r-- | Project/ControlElementContainer.cpp | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/Project/ControlElementContainer.cpp b/Project/ControlElementContainer.cpp new file mode 100644 index 0000000..062807a --- /dev/null +++ b/Project/ControlElementContainer.cpp @@ -0,0 +1,63 @@ +#include "ControlElementContainer.h" +#include "ControlEditor.h"; +#include "ControlElement.h"; +#include "ConnectionLine.h"; +#include "Constant.h"; +#include "Exponential.h"; +#include "Gain.h"; +#include "IOControl.h"; +#include "Limiter.h"; +#include "Multiplier.h"; +#include "RateLimiter.h"; +#include "Sum.h"; +#include "TransferFunction.h"; + +ControlElementContainer::ControlElementContainer() +{ +} + +ControlElementContainer::~ControlElementContainer() +{ +} + +void ControlElementContainer::FillContainer(ControlEditor* editor) +{ + ClearContainer(); + 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(limiter); + } 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(); +} |