summaryrefslogtreecommitdiffstats
path: root/Project/TransferFunctionForm.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/TransferFunctionForm.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/TransferFunctionForm.cpp')
-rw-r--r--Project/TransferFunctionForm.cpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/Project/TransferFunctionForm.cpp b/Project/TransferFunctionForm.cpp
new file mode 100644
index 0000000..d71b28b
--- /dev/null
+++ b/Project/TransferFunctionForm.cpp
@@ -0,0 +1,76 @@
+#include "TransferFunctionForm.h"
+#include "TransferFunction.h"
+
+TransferFunctionForm::TransferFunctionForm(wxWindow* parent, TransferFunction* transferFunction)
+ : TransferFunctionFormBase(parent)
+{
+ m_parent = parent;
+ m_tf = transferFunction;
+ LoadTFData();
+}
+
+TransferFunctionForm::~TransferFunctionForm() {}
+void TransferFunctionForm::OnCancelClick(wxCommandEvent& event) { EndModal(wxID_CANCEL); }
+void TransferFunctionForm::OnOKClick(wxCommandEvent& event)
+{
+ if(ValidateData()) EndModal(wxID_OK);
+}
+
+void TransferFunctionForm::LoadTFData()
+{
+ auto num = m_tf->GetNumerator();
+ auto den = m_tf->GetDenominator();
+
+ wxString numStr = "";
+ for(auto it = num.begin(), itEnd = num.end(); it != itEnd; ++it) {
+ double value = *it;
+ if(it == num.begin())
+ numStr = m_tf->StringFromDouble(value, 0);
+ else
+ numStr += " " + m_tf->StringFromDouble(value, 0);
+ }
+ m_textCtrlNumerator->SetValue(numStr);
+
+ wxString denStr = "";
+ for(auto it = den.begin(), itEnd = den.end(); it != itEnd; ++it) {
+ double value = *it;
+ if(it == den.begin())
+ denStr = m_tf->StringFromDouble(value, 0);
+ else
+ denStr += " " + m_tf->StringFromDouble(value, 0);
+ }
+ m_textCtrlDenominator->SetValue(denStr);
+}
+
+bool TransferFunctionForm::ValidateData()
+{
+ wxString num = m_textCtrlNumerator->GetValue();
+ std::vector<double> numerator;
+ while(num != "") {
+ wxString rest;
+ wxString strValue = num.BeforeFirst(' ', &rest);
+ num = rest;
+ double value = 0;
+ if(!m_tf->DoubleFromString(this, strValue, value,
+ _("Value entered incorrectly in the field \"Numerator parameters\".")))
+ return false;
+ numerator.push_back(value);
+ }
+
+ wxString den = m_textCtrlDenominator->GetValue();
+ std::vector<double> denominator;
+ while(den != "") {
+ wxString rest;
+ wxString strValue = den.BeforeFirst(' ', &rest);
+ den = rest;
+ double value = 0;
+ if(!m_tf->DoubleFromString(this, strValue, value,
+ _("Value entered incorrectly in the field \"Denominator parameters\".")))
+ return false;
+ denominator.push_back(value);
+ }
+ m_tf->SetNumerator(numerator);
+ m_tf->SetDenominator(denominator);
+ m_tf->UpdateTFText();
+ return true;
+}