diff options
author | Thales Lima Oliveira <thaleslima.ufu@gmail.com> | 2018-01-05 20:04:28 -0200 |
---|---|---|
committer | Thales Lima Oliveira <thaleslima.ufu@gmail.com> | 2018-01-05 20:04:28 -0200 |
commit | 95f61a7cad71c45c9e27af5c6f4bc5d64d5ecc45 (patch) | |
tree | d11fb974997f49942977a5ce3318074ea503f9bc /Project/Capacitor.cpp | |
parent | 76df1de5e2307229da9870306e4a1031170aaadf (diff) | |
download | PSP.git-95f61a7cad71c45c9e27af5c6f4bc5d64d5ecc45.tar.gz PSP.git-95f61a7cad71c45c9e27af5c6f4bc5d64d5ecc45.tar.xz PSP.git-95f61a7cad71c45c9e27af5c6f4bc5d64d5ecc45.zip |
Some power element file hand. organized
Diffstat (limited to 'Project/Capacitor.cpp')
-rw-r--r-- | Project/Capacitor.cpp | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/Project/Capacitor.cpp b/Project/Capacitor.cpp index 4f7491f..0378506 100644 --- a/Project/Capacitor.cpp +++ b/Project/Capacitor.cpp @@ -15,8 +15,8 @@ * along with this program. If not, see <https://www.gnu.org/licenses/>. */ -#include "ReactiveShuntElementForm.h" #include "Capacitor.h" +#include "ReactiveShuntElementForm.h" Capacitor::Capacitor() : Shunt() {} Capacitor::Capacitor(wxString name) : Shunt() { m_electricalData.name = name; } @@ -217,3 +217,43 @@ wxString Capacitor::GetTipText() const return tipText; } + +void Capacitor::SaveElement(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* elementListNode) +{ + auto elementNode = XMLParser::AppendNode(doc, elementListNode, "Capacitor"); + XMLParser::SetNodeAttribute(doc, elementNode, "ID", m_elementID); + + SaveCADProperties(doc, elementNode); + + auto electricalProp = XMLParser::AppendNode(doc, elementNode, "ElectricalProperties"); + auto isOnline = XMLParser::AppendNode(doc, electricalProp, "IsOnline"); + XMLParser::SetNodeValue(doc, isOnline, m_online); + auto name = XMLParser::AppendNode(doc, electricalProp, "Name"); + XMLParser::SetNodeValue(doc, name, m_electricalData.name); + auto reactivePower = XMLParser::AppendNode(doc, electricalProp, "ReactivePower"); + XMLParser::SetNodeValue(doc, reactivePower, m_electricalData.reactivePower); + XMLParser::SetNodeAttribute(doc, reactivePower, "UnitID", m_electricalData.reactivePowerUnit); + + SaveSwitchingData(doc, electricalProp); +} + +bool Capacitor::OpenElement(rapidxml::xml_node<>* elementNode, std::vector<Element*> parentList) +{ + if(!OpenCADProperties(elementNode, parentList)) return false; + + auto electricalProp = elementNode->first_node("ElectricalProperties"); + if(!electricalProp) return false; + + SetOnline(XMLParser::GetNodeValueInt(electricalProp, "IsOnline")); + m_electricalData.name = electricalProp->first_node("Name")->value(); + m_electricalData.reactivePower = XMLParser::GetNodeValueDouble(electricalProp, "ReactivePower"); + m_electricalData.reactivePowerUnit = + static_cast<ElectricalUnit>(XMLParser::GetAttributeValueInt(electricalProp, "ReactivePower", "UnitID")); + + if(!OpenSwitchingData(electricalProp)) return false; + + if(m_swData.swTime.size() != 0) SetDynamicEvent(true); + + m_inserted = true; + return true; +} |