本文整理汇总了C++中simtk::xml::Element::removeNode方法的典型用法代码示例。如果您正苦于以下问题:C++ Element::removeNode方法的具体用法?C++ Element::removeNode怎么用?C++ Element::removeNode使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类simtk::xml::Element
的用法示例。
在下文中一共展示了Element::removeNode方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: updateFromXMLNode
void Body::updateFromXMLNode(SimTK::Xml::Element& aNode, int versionNumber)
{
if (versionNumber < XMLDocument::getLatestVersion()) {
if (versionNumber < 30500) {
SimTK::Vec6 newInertia(1.0, 1.0, 1.0, 0., 0., 0.);
std::string inertiaComponents[] = { "inertia_xx", "inertia_yy", "inertia_zz", "inertia_xy", "inertia_xz", "inertia_yz" };
for (int i = 0; i < 6; ++i) {
SimTK::Xml::element_iterator iIter = aNode.element_begin(inertiaComponents[i]);
if (iIter != aNode.element_end()) {
newInertia[i] = iIter->getValueAs<double>();
aNode.removeNode(iIter);
}
}
std::ostringstream strs;
for (int i = 0; i < 6; ++i) {
strs << newInertia[i];
if (i < 5) strs << " ";
}
std::string strInertia = strs.str();
SimTK::Xml::Element inertiaNode("inertia", strInertia);
aNode.insertNodeAfter(aNode.element_end(), inertiaNode);
}
}
Super::updateFromXMLNode(aNode, versionNumber);
}
示例2: updateFromXMLNode
//_____________________________________________________________________________
// Override default implementation by object to intercept and fix the XML node
// underneath the model to match current version.
void Muscle::updateFromXMLNode(SimTK::Xml::Element& aNode, int versionNumber)
{
if ( versionNumber < XMLDocument::getLatestVersion()) {
if (Object::getDebugLevel()>=1)
cout << "Updating Muscle object to latest format..." << endl;
if (versionNumber <= 20301){
SimTK::Xml::element_iterator pathIter =
aNode.element_begin("GeometryPath");
if (pathIter != aNode.element_end()) {
XMLDocument::renameChildNode(*pathIter, "MusclePointSet", "PathPointSet");
XMLDocument::renameChildNode(*pathIter, "MuscleWrapSet", "PathWrapSet");
} else { // There was no GeometryPath, just MusclePointSet
SimTK::Xml::element_iterator musclePointSetIter = aNode.element_begin("MusclePointSet");
bool pathPointSetFound=false;
if (musclePointSetIter != aNode.element_end()){
XMLDocument::renameChildNode(aNode, "MusclePointSet", "PathPointSet");
pathPointSetFound=true;
}
bool pathWrapSetFound=false;
SimTK::Xml::element_iterator muscleWrapSetIter = aNode.element_begin("MuscleWrapSet");
if (muscleWrapSetIter != aNode.element_end()){
XMLDocument::renameChildNode(aNode, "MuscleWrapSet", "PathWrapSet");
pathWrapSetFound=true;
}
// Now create a "GeometryPath" node and move MusclePointSet & MuscleWrapSet under it
SimTK::Xml::Element myPathElement("GeometryPath");
SimTK::Xml::Node moveNode;
if (pathPointSetFound) {
SimTK::Xml::element_iterator pathPointSetIter = aNode.element_begin("PathPointSet");
moveNode = aNode.removeNode(pathPointSetIter);
myPathElement.insertNodeAfter(myPathElement.element_end(),moveNode);
}
if (pathWrapSetFound) {
SimTK::Xml::element_iterator pathWrapSetIter = aNode.element_begin("PathWrapSet");
moveNode = aNode.removeNode(pathWrapSetIter);
myPathElement.insertNodeAfter(myPathElement.element_end(),moveNode);
}
aNode.insertNodeAfter(aNode.element_end(), myPathElement);
}
XMLDocument::renameChildNode(aNode, "pennation_angle", "pennation_angle_at_optimal");
}
}
// Call base class now assuming aNode has been corrected for current version
Super::updateFromXMLNode(aNode, versionNumber);
}