26#include <wx/stdpaths.h>
27#include <wx/process.h>
29#include <wx/filedlg.h>
99 const wxString& aBoardPath,
102 m_editFrame( aEditFrame ),
104 m_boardPath( aBoardPath )
106 if(
m_job ==
nullptr )
110 { wxID_CANCEL,
_(
"Close" ) } } );
116 { wxID_CANCEL,
_(
"Close" ) } } );
126 brdFile.SetExt( wxT(
"step" ) );
127 path = brdFile.GetFullPath();
186 wxCommandEvent
dummy;
193 tmpStr = wxEmptyString;
234 wxCommandEvent
dummy;
242 tmpStr = wxEmptyString;
248 size_t bad_count = 0;
254 if( model.m_Scale.x != 1.0 || model.m_Scale.y != 1.0 || model.m_Scale.z != 1.0 )
256 bad_scales.Append( wxS(
"\n") );
257 bad_scales.Append( model.m_Filename );
266 if( !bad_scales.empty()
267 && !
Pgm().GetCommonSettings()->m_DoNotShowAgain.scaled_3d_models_warning )
269 wxString extendedMsg =
_(
"Non-unity scaled models:" ) + wxT(
"\n" ) + bad_scales;
272 "Model scaling is not reliable for mechanical export." ),
273 _(
"Model Scale Warning" ), wxOK | wxICON_WARNING );
274 msgDlg.SetExtendedMessage( extendedMsg );
308 catch(
const std::runtime_error& e )
310 wxFAIL_MSG( e.what() );
380 wxFileName autosaveProjFile;
387 "Please save the PCB and try again" ) );
396 autosaveProjFile = brdFile;
397 autosaveProjFile.SetName( autosaveFileName );
398 autosaveProjFile.SetExt(
"kicad_pro" );
402 brdFile.SetName( autosaveFileName );
409 if( !autosaveProjFile.GetFullPath().IsEmpty() )
410 wxRemoveFile( autosaveProjFile.GetFullPath() );
435 wxString
filter =
_(
"STEP files" )
437 +
_(
"Binary glTF files" )
441 +
_(
"BREP (OCCT) files" )
451 wxFileName fn(
Prj().AbsolutePath(
path ) );
453 wxFileDialog dlg(
this,
_(
"3D Model Output File" ), fn.GetPath(), fn.GetFullName(),
filter,
456 if( dlg.ShowModal() == wxID_CANCEL )
459 path = dlg.GetPath();
462 fn = wxFileName(
path );
480 int sepIdx = std::max(
path.Find(
'/',
true ),
path.Find(
'\\',
true ) );
481 int dotIdx =
path.Find(
'.',
true );
483 if( dotIdx == -1 || dotIdx < sepIdx )
484 path <<
'.' << newExt;
486 path =
path.Mid( 0, dotIdx ) <<
'.' << newExt;
518 std::function<bool( wxString* )> textResolver =
519 [&]( wxString* token ) ->
bool
562 case 0: tolerance = 0.001;
break;
564 case 1: tolerance = 0.01;
break;
565 case 2: tolerance = 0.1;
break;
578 chainingEpsilon,
nullptr );
582 _(
"Board outline is missing or not closed using %.3f mm tolerance.\n"
583 "Run DRC for a full analysis." ), tolerance ) );
587 wxFileName fn(
Prj().AbsolutePath(
path ) );
591 msg.Printf(
_(
"File '%s' already exists. Do you want overwrite this file?" ),
594 if( wxMessageBox( msg,
_(
"STEP/GLTF Export" ), wxYES_NO | wxICON_QUESTION,
this ) == wxNO )
598 wxFileName appK2S( wxStandardPaths::Get().GetExecutablePath() );
601 if( appK2S.GetPath().Find(
"/Contents/Applications/pcbnew.app/Contents/MacOS" ) != wxNOT_FOUND )
603 appK2S.AppendDir( wxT(
".." ) );
604 appK2S.AppendDir( wxT(
".." ) );
605 appK2S.AppendDir( wxT(
".." ) );
606 appK2S.AppendDir( wxT(
".." ) );
607 appK2S.AppendDir( wxT(
"MacOS" ) );
610 if( wxGetEnv( wxT(
"KICAD_RUN_FROM_BUILD_DIR" ),
nullptr ) )
612 appK2S.RemoveLastDir();
613 appK2S.AppendDir(
"kicad" );
617 appK2S.SetName( wxT(
"kicad-cli" ) );
620 wxString cmdK2S = wxT(
"\"" );
621 cmdK2S.Append( appK2S.GetFullPath() );
622 cmdK2S.Append( wxT(
"\"" ) );
624 cmdK2S.Append( wxT(
" pcb" ) );
625 cmdK2S.Append( wxT(
" export" ) );
627 cmdK2S.Append( wxT(
" " ) );
631 cmdK2S.Append( wxT(
" --no-unspecified" ) );
634 cmdK2S.Append( wxT(
" --no-dnp" ) );
637 cmdK2S.Append( wxT(
" --subst-models" ) );
640 cmdK2S.Append( wxT(
" --no-optimize-step" ) );
643 cmdK2S.Append( wxT(
" --no-board-body" ) );
646 cmdK2S.Append( wxT(
" --no-components" ) );
649 cmdK2S.Append( wxT(
" --include-tracks" ) );
652 cmdK2S.Append( wxT(
" --include-pads" ) );
655 cmdK2S.Append( wxT(
" --include-zones" ) );
658 cmdK2S.Append( wxT(
" --include-inner-copper" ) );
661 cmdK2S.Append( wxT(
" --include-silkscreen" ) );
664 cmdK2S.Append( wxT(
" --include-soldermask" ) );
667 cmdK2S.Append( wxT(
" --fuse-shapes" ) );
670 cmdK2S.Append( wxT(
" --cut-vias-in-body" ) );
673 cmdK2S.Append( wxT(
" --fill-all-vias" ) );
682 cmdK2S.Append( wxString::Format( wxT(
" --net-filter %c%s%c" ), dblquote,
m_netFilter,
690 wxArrayString components;
693 std::for_each( selection.
begin(), selection.
end(),
696 if( item->Type() == PCB_FOOTPRINT_T )
697 components.push_back( static_cast<FOOTPRINT*>( item )->GetReference() );
700 cmdK2S.Append( wxString::Format( wxT(
" --component-filter %c%s%c" ), dblquote,
701 wxJoin( components,
',' ), dblquote ) );
706 cmdK2S.Append( wxString::Format( wxT(
" --component-filter %c%s%c" ), dblquote,
717 wxFAIL_MSG( wxT(
"Unsupported origin option: how did we get here?" ) );
721 cmdK2S.Append( wxT(
" --drill-origin" ) );
725 cmdK2S.Append( wxT(
" --grid-origin" ) );
741 cmdK2S.Append( wxString::Format( wxT(
" --user-origin=%c%.6fx%.6fmm%c" ),
742 quote, xOrg, yOrg, quote ) );
753 cmdK2S.Append( wxString::Format( wxT(
" --user-origin=%c%.6fx%.6fmm%c" ),
754 quote, xOrg, yOrg, quote ) );
761 cmdK2S.Append( wxString::Format( wxT(
" --min-distance=%c%.3fmm%c" ),
762 quote, tolerance, quote ) );
766 cmdK2S.Append( wxString::Format( wxT(
" -f -o %c%s%c" ),
767 dblquote, fn.GetFullPath(), dblquote ) );
771 cmdK2S.Append( wxString::Format( wxT(
" %c%s%c" ), dblquote,
m_boardPath, dblquote ) );
773 wxLogTrace(
traceKiCad2Step, wxT(
"export step command: %s" ), cmdK2S );
constexpr EDA_IU_SCALE pcbIUScale
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap)
bool ResolveTextVar(wxString *token, int aDepth) const
BOX2I ComputeBoundingBox(bool aBoardEdgesOnly=false) const
Calculate the bounding box containing all board items (or board edge segments).
const FOOTPRINTS & Footprints() const
const wxString & GetFileName() const
constexpr const Vec GetCenter() const
DO_NOT_SHOW_AGAIN m_DoNotShowAgain
Class DIALOG_EXPORT_STEP_BASE.
wxCheckBox * m_cbExportTracks
wxCheckBox * m_cbSubstModels
TEXT_CTRL_EVAL * m_STEP_Xorg
TEXT_CTRL_EVAL * m_STEP_Yorg
wxRadioButton * m_rbOnlySelected
wxRadioButton * m_rbGridOrigin
wxCheckBox * m_cbExportBody
wxCheckBox * m_cbRemoveUnspecified
wxCheckBox * m_cbOverwriteFile
wxCheckBox * m_cbRemoveDNP
wxBoxSizer * bSizerSTEPFile
wxCheckBox * m_cbExportComponents
wxCheckBox * m_cbOptimizeStep
wxCheckBox * m_cbFuseShapes
wxRadioButton * m_rbBoardCenterOrigin
wxTextCtrl * m_outputFileName
wxCheckBox * m_cbExportInnerCopper
wxChoice * m_choiceTolerance
wxChoice * m_STEP_OrgUnitChoice
wxTextCtrl * m_txtNetFilter
wxCheckBox * m_cbExportSoldermask
wxCheckBox * m_cbExportPads
wxChoice * m_choiceFormat
wxCheckBox * m_cbExportZones
wxRadioButton * m_rbAllComponents
wxRadioButton * m_rbUserDefinedOrigin
wxCheckBox * m_cbExportSilkscreen
wxRadioButton * m_rbFilteredComponents
wxCheckBox * m_cbCutViasInBody
wxRadioButton * m_rbDrillAndPlotOrigin
wxTextCtrl * m_txtComponentFilter
STD_BITMAP_BUTTON * m_browseButton
wxCheckBox * m_cbFillAllVias
void onFormatChoice(wxCommandEvent &event) override
STEP_ORIGIN_OPTION GetOriginOption()
static int m_formatLastChoice
static bool m_exportSoldermask
static bool m_cutViasInBody
void OnFmtChoiceOptionChanged()
int GetOrgUnitsChoice() const
void onCbExportComponents(wxCommandEvent &event) override
static bool m_fillAllVias
PCB_EDIT_FRAME * m_editFrame
void OnComponentModeChange(wxCommandEvent &event) override
@ STEP_ORIGIN_BOARD_CENTER
DIALOG_EXPORT_STEP(PCB_EDIT_FRAME *aEditFrame, const wxString &aBoardPath)
static COMPONENT_MODE m_componentMode
void onUpdateXPos(wxUpdateUIEvent &aEvent) override
static bool m_exportComponents
static bool m_exportZones
STEP_ORIGIN_OPTION m_origin
JOB_EXPORT_PCB_3D * m_job
void onExportButton(wxCommandEvent &aEvent) override
static bool m_exportBoardBody
static bool m_exportSilkscreen
static wxString m_componentFilter
static int m_toleranceLastChoice
static bool m_optimizeStep
void onUpdateUnits(wxUpdateUIEvent &aEvent) override
bool GetNoUnspecifiedOption()
static bool m_exportInnerCopper
void onUpdateYPos(wxUpdateUIEvent &aEvent) override
static bool m_exportTracks
void onBrowseClicked(wxCommandEvent &aEvent) override
void SetupStandardButtons(std::map< int, wxString > aLabels={})
void finishDialogSettings()
In all dialogs, we must call the same functions to fix minimal dlg size, the default position and per...
A base class for most all the KiCad significant classes used in schematics and boards.
bool m_IncludeUnspecified
wxString m_ComponentFilter
EXPORTER_STEP_PARAMS m_3dparams
Despite the name; also used for other formats.
void SetOutputPath(const wxString &aPath)
Helper class to create more flexible dialogs, including 'do not show again' checkbox handling.
bool DoNotShowAgain() const
void DoNotShowCheckbox(wxString file, int line)
Checks the 'do not show again' setting for the dialog.
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
Instantiate the current locale within a scope in which you are expecting exceptions to be thrown.
DIALOG_EXPORT_STEP m_ExportStep
PCBNEW_SETTINGS * GetPcbNewSettings() const
PCB_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
The main frame for Pcbnew.
void SetLastPath(LAST_PATH_TYPE aType, const wxString &aLastPath)
Set the path of the last file successfully read.
bool doAutoSave() override
Perform auto save when the board has been modified and not saved within the auto save interval.
void OnExportSTEP(wxCommandEvent &event)
Export the current BOARD to a STEP assembly.
wxString GetLastPath(LAST_PATH_TYPE aType)
Get the last path for a particular type.
bool IsContentModified() const override
Get if the current board has been modified but not saved.
SELECTION & GetCurrentSelection() override
Get the current selection from the canvas area.
virtual COMMON_SETTINGS * GetCommonSettings() const
virtual const wxString AbsolutePath(const wxString &aFileName) const
Fix up aFileName if it is relative to the project's directory to be an absolute path and filename.
void SaveProjectCopy(const wxString &aFullPath, PROJECT *aProject=nullptr)
Saves a copy of the current project under the given path.
Represent a set of closed polygons.
void SetValue(const wxString &aValue) override
Set a new value in evaluator buffer, and display it in the wxTextCtrl.
const wxString ExpandEnvVarSubstitutions(const wxString &aString, const PROJECT *aProject)
Replace any environment variable & text variable references with their values.
wxString ExpandTextVars(const wxString &aSource, const PROJECT *aProject, int aFlags)
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
This file is part of the common library.
bool BuildBoardPolygonOutlines(BOARD *aBoard, SHAPE_POLY_SET &aOutlines, int aErrorMax, int aChainingEpsilon, OUTLINE_ERROR_HANDLER *aErrorHandler, bool aAllowUseArcsInPolygons)
Extract the board outlines and build a closed polygon from lines, arcs and circle items on edge cut l...
static const std::map< wxString, int > c_formatExtToChoice
static const std::vector< wxString > c_formatCommand
static const std::string BrepFileExtension
static const std::string StepFileAbrvExtension
static const std::string XaoFileExtension
static const std::string GltfBinaryFileExtension
static const std::string StlFileExtension
static const std::string AutoSaveFilePrefix
static const std::string PlyFileExtension
static const std::string StepFileExtension
const wxChar *const traceKiCad2Step
Flag to enable KiCad2Step debug tracing.
This file is part of the common library.
std::optional< V > get_opt(const std::map< wxString, V > &aMap, const wxString &aKey)
KICOMMON_API double DoubleValueFromString(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, const wxString &aTextValue, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Function DoubleValueFromString converts aTextValue to a double.
SETTINGS_MANAGER * GetSettingsManager()
PGM_BASE & Pgm()
The global Program "get" accessor.
std::vector< FAB_LAYER_COLOR > dummy
bool scaled_3d_models_warning
constexpr double IUTomm(int iu) const
constexpr int mmToIU(double mm) const
wxLogTrace helper definitions.
VECTOR2< double > VECTOR2D
wxString AddFileExtListToFilter(const std::vector< std::string > &aExts)
Build the wildcard extension file dialog wildcard filter to add to the base message dialog.
Definition of file extensions used in Kicad.
#define FN_NORMALIZE_FLAGS
Default flags to pass to wxFileName::Normalize().