diff options
author | Thales1330 <thaleslima.ufu@gmail.com> | 2017-03-08 18:26:37 -0300 |
---|---|---|
committer | Thales1330 <thaleslima.ufu@gmail.com> | 2017-03-08 18:26:37 -0300 |
commit | a1890bd024e0baea393480810709f43208825b9a (patch) | |
tree | 5eeb60b0e9d3085bbe2d2ba0c1939f26aa574f27 /Project/SumForm.cpp | |
parent | 009849e49967af659354a94a16c51cab5eb8b5a4 (diff) | |
download | PSP.git-a1890bd024e0baea393480810709f43208825b9a.tar.gz PSP.git-a1890bd024e0baea393480810709f43208825b9a.tar.xz PSP.git-a1890bd024e0baea393480810709f43208825b9a.zip |
Sum form implementation start
Diffstat (limited to 'Project/SumForm.cpp')
-rw-r--r-- | Project/SumForm.cpp | 60 |
1 files changed, 59 insertions, 1 deletions
diff --git a/Project/SumForm.cpp b/Project/SumForm.cpp index d257771..4742eaa 100644 --- a/Project/SumForm.cpp +++ b/Project/SumForm.cpp @@ -6,9 +6,67 @@ SumForm::SumForm(wxWindow* parent, Sum* sum) { m_parent = parent; m_sum = sum; + + wxString signalStr = ""; + auto signalList = m_sum->GetSignalList(); + for(auto it = signalList.begin(), itEnd = signalList.end(); it != itEnd; ++it) { + Sum::Signal signal = *it; + switch(signal) { + case Sum::SIGNAL_POSITIVE: { + signalStr += "+"; + } break; + case Sum::SIGNAL_NEGATIVE: { + signalStr += "-"; + } break; + } + if(it != itEnd - 1) signalStr += " "; + } + m_textCtrlSigns->SetValue(signalStr); } -SumForm::~SumForm() +SumForm::~SumForm() {} + +void SumForm::OnOKClick(wxCommandEvent& event) { + if(ValidateData()) EndModal(wxID_OK); } +bool SumForm::ValidateData() +{ + wxString signalStr = ""; + for(int i = 0; i < (int)m_textCtrlSigns->GetValue().length(); ++i) { + if(m_textCtrlSigns->GetValue()[i] != ' ') signalStr += m_textCtrlSigns->GetValue()[i]; + } + if(signalStr.size() < 2) return false; + + std::vector<Sum::Signal> signalList; + for(int i = 0; i < (int)signalStr.length(); ++i) { + switch(signalStr[i].GetValue()) { + case '+': { + signalList.push_back(Sum::SIGNAL_POSITIVE); + } break; + case '-': { + signalList.push_back(Sum::SIGNAL_NEGATIVE); + } break; + default: { + return false; + } + } + } + + int diff = (int)signalList.size() - (int)m_sum->GetSignalList().size(); + + if(diff < 0) { + + } else if(diff > 0) { + auto nodeList = m_sum->GetNodeList(); + for(int i = 0; i < diff; ++i) { + Node* newNode = new Node(); + nodeList.insert(nodeList.end() - 1, newNode); + } + m_sum->SetNodeList(nodeList); + } + m_sum->SetSignalList(signalList); + m_sum->UpdatePoints(); + return true; +} |