From 76df1de5e2307229da9870306e4a1031170aaadf Mon Sep 17 00:00:00 2001 From: Thales Lima Oliveira Date: Thu, 4 Jan 2018 19:11:08 -0200 Subject: Control elements file handling reorganized --- Project/Constant.cpp | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'Project/Constant.cpp') diff --git a/Project/Constant.cpp b/Project/Constant.cpp index f99eab6..ce50719 100644 --- a/Project/Constant.cpp +++ b/Project/Constant.cpp @@ -32,6 +32,7 @@ Constant::~Constant() { if(m_glText) delete m_glText; } + void Constant::Draw(wxPoint2DDouble translation, double scale) const { glLineWidth(1.0); @@ -127,3 +128,29 @@ bool Constant::UpdateText() if(!m_glText->IsTextureOK()) return false; return true; } + +void Constant::SaveElement(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* elementListNode) +{ + auto elementNode = XMLParser::AppendNode(doc, elementListNode, "Constant"); + XMLParser::SetNodeAttribute(doc, elementNode, "ID", m_elementID); + + SaveCADProperties(doc, elementNode); + SaveControlNodes(doc, elementNode); + + // Element properties + auto value = XMLParser::AppendNode(doc, elementNode, "Value"); + XMLParser::SetNodeValue(doc, value, m_value); +} + +bool Constant::OpenElement(rapidxml::xml_node<>* elementNode) +{ + if(!OpenCADProperties(elementNode)) return false; + if(!OpenControlNodes(elementNode)) return false; + + // Element properties + double value = XMLParser::GetNodeValueDouble(elementNode, "Value"); + + SetPosition(m_position); + SetValue(value); + return true; +} -- cgit From c11a42ee83fcf535557d4f2cc259efae2da1b7ff Mon Sep 17 00:00:00 2001 From: Thales Lima Oliveira Date: Mon, 8 Jan 2018 20:07:47 -0200 Subject: File handling and control initialization organized --- Project/Constant.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'Project/Constant.cpp') diff --git a/Project/Constant.cpp b/Project/Constant.cpp index ce50719..c81a0cf 100644 --- a/Project/Constant.cpp +++ b/Project/Constant.cpp @@ -129,7 +129,7 @@ bool Constant::UpdateText() return true; } -void Constant::SaveElement(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* elementListNode) +rapidxml::xml_node<>* Constant::SaveElement(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* elementListNode) { auto elementNode = XMLParser::AppendNode(doc, elementListNode, "Constant"); XMLParser::SetNodeAttribute(doc, elementNode, "ID", m_elementID); @@ -140,6 +140,8 @@ void Constant::SaveElement(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* // Element properties auto value = XMLParser::AppendNode(doc, elementNode, "Value"); XMLParser::SetNodeValue(doc, value, m_value); + + return elementNode; } bool Constant::OpenElement(rapidxml::xml_node<>* elementNode) -- cgit