summaryrefslogtreecommitdiffstats
path: root/Project/MathExpression.h
diff options
context:
space:
mode:
authorThales Lima Oliveira <thaleslima.ufu@gmail.com>2017-12-31 18:00:25 -0200
committerGitHub <noreply@github.com>2017-12-31 18:00:25 -0200
commit0c0280cfcf540f943fd2dbfdf7ac0304ea96a465 (patch)
tree51c89fc8155dcc447743dc89a1ab5ce36acc72cf /Project/MathExpression.h
parentc8193665975686fb8a344bee3dc94914a3d3558a (diff)
parentdbe0b112622f8e91fa3e44a6b6e1aa7e230d3ded (diff)
downloadPSP.git-0c0280cfcf540f943fd2dbfdf7ac0304ea96a465.tar.gz
PSP.git-0c0280cfcf540f943fd2dbfdf7ac0304ea96a465.tar.xz
PSP.git-0c0280cfcf540f943fd2dbfdf7ac0304ea96a465.zip
Merge pull request #43 from Thales1330/wip/math-expr-control-block
Wip math expr control block
Diffstat (limited to 'Project/MathExpression.h')
-rw-r--r--Project/MathExpression.h78
1 files changed, 78 insertions, 0 deletions
diff --git a/Project/MathExpression.h b/Project/MathExpression.h
new file mode 100644
index 0000000..77894ef
--- /dev/null
+++ b/Project/MathExpression.h
@@ -0,0 +1,78 @@
+/*
+ * Copyright (C) 2017 Thales Lima Oliveira <thales@ufu.br>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ */
+
+#ifndef MATHEXPRESSION_H
+#define MATHEXPRESSION_H
+
+#include "ControlElement.h"
+#include "MathExprParser.h"
+#include "OpenGLText.h"
+
+class ConnectionLine;
+
+class MathExpressionForm;
+
+/**
+ * @class MathExpression
+ * @author Thales Lima Oliveira <thales@ufu.br>
+ * @date 19/12/2017
+ * @brief A generic math expression block that can perform math and conditional operations with the inputs.
+ * @file MathExpression.h
+ */
+class MathExpression : public ControlElement
+{
+ public:
+ MathExpression(int id);
+ ~MathExpression();
+
+ virtual void Draw(wxPoint2DDouble translation, double scale) const;
+ virtual bool Contains(wxPoint2DDouble position) const { return m_rect.Contains(position); }
+ virtual bool Intersects(wxRect2DDouble rect) const { return m_rect.Intersects(rect); }
+ virtual bool ShowForm(wxWindow* parent, Element* element);
+ virtual void Rotate(bool clockwise = true);
+
+ virtual bool Solve(double* input, double timeStep);
+ virtual bool Initialize();
+ virtual wxString GetMathExpression() { return m_mathExpression; }
+ virtual void SetMathExpression(wxString mathExpression) { m_mathExpression = mathExpression; }
+ virtual std::vector<wxString> GetVariables() { return m_variablesVector; }
+ virtual void SetVariables(std::vector<wxString> variablesVector);
+ virtual MathExprParser GetParser() { return m_fparser; }
+
+ virtual void UpdatePoints();
+ void AddInNode();
+ void RemoveInNode();
+ virtual bool UpdateText();
+
+ virtual Element* GetCopy();
+
+ protected:
+ void CalculateBlockSize(double numInNodes);
+
+ MathExprParser m_fparser;
+ wxString m_mathExpression = "sqrt(x^2 + y^2)";
+ wxString m_variables = "time,step,x,y";
+ std::vector<wxString> m_variablesVector;
+ double* m_inputValues = NULL;
+ std::vector<OpenGLText*> m_glTextInputVector;
+ OpenGLText m_symbol;
+ wxSize m_symbolSize;
+ int m_maxSringSize = 0;
+ double m_minimumSize = 36.0;
+};
+
+#endif // MATHEXPRESSION_H