STEP export: make use of footprint names instead of "SOLID".

Should help when importing into software that does deduplication
based on label names (e.g. SolidWorks).
This commit is contained in:
Alex Shvartzkop 2023-11-21 14:11:16 +03:00
parent a3a2f43f6c
commit 58b9d68084
1 changed files with 16 additions and 3 deletions

View File

@ -1491,7 +1491,7 @@ bool STEP_PCB_MODEL::readSTEP( Handle( TDocStd_Document )& doc, const char* fnam
// set other translation options // set other translation options
reader.SetColorMode( true ); // use model colors reader.SetColorMode( true ); // use model colors
reader.SetNameMode( false ); // don't use label names reader.SetNameMode( true ); // use label names
reader.SetLayerMode( false ); // ignore LAYER data reader.SetLayerMode( false ); // ignore LAYER data
if( !reader.Transfer( doc ) ) if( !reader.Transfer( doc ) )
@ -1543,10 +1543,17 @@ TDF_Label STEP_PCB_MODEL::transferModel( Handle( TDocStd_Document )& source,
while( id <= nshapes ) while( id <= nshapes )
{ {
TopoDS_Shape shape = s_assy->GetShape( frshapes.Value( id ) ); const TDF_Label& s_shapeLabel = frshapes.Value( id );
TopoDS_Shape shape = s_assy->GetShape( s_shapeLabel );
if( !shape.IsNull() ) if( !shape.IsNull() )
{ {
Handle( TDataStd_Name ) s_nameAttr;
s_shapeLabel.FindAttribute( TDataStd_Name::GetID(), s_nameAttr );
TCollection_ExtendedString s_labelName =
s_nameAttr ? s_nameAttr->Get() : TCollection_ExtendedString();
TopoDS_Shape scaled_shape( shape ); TopoDS_Shape scaled_shape( shape );
if( aScale.x != 1.0 || aScale.y != 1.0 || aScale.z != 1.0 ) if( aScale.x != 1.0 || aScale.y != 1.0 || aScale.z != 1.0 )
@ -1565,7 +1572,13 @@ TDF_Label STEP_PCB_MODEL::transferModel( Handle( TDocStd_Document )& source,
} }
} }
TDF_Label niulab = d_assy->AddComponent( component, scaled_shape, Standard_False ); TDF_Label d_shapeLabel = d_assy->AddShape( scaled_shape, Standard_False );
if( s_labelName.Length() > 0 )
TDataStd_Name::Set( d_shapeLabel, s_labelName );
TDF_Label niulab =
d_assy->AddComponent( component, d_shapeLabel, scaled_shape.Location() );
// check for per-surface colors // check for per-surface colors
stop.Init( shape, TopAbs_FACE ); stop.Init( shape, TopAbs_FACE );