Export VRML: fix bug that prevent to merge 3D footprint shapes to the board file.
Fixes #9127 https://gitlab.com/kicad/code/kicad/issues/9127
This commit is contained in:
parent
1a43515128
commit
5e742d97b6
|
@ -775,10 +775,12 @@ static void compose_quat( double q1[4], double q2[4], double qr[4] )
|
||||||
|
|
||||||
void EXPORTER_PCB_VRML::ExportVrmlFootprint( FOOTPRINT* aFootprint, std::ostream* aOutputFile )
|
void EXPORTER_PCB_VRML::ExportVrmlFootprint( FOOTPRINT* aFootprint, std::ostream* aOutputFile )
|
||||||
{
|
{
|
||||||
wxCHECK( aFootprint && aOutputFile, /* void */ );
|
// Note: if m_UseInlineModelsInBrdfile is false, the 3D footprint shape is copied to
|
||||||
|
// the vrml board file, and aOutputFile is not used (can be nullptr)
|
||||||
int old_precision = aOutputFile->precision();
|
// if m_UseInlineModelsInBrdfile is true, the 3D footprint shape is copied to
|
||||||
aOutputFile->precision( m_precision );
|
// aOutputFile (with the suitable rotation/translation/scale transform, and the vrml board
|
||||||
|
// file contains only the filename of 3D shapes to add to the full vrml scene
|
||||||
|
wxCHECK( aFootprint, /* void */ );
|
||||||
|
|
||||||
// Export pad holes
|
// Export pad holes
|
||||||
for( PAD* pad : aFootprint->Pads() )
|
for( PAD* pad : aFootprint->Pads() )
|
||||||
|
@ -854,6 +856,11 @@ void EXPORTER_PCB_VRML::ExportVrmlFootprint( FOOTPRINT* aFootprint, std::ostream
|
||||||
|
|
||||||
if( m_UseInlineModelsInBrdfile )
|
if( m_UseInlineModelsInBrdfile )
|
||||||
{
|
{
|
||||||
|
wxCHECK( aOutputFile, /* void */ );
|
||||||
|
|
||||||
|
int old_precision = aOutputFile->precision();
|
||||||
|
aOutputFile->precision( m_precision );
|
||||||
|
|
||||||
wxFileName srcFile = m_Cache3Dmodels->GetResolver()->ResolvePath( sM->m_Filename );
|
wxFileName srcFile = m_Cache3Dmodels->GetResolver()->ResolvePath( sM->m_Filename );
|
||||||
wxFileName dstFile;
|
wxFileName dstFile;
|
||||||
dstFile.SetPath( m_Subdir3DFpModels );
|
dstFile.SetPath( m_Subdir3DFpModels );
|
||||||
|
@ -923,6 +930,8 @@ void EXPORTER_PCB_VRML::ExportVrmlFootprint( FOOTPRINT* aFootprint, std::ostream
|
||||||
fn.Replace( "\\", "/" );
|
fn.Replace( "\\", "/" );
|
||||||
(*aOutputFile) << TO_UTF8( fn ) << "\"\n } ]\n";
|
(*aOutputFile) << TO_UTF8( fn ) << "\"\n } ]\n";
|
||||||
(*aOutputFile) << " }\n";
|
(*aOutputFile) << " }\n";
|
||||||
|
|
||||||
|
aOutputFile->precision( old_precision );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -949,8 +958,6 @@ void EXPORTER_PCB_VRML::ExportVrmlFootprint( FOOTPRINT* aFootprint, std::ostream
|
||||||
|
|
||||||
++sM;
|
++sM;
|
||||||
}
|
}
|
||||||
|
|
||||||
aOutputFile->precision( old_precision );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue