// Created on: 2017-06-16 // Created by: Natalia ERMOLAEVA // Copyright (c) 2017 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #if OCC_VERSION_HEX > 0x060901 #include #include #endif #include #include #include #include #include #include #include // ======================================================================= // function : GetAttributeInfo // purpose : // ======================================================================= TCollection_AsciiString DFBrowserPaneXDE_XDEDRAW::GetAttributeInfo (Handle(TDF_Attribute) att) { TCollection_AsciiString anInfo; if ( att->IsKind(STANDARD_TYPE (TDataStd_TreeNode)) ) { Standard_CString type = ""; if ( att->ID() == XCAFDoc::ShapeRefGUID() ) type = "Shape Instance Link"; else if ( att->ID() == XCAFDoc::ColorRefGUID(XCAFDoc_ColorGen) ) type = "Generic Color Link"; else if ( att->ID() == XCAFDoc::ColorRefGUID(XCAFDoc_ColorSurf) ) type = "Surface Color Link"; else if ( att->ID() == XCAFDoc::ColorRefGUID(XCAFDoc_ColorCurv) ) type = "Curve Color Link"; else if ( att->ID() == XCAFDoc::DimTolRefGUID() ) type = "DGT Link"; else if ( att->ID() == XCAFDoc::DatumRefGUID() ) type = "Datum Link"; else if ( att->ID() == XCAFDoc::MaterialRefGUID() ) type = "Material Link"; Handle(TDataStd_TreeNode) TN = Handle(TDataStd_TreeNode)::DownCast (att); TCollection_AsciiString ref; if ( TN->HasFather() ) { TDF_Tool::Entry ( TN->Father()->Label(), ref ); anInfo = type; anInfo += TCollection_AsciiString (" ==> ") + ref.ToCString(); } else { anInfo = type; anInfo += TCollection_AsciiString (" <== (") + ref.ToCString(); Handle(TDataStd_TreeNode) child = TN->First(); while ( ! child.IsNull() ) { TDF_Tool::Entry ( child->Label(), ref ); if ( child != TN->First() ) anInfo += ", " ; anInfo += ref.ToCString(); child = child->Next(); } anInfo += ")"; } } else if ( att->IsKind(STANDARD_TYPE (TDF_Reference)) ) { Handle(TDF_Reference) val = Handle(TDF_Reference)::DownCast ( att ); TCollection_AsciiString ref; TDF_Tool::Entry ( val->Get(), ref ); anInfo += TCollection_AsciiString ("==> ") + ref.ToCString(); } else if ( att->IsKind(STANDARD_TYPE (TDataStd_Integer)) ) { Handle(TDataStd_Integer) val = Handle(TDataStd_Integer)::DownCast ( att ); anInfo = TCollection_AsciiString ( val->Get() ); } else if ( att->IsKind(STANDARD_TYPE (TDataStd_Real)) ) { Handle(TDataStd_Real) val = Handle(TDataStd_Real)::DownCast ( att ); anInfo = TCollection_AsciiString ( val->Get() ); } else if ( att->IsKind(STANDARD_TYPE (TDataStd_Name)) ) { Handle(TDataStd_Name) val = Handle(TDataStd_Name)::DownCast ( att ); anInfo = TCollection_AsciiString ( val->Get(), '?' ); } else if ( att->IsKind(STANDARD_TYPE (TDataStd_Comment)) ) { Handle(TDataStd_Comment) val = Handle(TDataStd_Comment)::DownCast ( att ); anInfo = TCollection_AsciiString ( val->Get(), '?' ); } else if ( att->IsKind(STANDARD_TYPE (TDataStd_AsciiString)) ) { Handle(TDataStd_AsciiString) val = Handle(TDataStd_AsciiString)::DownCast ( att ); anInfo = TCollection_AsciiString ( val->Get(), '?' ); } else if ( att->IsKind(STANDARD_TYPE (TDataStd_IntegerArray)) ) { Handle(TDataStd_IntegerArray) val = Handle(TDataStd_IntegerArray)::DownCast ( att ); for ( Standard_Integer j=val->Lower(); j <= val->Upper(); j++ ) { if ( j > val->Lower() ) anInfo += TCollection_AsciiString ( ", " ); anInfo += TCollection_AsciiString ( val->Value(j) ); } } else if ( att->IsKind(STANDARD_TYPE (TDataStd_RealArray)) ) { Handle(TDataStd_RealArray) val = Handle(TDataStd_RealArray)::DownCast ( att ); for ( Standard_Integer j=val->Lower(); j <= val->Upper(); j++ ) { if ( j > val->Lower() ) anInfo += TCollection_AsciiString ( ", " ); anInfo += TCollection_AsciiString ( val->Value(j) ); } } else if ( att->IsKind(STANDARD_TYPE (TDataStd_ByteArray)) ) { Handle(TDataStd_ByteArray) val = Handle(TDataStd_ByteArray)::DownCast ( att ); for ( Standard_Integer j=val->Lower(); j <= val->Upper(); j++ ) { if ( j > val->Lower() ) anInfo += TCollection_AsciiString ( ", " ); anInfo += TCollection_AsciiString ( val->Value(j) ); } } else if ( att->IsKind(STANDARD_TYPE (TNaming_NamedShape)) ) { Handle(TNaming_NamedShape) val = Handle(TNaming_NamedShape)::DownCast ( att ); TopoDS_Shape S = val->Get(); if (!S.IsNull()) anInfo = S.TShape()->DynamicType()->Name(); else anInfo = "Empty Shape"; if ( ! S.Location().IsIdentity() ) anInfo += TCollection_AsciiString ( "(located)" ); } else if ( att->IsKind(STANDARD_TYPE (XCAFDoc_Volume)) ) { Handle(XCAFDoc_Volume) val = Handle(XCAFDoc_Volume)::DownCast ( att ); anInfo += TCollection_AsciiString ( val->Get() ); } else if ( att->IsKind(STANDARD_TYPE (XCAFDoc_Area)) ) { Handle(XCAFDoc_Area) val = Handle(XCAFDoc_Area)::DownCast ( att ); TCollection_AsciiString str ( val->Get() ); anInfo = str.ToCString(); } else if ( att->IsKind(STANDARD_TYPE (XCAFDoc_Centroid)) ) { Handle(XCAFDoc_Centroid) val = Handle(XCAFDoc_Centroid)::DownCast ( att ); gp_Pnt myCentroid = val->Get(); anInfo = "(" ; anInfo += TCollection_AsciiString ( myCentroid.X() ).ToCString(); anInfo += TCollection_AsciiString ( " , " ); anInfo += TCollection_AsciiString ( TCollection_AsciiString ( myCentroid.Y() ).ToCString() ); anInfo += TCollection_AsciiString ( " , " ); anInfo += TCollection_AsciiString ( myCentroid.Z() ).ToCString(); anInfo += TCollection_AsciiString ( ")" ); } else if ( att->IsKind(STANDARD_TYPE (TDataStd_UAttribute)) ) { if ( att->ID() == XCAFDoc::AssemblyGUID() ) anInfo += TCollection_AsciiString ( "is assembly" ); if ( att->ID() == XCAFDoc::InvisibleGUID() ) anInfo += TCollection_AsciiString ( "invisible" ); } else if ( att->IsKind(STANDARD_TYPE (XCAFDoc_Color)) ) { Handle(XCAFDoc_Color) val = Handle(XCAFDoc_Color)::DownCast ( att ); Quantity_Color C = val->GetColor(); char string[260]; Sprintf ( string, "%s (%g, %g, %g)", C.StringName ( C.Name() ), C.Red(), C.Green(), C.Blue() ); anInfo = string; } else if ( att->IsKind(STANDARD_TYPE (XCAFDoc_DimTol)) ) { Handle(XCAFDoc_DimTol) val = Handle(XCAFDoc_DimTol)::DownCast ( att ); Standard_Integer kind = val->GetKind(); Handle(TColStd_HArray1OfReal) HAR = val->GetVal(); if(kind<20) { //dimension anInfo = "Diameter (ValueRange["; anInfo += TCollection_AsciiString ( HAR->Value(1) ); anInfo += TCollection_AsciiString ( "," ); anInfo += TCollection_AsciiString ( HAR->Value(2) ); anInfo += TCollection_AsciiString ( "])" ); } else { switch (kind) { case 21: anInfo = "GeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol_1"; break; case 22: anInfo = "GeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol_2"; break; case 23: anInfo = "GeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol_3"; break; case 24: anInfo = "AngularityTolerance"; break; case 25: anInfo = "CircularRunoutTolerance"; break; case 26: anInfo = "CoaxialityTolerance"; break; case 27: anInfo = "ConcentricityTolerance"; break; case 28: anInfo = "ParallelismTolerance"; break; case 29: anInfo = "PerpendicularityTolerance"; break; case 30: anInfo = "SymmetryTolerance"; break; case 31: anInfo = "TotalRunoutTolerance"; break; case 35: anInfo = "ModifiedGeometricTolerance_1"; break; case 36: anInfo = "ModifiedGeometricTolerance_2"; break; case 37: anInfo = "ModifiedGeometricTolerance_3"; break; case 38: anInfo = "CylindricityTolerance"; break; case 39: anInfo = "FlatnessTolerance"; break; case 40: anInfo = "LineProfileTolerance"; break; case 41: anInfo = "PositionTolerance"; break; case 42: anInfo = "RoundnessTolerance"; break; case 43: anInfo = "StraightnessTolerance"; break; case 44: anInfo = "SurfaceProfileTolerance"; break; } if (anInfo.Length() > 0) { anInfo += " (Value="; anInfo += TCollection_AsciiString (HAR->Value (1)); anInfo += ")"; } } } else if ( att->IsKind(STANDARD_TYPE (XCAFDoc_Material)) ) { Handle(XCAFDoc_Material) val = Handle(XCAFDoc_Material)::DownCast ( att ); Standard_Real dens = val->GetDensity(); Standard_CString dimdens = "g/cu sm"; if(dens==0) anInfo = val->GetName()->ToCString(); else { anInfo = val->GetName()->ToCString(); anInfo += "(density="; anInfo += TCollection_AsciiString ( dens ); anInfo += dimdens; anInfo += ")"; } } else if ( att->IsKind(STANDARD_TYPE (XCAFDoc_GraphNode)) ) { Standard_CString type; if ( att->ID() == XCAFDoc::LayerRefGUID() ) { type = "Layer Instance Link"; } else if ( att->ID() == XCAFDoc::SHUORefGUID() ) { type = "SHUO Instance Link"; } else if ( att->ID() == XCAFDoc::DatumTolRefGUID() ) { type = "DatumToler Link"; } #if OCC_VERSION_HEX > 0x060901 else if ( att->ID() == XCAFDoc::DimensionRefFirstGUID() ) { type = "Dimension Link First"; } else if ( att->ID() == XCAFDoc::DimensionRefSecondGUID() ) { type = "Dimension Link Second"; } else if ( att->ID() == XCAFDoc::GeomToleranceRefGUID() ){ type = "GeomTolerance Link"; } #endif else return TCollection_AsciiString(); Handle(XCAFDoc_GraphNode) DETGN = Handle(XCAFDoc_GraphNode)::DownCast (att); TCollection_AsciiString ref; Standard_Integer ii = 1; if (DETGN->NbFathers()!=0) { TDF_Tool::Entry ( DETGN->GetFather(ii)->Label(), ref ); anInfo = type; anInfo += " ==> ("; anInfo += ref; for (ii = 2; ii <= DETGN->NbFathers(); ii++) { TDF_Tool::Entry ( DETGN->GetFather(ii)->Label(), ref ); anInfo += ", "; anInfo += ref.ToCString(); } anInfo += ") "; } ii = 1; if (DETGN->NbChildren ()!=0) { TDF_Tool::Entry ( DETGN->GetChild(ii)->Label(), ref ); anInfo += type; anInfo += " <== ("; anInfo += ref; for (ii = 2; ii <= DETGN->NbChildren (); ii++) { TDF_Tool::Entry ( DETGN->GetChild(ii)->Label(), ref ); anInfo += ", "; anInfo += ref; } anInfo += ") "; } } return anInfo; }