diff options
author | Thales Lima Oliveira <thaleslima.ufu@gmail.com> | 2018-01-04 19:11:08 -0200 |
---|---|---|
committer | Thales Lima Oliveira <thaleslima.ufu@gmail.com> | 2018-01-04 19:11:08 -0200 |
commit | 76df1de5e2307229da9870306e4a1031170aaadf (patch) | |
tree | 6d7144e9982a824474279f02574c918ce8fa0e9d /Project/TransferFunction.cpp | |
parent | cef9e14b989a3ba19321e4fe215ada2ee3998037 (diff) | |
download | PSP.git-76df1de5e2307229da9870306e4a1031170aaadf.tar.gz PSP.git-76df1de5e2307229da9870306e4a1031170aaadf.tar.xz PSP.git-76df1de5e2307229da9870306e4a1031170aaadf.zip |
Control elements file handling reorganized
Diffstat (limited to 'Project/TransferFunction.cpp')
-rw-r--r-- | Project/TransferFunction.cpp | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/Project/TransferFunction.cpp b/Project/TransferFunction.cpp index 8ebaddc..d630ea3 100644 --- a/Project/TransferFunction.cpp +++ b/Project/TransferFunction.cpp @@ -389,9 +389,52 @@ bool TransferFunction::UpdateText() void TransferFunction::SaveElement(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* elementListNode) { + auto elementNode = XMLParser::AppendNode(doc, elementListNode, "TransferFunction"); + XMLParser::SetNodeAttribute(doc, elementNode, "ID", m_elementID); + + SaveCADProperties(doc, elementNode); + SaveControlNodes(doc, elementNode); + + // Element properties + auto numeratorNode = XMLParser::AppendNode(doc, elementNode, "Numerator"); + for(unsigned int i = 0; i < m_numerator.size(); ++i) { + auto value = XMLParser::AppendNode(doc, numeratorNode, "Value"); + XMLParser::SetNodeValue(doc, value, m_numerator[i]); + } + auto denominatorNode = XMLParser::AppendNode(doc, elementNode, "Denominator"); + for(unsigned int i = 0; i < m_denominator.size(); ++i) { + auto value = XMLParser::AppendNode(doc, denominatorNode, "Value"); + XMLParser::SetNodeValue(doc, value, m_denominator[i]); + } } bool TransferFunction::OpenElement(rapidxml::xml_node<>* elementNode) { + if(!OpenCADProperties(elementNode)) return false; + if(!OpenControlNodes(elementNode)) return false; + + // Element properties + std::vector<double> numerator, denominator; + m_numerator.clear(); + m_denominator.clear(); + auto numeratorNode = elementNode->first_node("Numerator"); + auto nValue = numeratorNode->first_node("Value"); + while(nValue) { + double value = 0.0; + wxString(nValue->value()).ToCDouble(&value); + m_numerator.push_back(value); + nValue = nValue->next_sibling("Value"); + } + auto denominatorNode = elementNode->first_node("Denominator"); + auto dValue = denominatorNode->first_node("Value"); + while(dValue) { + double value = 0.0; + wxString(dValue->value()).ToCDouble(&value); + m_denominator.push_back(value); + dValue = dValue->next_sibling("Value"); + } + StartMove(m_position); + UpdateTFText(); + return true; } |