Files
Hoops_Exchange/exchange/exchangesource/PRC2XML/PRC2XMLStructure.cpp
2025-12-15 22:06:49 +08:00

615 lines
23 KiB
C++

/***********************************************************************************************************************
*
* Copyright (c) 2010 - 2022 by Tech Soft 3D, Inc.
* The information contained herein is confidential and proprietary to Tech Soft 3D, Inc., and considered a trade secret
* as defined under civil and criminal statutes. Tech Soft 3D shall pursue its civil and criminal remedies in the event
* of unauthorized use or misappropriation of its trade secrets. Use of this information by anyone other than authorized
* employees of Tech Soft 3D, Inc. is granted only under a written non-disclosure agreement, expressly prescribing the
* scope and manner of such use.
*
***********************************************************************************************************************/
#include <A3DSDKIncludes.h>
#include "PRC2XML.h"
int traverseDisplayFilters(A3DUns32 uiSize, A3DAsmFilter** ppFilters, _TiXmlElement* setting);
int traverseGraphScene(const A3DGraphSceneDisplayParametersData& sData, _TiXmlElement* setting);
//######################################################################################################################
int traverseMaterialProperties(const A3DEntity* pEntity, _TiXmlElement* xmlfather)
{
_TiXmlElement* xml = new _TiXmlElement("A3DMiscMaterialPropertiesData");
A3DMiscMaterialPropertiesData sMaterialPropertiesData;
A3D_INITIALIZE_DATA(A3DMiscMaterialPropertiesData, sMaterialPropertiesData);
A3DStatus iRet = A3DMiscGetMaterialProperties(pEntity, &sMaterialPropertiesData);
if(iRet == A3D_SUCCESS)
{
xml->SetDoubleAttribute("m_dDensity", sMaterialPropertiesData.m_dDensity);
xml->SetAttribute("m_pcMaterialName", sMaterialPropertiesData.m_pcMaterialName ? sMaterialPropertiesData.m_pcMaterialName:"NULL");
xml->SetAttribute("m_ePhysicType", sMaterialPropertiesData.m_ePhysicType);
switch (sMaterialPropertiesData.m_ePhysicType)
{
case A3DPhysicType_None:
case A3DPhysicType_Fiber:
case A3DPhysicType_HoneyComb:
case A3DPhysicType_Isotropic:
case A3DPhysicType_Orthotropic2D:
case A3DPhysicType_Orthotropic3D:
case A3DPhysicType_Anisotropic:
default:
break;
}
A3DMiscGetMaterialProperties(NULL, &sMaterialPropertiesData);
}
xmlfather->LinkEndChild(xml);
return A3D_SUCCESS;
}
//######################################################################################################################
static int stTraversePartDef(const A3DAsmPartDefinition* pPart, _TiXmlElement* xmlfather)
{
A3DInt32 iRet = A3D_SUCCESS;
A3DAsmPartDefinitionData sData;
A3D_INITIALIZE_DATA(A3DAsmPartDefinitionData, sData);
_TiXmlElement* part = new _TiXmlElement("A3DAsmPartDefinitionData");
traverseSource(pPart, part);
iRet = A3DAsmPartDefinitionGet(pPart, &sData);
if(iRet == A3D_SUCCESS)
{
A3DUns32 ui;
part->SetAttribute("m_bInactivateAnnotations", sData.m_bInactivateAnnotations ? "true" : "false");
iRet = traverseBoundingBox(&sData.m_sBoundingBox, part);
for(ui = 0; ui < sData.m_uiAnnotationsSize; ++ui)
traverseAnnotation(sData.m_ppAnnotations[ui], part);
for(ui = 0; ui < sData.m_uiViewsSize; ++ui)
traverseView(sData.m_ppViews[ui], part);
for(ui = 0; ui < sData.m_uiRepItemsSize; ++ui)
traverseRepItem(sData.m_ppRepItems[ui], part);
// traverse the drawing !!!!!!!
for (ui = 0; ui < sData.m_uiDrawingModelsSize; ++ui)
traverseDrawing(sData.m_ppDrawingModels[ui], part);
A3DAsmPartDefinitionGet(NULL, &sData);
}
else
{
part->SetAttribute("error", iRet);
}
traverseMaterialProperties(pPart, part);
xmlfather->LinkEndChild(part);
return A3D_SUCCESS;
}
//######################################################################################################################
static int stTraverseFilter(const A3DAsmFilter* pFilter, _TiXmlElement* setting)
{
A3DInt32 iRet = A3D_SUCCESS;
A3DAsmFilterData sData;
A3D_INITIALIZE_DATA(A3DAsmFilterData, sData);
_TiXmlElement* filter = new _TiXmlElement("A3DAsmFilterData");
traverseSource(pFilter, filter);
iRet = A3DAsmFilterGet(pFilter, &sData);
if(iRet == A3D_SUCCESS)
{
filter->SetAttribute("active", (int) sData.m_bIsActive);
A3DAsmFilterGet(NULL, &sData);
}
else
{
filter->SetAttribute("error", iRet);
}
setting->LinkEndChild(filter);
return iRet;
}
//######################################################################################################################
int traverseEntityReference(const A3DMiscEntityReference* pEntityReference, _TiXmlElement* setting)
{
A3DInt32 iRet = A3D_SUCCESS;
A3DMiscEntityReferenceData sData;
A3D_INITIALIZE_DATA(A3DMiscEntityReferenceData, sData);
_TiXmlElement* entityreference = new _TiXmlElement("A3DMiscEntityReferenceData");
traverseSource(pEntityReference, entityreference);
iRet = A3DMiscEntityReferenceGet(pEntityReference, &sData);
if (iRet != A3D_SUCCESS || sData.m_pEntity == NULL)
{
entityreference->SetAttribute("error", iRet);
setting->LinkEndChild(entityreference);
return iRet;
}
_TiXmlElement* entity = new _TiXmlElement("m_pEntity");
_SetAttributePtr(entity, "Address", (void*)sData.m_pEntity);
entityreference->LinkEndChild(entity);
if (sData.m_pCoordinateSystem != NULL)
iRet = traverseCSys(sData.m_pCoordinateSystem, entityreference);
A3DEEntityType eType = kA3DTypeUnknown;
iRet = A3DEntityGetType(sData.m_pEntity, &eType);
if (iRet != A3D_SUCCESS)
{
entityreference->SetAttribute("error_A3DEntityGetType", iRet);
setting->LinkEndChild(entityreference);
return iRet;
}
if (eType == kA3DTypeMiscReferenceOnTopology)
{
A3DMiscReferenceOnTopologyData sReferenceOnTopologyData;
A3D_INITIALIZE_DATA(A3DMiscReferenceOnTopologyData, sReferenceOnTopologyData);
if(A3DMiscReferenceOnTopologyGet((A3DMiscReferenceOnTopology*) sData.m_pEntity, &sReferenceOnTopologyData) != A3D_SUCCESS)
{
entityreference->SetAttribute("error_A3DMiscReferenceOnTopologyGet", iRet);
setting->LinkEndChild(entityreference);
return iRet;
}
switch(sReferenceOnTopologyData.m_eTopoItemType)
{
case kA3DTypeTopoEdge:
entityreference->SetAttribute("topotype", "Edge");
if(sReferenceOnTopologyData.m_uiSize != 3)
{
entityreference->SetAttribute("ref_count", "error");
break;
}
entityreference->SetAttribute("face_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[0]);
entityreference->SetAttribute("loop_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[1]);
entityreference->SetAttribute("edge_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[2]);
break;
case kA3DTypeTopoCoEdge:
entityreference->SetAttribute("topotype", "CoEdge");
if(sReferenceOnTopologyData.m_uiSize != 3)
{
entityreference->SetAttribute("ref_count", "error");
break;
}
entityreference->SetAttribute("face_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[0]);
entityreference->SetAttribute("loop_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[1]);
entityreference->SetAttribute("coedge_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[2]);
break;
case kA3DTypeTopoFace:
entityreference->SetAttribute("topotype", "Face");
if(sReferenceOnTopologyData.m_uiSize != 1)
{
entityreference->SetAttribute("ref_count", "error");
break;
}
entityreference->SetAttribute("face_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[0]);
break;
case kA3DTypeTopoUniqueVertex:
entityreference->SetAttribute("topotype", "Unique Vertex");
if(sReferenceOnTopologyData.m_uiSize != 4)
{
entityreference->SetAttribute("ref_count", "error");
break;
}
entityreference->SetAttribute("face_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[0]);
entityreference->SetAttribute("loop_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[1]);
entityreference->SetAttribute("edge_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[2]);
entityreference->SetAttribute("vertex_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[3]);
break;
case kA3DTypeTopoMultipleVertex:
entityreference->SetAttribute("topotype", "Multiple Vertex");
if(sReferenceOnTopologyData.m_uiSize%3 != 0)
{
entityreference->SetAttribute("ref_count", "error");
break;
}
entityreference->SetAttribute("ref_count", "todo");
entityreference->SetAttribute("face_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[0]);
entityreference->SetAttribute("loop_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[1]);
entityreference->SetAttribute("edge_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[2]);
entityreference->SetAttribute("vertex_indice", sReferenceOnTopologyData.m_puiAdditionalIndexes[3]);
break;
default:
entityreference->SetAttribute("linked_item_topo_reference", "unexpected");
break;
}
A3DMiscReferenceOnTopologyGet(nullptr, &sReferenceOnTopologyData);
}
else if(eType == kA3DTypeMiscReferenceOnCsysItem)
{
A3DMiscReferenceOnCsysItemData sA3DMiscReferenceOnCSYSITemData;
A3D_INITIALIZE_DATA(A3DMiscReferenceOnCsysItemData, sA3DMiscReferenceOnCSYSITemData);
iRet = A3DMiscReferenceOnCsysItemGet(sData.m_pEntity, &sA3DMiscReferenceOnCSYSITemData);
if(iRet!=A3D_SUCCESS || !sA3DMiscReferenceOnCSYSITemData.m_pCoordinateSystem)
{
entityreference->SetAttribute("error_A3DMiscReferenceOnCsysItemGet", iRet);
setting->LinkEndChild(entityreference);
A3DMiscReferenceOnCsysItemGet(nullptr, &sA3DMiscReferenceOnCSYSITemData);
return iRet;
}
A3DRootBaseData sCSYSRootData;
A3D_INITIALIZE_DATA(A3DRootBaseData, sCSYSRootData);
if( A3DRootBaseGet(sA3DMiscReferenceOnCSYSITemData.m_pCoordinateSystem, &sCSYSRootData)== A3D_SUCCESS)
{
entityreference->SetAttribute("cys_name", (sCSYSRootData.m_pcName && sCSYSRootData.m_pcName[0] != '\0')?sCSYSRootData.m_pcName:"NULL");
entityreference->SetAttribute("index", sA3DMiscReferenceOnCSYSITemData.m_uiIndex);
}
A3DMiscReferenceOnCsysItemGet(nullptr, &sA3DMiscReferenceOnCSYSITemData);
}
else
{
A3DRootBaseData sBaseData;
A3D_INITIALIZE_DATA(A3DRootBaseData, sBaseData);
iRet = A3DRootBaseGet(sData.m_pEntity,&sBaseData);
if(iRet == A3D_SUCCESS)
{
if(sBaseData.m_pcName && sBaseData.m_pcName[0] != '\0')
entityreference->SetAttribute("name", sBaseData.m_pcName);
A3DRootBaseGet(NULL,&sBaseData);
}
if (eType == kA3DTypeRiPolyBrepModel)
{
A3DMiscReferenceOnTessData sReferenceOnTessData;
A3D_INITIALIZE_DATA(A3DMiscReferenceOnTessData, sReferenceOnTessData);
if (A3DMiscReferenceOnTessGet(pEntityReference, &sReferenceOnTessData) == A3D_SUCCESS)
{
switch(sReferenceOnTessData.m_eTopoItemType)
{
case kA3DTypeTessFace:
entityreference->SetAttribute("topotype", "Face");
if (sReferenceOnTessData.m_uiSize == 0)
entityreference->SetAttribute("ref_count", "error");
for (A3DUns32 iFace=0;iFace<sReferenceOnTessData.m_uiSize;iFace++)
entityreference->SetAttribute("face_indice", sReferenceOnTessData.m_puiAdditionalIndexes[iFace]);
break;
case kA3DTypeTessEdge:
entityreference->SetAttribute("topotype", "Edge");
if (sReferenceOnTessData.m_uiSize != 3)
entityreference->SetAttribute("ref_count", "error");
else
{
entityreference->SetAttribute("face_indice", sReferenceOnTessData.m_puiAdditionalIndexes[0]);
entityreference->SetAttribute("loop_indice", sReferenceOnTessData.m_puiAdditionalIndexes[1]);
entityreference->SetAttribute("edge_indice", sReferenceOnTessData.m_puiAdditionalIndexes[2]);
}
break;
case kA3DTypeTessVertex:
entityreference->SetAttribute("topotype", "Vertex");
if (sReferenceOnTessData.m_uiSize != 4)
entityreference->SetAttribute("ref_count", "error");
else
{
entityreference->SetAttribute("face_indice" , sReferenceOnTessData.m_puiAdditionalIndexes[0]);
entityreference->SetAttribute("loop_indice" , sReferenceOnTessData.m_puiAdditionalIndexes[1]);
entityreference->SetAttribute("edge_indice" , sReferenceOnTessData.m_puiAdditionalIndexes[2]);
entityreference->SetAttribute("vertex_indice", sReferenceOnTessData.m_puiAdditionalIndexes[3]);
}
break;
default: break;
}
A3DMiscReferenceOnTessGet(NULL, &sReferenceOnTessData);
}
}
else if(eType == kA3DTypeRiPlane)
{
A3DMiscMarkupLinkedItem* pLinkedItem = NULL;
A3DRiPlaneSupportGet((const A3DRiPlane*) sData.m_pEntity, &pLinkedItem);
if( pLinkedItem)
{
_TiXmlElement* entityreferencesupport = new _TiXmlElement("SUPPORT");
entityreference->LinkEndChild(entityreferencesupport);
traverseEntityReference(pLinkedItem, entityreferencesupport);
}
}
else if(eType == kA3DTypeRiCurve)
{
A3DMiscMarkupLinkedItem* pLinkedItem = NULL;
A3DRiCurveSupportGet((const A3DRiCurve*) sData.m_pEntity, &pLinkedItem);
if( pLinkedItem)
{
_TiXmlElement* entityreferencesupport = new _TiXmlElement("SUPPORT");
entityreference->LinkEndChild(entityreferencesupport);
traverseEntityReference(pLinkedItem, entityreferencesupport);
}
}
}
A3DMiscEntityReferenceGet(NULL, &sData);
setting->LinkEndChild(entityreference);
return iRet;
}
//######################################################################################################################
static int traverseMaterialAndVis(const A3DMaterialAndVisualisationInfos& oMatVis, _TiXmlElement* setting)
{
setting->SetAttribute("m_bIsSuppressed", oMatVis.m_bIsSuppressed);
setting->SetAttribute("m_usLayer", oMatVis.m_usLayer);
setting->SetAttribute("m_usBehaviour", oMatVis.m_usBehaviour);
setting->SetAttribute("m_ucType", oMatVis.m_ucType);
for (A3DUns32 i = 0; i < oMatVis.m_uiPathInAssemblyTreeSize; i++)
{
A3DUTF8Char* acValue = oMatVis.m_ppPathInAssemblyTree[i];
char acBuffer[32];
sprintf(acBuffer, "m_ppPathInAssemblyTree_%d", i);
setting->SetAttribute(acBuffer, acValue ? acValue : "");
}
if (oMatVis.m_pMaterial)
traverseMaterial(*oMatVis.m_pMaterial, setting);
if (oMatVis.m_pTransform)
traverseCartesianTransformationData(*oMatVis.m_pTransform, setting);
return 0;
}
//######################################################################################################################
static int stTraversePOccurrence(const A3DAsmProductOccurrence* pOccurrence, _TiXmlElement* setting)
{
A3DInt32 iRet = A3D_SUCCESS;
A3DAsmProductOccurrenceData sData;
A3D_INITIALIZE_DATA(A3DAsmProductOccurrenceData, sData);
_TiXmlElement* occurrence = new _TiXmlElement("A3DAsmProductOccurrenceData");
traverseSource(pOccurrence, occurrence);
A3DRootBaseData sRootBaseData;
A3D_INITIALIZE_DATA(A3DRootBaseData, sRootBaseData);
iRet = A3DRootBaseGet(pOccurrence, &sRootBaseData);
if (iRet == A3D_SUCCESS)
{
if (sRootBaseData.m_pcName && sRootBaseData.m_pcName[0] != '\0')
occurrence->SetAttribute("m_pcName", sRootBaseData.m_pcName);
A3DRootBaseGet(NULL, &sRootBaseData);
}
iRet = A3DAsmProductOccurrenceGet(pOccurrence, &sData);
if (iRet == A3D_SUCCESS)
{
A3DUns32 ui;
occurrence->SetAttribute("m_ucBehaviour", (int)(sData.m_ucBehaviour));
occurrence->SetAttribute("m_eProductLoadStatus", (int)(sData.m_eProductLoadStatus));
occurrence->SetAttribute("m_uiProductFlags", (int)(sData.m_uiProductFlags));
occurrence->SetAttribute("m_bUnitFromCAD", (int)(sData.m_bUnitFromCAD));
occurrence->SetDoubleAttribute("m_dUnit", (double)(sData.m_dUnit));
occurrence->SetDoubleAttribute("m_dDensityVolumeUnit", sData.m_dDensityVolumeUnit);
occurrence->SetDoubleAttribute("m_dDensityMassUnit", sData.m_dDensityMassUnit);
occurrence->SetAttribute("m_eModellerType", sData.m_eModellerType);
occurrence->SetAttribute("m_bInactivateAnnotations", sData.m_bInactivateAnnotations ? "true" : "false");
traverseTransformation(sData.m_pLocation, occurrence);
if (sData.m_uiDisplayFilterSize && sData.m_ppDisplayFilters)
{
_TiXmlElement* displayfilters = new _TiXmlElement("DisplayFilters");
traverseDisplayFilters(sData.m_uiDisplayFilterSize, sData.m_ppDisplayFilters, displayfilters);
occurrence->LinkEndChild(displayfilters);
}
A3DUns32 uiLayers=0;
A3DAsmLayer* asLayers = 0;
if (A3DAsmProductOccurrenceGetLayerList(pOccurrence,&uiLayers,&asLayers) == A3D_SUCCESS)
{
if (uiLayers)
{
_TiXmlElement * pLayers = new _TiXmlElement("Layers");
for (A3DUns32 i = 0; i < uiLayers; ++i)
{
_TiXmlElement * Layer = new _TiXmlElement("Layer");
Layer->SetAttribute("Name", asLayers[i].m_pcLayerName ? asLayers[i].m_pcLayerName : "null");
Layer->SetAttribute("Layer", asLayers[i].m_usLayer);
pLayers->LinkEndChild(Layer);
}
occurrence->LinkEndChild(pLayers);
}
A3DAsmProductOccurrenceGetLayerList(0, &uiLayers, &asLayers);
}
if (sData.m_pPrototype)
{
_TiXmlElement* occurrenceproto = new _TiXmlElement("m_pPrototype");
stTraversePOccurrence(sData.m_pPrototype, occurrenceproto);
occurrence->LinkEndChild(occurrenceproto);
}
//else // this is commented but beware http://docs.techsoft3d.com/exchange/latest/build/group__a3d__productoccurrence.html#ga497615eb89393c2aba37cce2e2323f4d
{
A3DUTF8Char* mPOPath = NULL;
iRet = A3DAsmProductOccurrenceGetFilePathName(pOccurrence, &mPOPath);
if (iRet == A3D_SUCCESS)
occurrence->SetAttribute("A3DAsmProductOccurrenceGetFilePathName", mPOPath != NULL ? mPOPath : "");
else
occurrence->SetAttribute("A3DAsmProductOccurrenceGetFilePathName", iRet);
A3DAsmProductOccurrenceGetFilePathName(NULL, &mPOPath);
mPOPath = NULL;
iRet = A3DAsmProductOccurrenceGetOriginalFilePathName(pOccurrence, &mPOPath);
if (iRet == A3D_SUCCESS)
occurrence->SetAttribute("A3DAsmProductOccurrenceGetOriginalFilePathName", mPOPath != NULL ? mPOPath : "");
else
occurrence->SetAttribute("A3DAsmProductOccurrenceGetOriginalFilePathName", iRet);
A3DAsmProductOccurrenceGetOriginalFilePathName(NULL, &mPOPath);
}
if (sData.m_pExternalData)
{
_TiXmlElement* occurrenceexternaldata = new _TiXmlElement("m_pExternalData");
stTraversePOccurrence(sData.m_pExternalData, occurrenceexternaldata);
occurrence->LinkEndChild(occurrenceexternaldata);
}
for (ui = 0; ui < sData.m_uiPOccurrencesSize; ++ui)
stTraversePOccurrence(sData.m_ppPOccurrences[ui], occurrence);
for (ui = 0; ui < sData.m_uiEntityReferenceSize; ++ui)
traverseEntityReference(sData.m_ppEntityReferences[ui], occurrence);
for (ui = 0; ui < sData.m_uiAnnotationsSize; ++ui)
traverseAnnotation(sData.m_ppAnnotations[ui], occurrence);
for (ui = 0; ui < sData.m_uiSceneDisplayParameterSize; ++ui)
traverseGraphScene(sData.m_psSceneDisplayParameters[ui], occurrence);
for (ui = 0; ui < sData.m_uiViewsSize; ++ui)
traverseView(sData.m_ppViews[ui], occurrence);
if (sData.m_pPart)
stTraversePartDef(sData.m_pPart, occurrence);
if (sData.m_pEntityFilter)
stTraverseFilter(sData.m_pEntityFilter, occurrence);
for (ui = 0; ui < sData.m_uiFeatureBasedEntitiesSize; ++ui)
traverseFeatureTree(sData.m_ppFeatureBasedEntities[ui], occurrence);
for (ui = 0; ui < sData.m_uiContraintsSize; ++ui)
traverseConstraint(sData.m_ppConstraints[ui], occurrence);
for (ui = 0; ui < sData.m_uiMaterialAndVisualisationSetupSize; ++ui)
{
_TiXmlElement* materialandvis = new _TiXmlElement("m_psMaterialAndVisualisationSetup");
traverseMaterialAndVis(sData.m_psMaterialAndVisualisationSetup[ui], materialandvis);
occurrence->LinkEndChild(materialandvis);
}
//----------- Export Specific information per CAD format -----------
switch (sData.m_eModellerType)
{
case kA3DModellerUnigraphics:
{
A3DAsmProductOccurrenceDataUg sDataUg;
A3D_INITIALIZE_DATA(A3DAsmProductOccurrenceDataUg, sDataUg);
iRet = A3DAsmProductOccurrenceGetUg(pOccurrence, &sDataUg);
if (iRet == A3D_SUCCESS)
{
_TiXmlElement* occurrencedataug = new _TiXmlElement("A3DAsmProductOccurrenceDataUg");
occurrencedataug->SetAttribute("RootFilePath", sDataUg.m_psRootFilePath ? sDataUg.m_psRootFilePath : "NULL");
occurrencedataug->SetAttribute("FileName", sDataUg.m_psFileName ? sDataUg.m_psFileName : "NULL");
occurrencedataug->SetAttribute("PartUID", sDataUg.m_psPartUID ? sDataUg.m_psPartUID : "NULL");
occurrencedataug->SetAttribute("InstanceFileName", sDataUg.m_psInstanceFileName ? sDataUg.m_psInstanceFileName : "NULL");
occurrencedataug->SetAttribute("InstanceTag", sDataUg.m_uiInstanceTag);
// Treat RefSets
if (sDataUg.m_uiChildrenByRefsetsSize || sDataUg.m_uiSolidsByRefsetsSize)
{
_TiXmlElement* refsetList = new _TiXmlElement("RefSets");
// Children by RefSet
for (A3DUns32 iRefSet = 0; iRefSet < sDataUg.m_uiChildrenByRefsetsSize; ++iRefSet)
{
const A3DElementsByRefsetUg &pRefsetData = sDataUg.m_asChildrenByRefsets[iRefSet];
// Init Xml Element if first occurrence
_TiXmlElement* refset = new _TiXmlElement("RefSet");
refset->SetAttribute("Name", pRefsetData.m_psRefset);
// Add children
for (A3DUns32 i = 0; i < pRefsetData.m_uiElementsSize; ++i)
{
_TiXmlElement * refsetChild = new _TiXmlElement("Child");
refsetChild->SetAttribute("id", pRefsetData.m_auiElements[i]);
refset->LinkEndChild(refsetChild);
}
refsetList->LinkEndChild(refset);
}
// Solid by RefSet
for (A3DUns32 iRefSet = 0; iRefSet < sDataUg.m_uiSolidsByRefsetsSize; ++iRefSet)
{
const A3DElementsByRefsetUg &pRefsetData = sDataUg.m_asSolidsByRefsets[iRefSet];
// Init Xml Element if first occurrence
_TiXmlElement* refset = new _TiXmlElement("RefSet");
refset->SetAttribute("Name", pRefsetData.m_psRefset);
// Add Solid
for (A3DUns32 i = 0; i < pRefsetData.m_uiElementsSize; ++i)
{
_TiXmlElement * refsetChild = new _TiXmlElement("Solid");
refsetChild->SetAttribute("id", pRefsetData.m_auiElements[i]);
refset->LinkEndChild(refsetChild);
}
refsetList->LinkEndChild(refset);
}
occurrencedataug->LinkEndChild(refsetList);
}
occurrence->LinkEndChild(occurrencedataug);
CHECK_RET(A3DAsmProductOccurrenceGetUg(NULL, &sDataUg));
}
break;
}
default:
break;
}
CHECK_RET(A3DAsmProductOccurrenceGet(NULL, &sData));
}
else
{
occurrence->SetAttribute("error", iRet);
}
traverseMaterialProperties(pOccurrence, occurrence);
setting->LinkEndChild(occurrence);
return iRet;
}
//######################################################################################################################
int traverseModel(const A3DAsmModelFile* pModelFile, _TiXmlElement* setting)
{
A3DInt32 iRet = A3D_SUCCESS;
A3DAsmModelFileData sData;
A3D_INITIALIZE_DATA(A3DAsmModelFileData, sData);
_TiXmlElement* model = new _TiXmlElement("A3DAsmModelFileData");
traverseSource(pModelFile, model);
iRet = A3DAsmModelFileGet(pModelFile , &sData);
if(iRet == A3D_SUCCESS)
{
A3DUns32 ui;
model->SetAttribute("m_bUnitFromCAD", sData.m_bUnitFromCAD);
model->SetDoubleAttribute("m_dUnit", sData.m_dUnit);
model->SetAttribute("m_eModellerType", sData.m_eModellerType);
dumpRelationships(sData.m_pBIMData, model);
for(ui = 0; ui < sData.m_uiPOccurrencesSize; ++ui)
stTraversePOccurrence(sData.m_ppPOccurrences[ui], model);
CHECK_RET(A3DAsmModelFileGet(NULL, &sData));
}
else
{
model->SetAttribute("error", iRet);
}
setting->LinkEndChild(model);
return iRet;
}