From 763c77eab85a0275299e67488059b79654545bb5 Mon Sep 17 00:00:00 2001 From: Jeff Young Date: Mon, 18 Jul 2022 17:49:50 +0100 Subject: [PATCH] DXF parameters are for DXF (only). Fixes https://gitlab.com/kicad/code/kicad/issues/12021 --- pcbnew/import_gfx/dialog_import_gfx.cpp | 94 ++++++++++++++++--------- pcbnew/import_gfx/dialog_import_gfx.h | 9 +-- pcbnew/import_gfx/svg_import_plugin.cpp | 2 + pcbnew/pcbnew_settings.cpp | 4 +- pcbnew/pcbnew_settings.h | 4 +- 5 files changed, 73 insertions(+), 40 deletions(-) diff --git a/pcbnew/import_gfx/dialog_import_gfx.cpp b/pcbnew/import_gfx/dialog_import_gfx.cpp index ca1374874f..ecfca52ebc 100644 --- a/pcbnew/import_gfx/dialog_import_gfx.cpp +++ b/pcbnew/import_gfx/dialog_import_gfx.cpp @@ -45,7 +45,7 @@ bool DIALOG_IMPORT_GFX::m_shouldGroupItems = true; int DIALOG_IMPORT_GFX::m_layer = Dwgs_User; double DIALOG_IMPORT_GFX::m_scaleImport = 1.0; // Do not change the imported items size int DIALOG_IMPORT_GFX::m_originUnits = 0; // millimeter -int DIALOG_IMPORT_GFX::m_lineWidthUnits = 0; // millimeter +int DIALOG_IMPORT_GFX::m_dxfLineWidthUnits = 0; // millimeter int DIALOG_IMPORT_GFX::m_dxfUnits = 0; // first entry in the dxfUnits map below const std::map dxfUnitsMap = { @@ -86,23 +86,23 @@ DIALOG_IMPORT_GFX::DIALOG_IMPORT_GFX( PCB_BASE_FRAME* aParent, bool aImportAsFoo m_originUnits = 0; m_origin.x = 0.0; // always in mm m_origin.y = 0.0; // always in mm - m_lineWidth = 0.2; // always in mm - m_lineWidthUnits = 0; + m_dxfLineWidth = 0.2; // always in mm + m_dxfLineWidthUnits = 0; auto cfg = m_parent->GetPcbNewSettings(); m_layer = cfg->m_ImportGraphics.layer; m_placementInteractive = cfg->m_ImportGraphics.interactive_placement; m_filename = cfg->m_ImportGraphics.last_file; - m_lineWidth = cfg->m_ImportGraphics.line_width; - m_lineWidthUnits = cfg->m_ImportGraphics.line_width_units; + m_dxfLineWidth = cfg->m_ImportGraphics.dxf_line_width; + m_dxfLineWidthUnits = cfg->m_ImportGraphics.dxf_line_width_units; m_originUnits = cfg->m_ImportGraphics.origin_units; m_origin.x = cfg->m_ImportGraphics.origin_x; m_origin.y = cfg->m_ImportGraphics.origin_y; m_dxfUnits = cfg->m_ImportGraphics.dxf_units; - m_choiceUnitLineWidth->SetSelection( m_lineWidthUnits ); - showPCBdefaultLineWidth(); + m_choiceUnitLineWidth->SetSelection( m_dxfLineWidthUnits ); + showDXFDefaultLineWidth(); m_DxfPcbPositionUnits->SetSelection( m_originUnits ); showPcbImportOffsets(); @@ -132,12 +132,19 @@ DIALOG_IMPORT_GFX::DIALOG_IMPORT_GFX( PCB_BASE_FRAME* aParent, bool aImportAsFoo m_browseButton->SetBitmap( KiBitmap( BITMAPS::small_folder ) ); + wxCommandEvent dummy; + onFilename( dummy ); + SetInitialFocus( m_textCtrlFileName ); SetupStandardButtons(); GetSizer()->Fit( this ); GetSizer()->SetSizeHints( this ); Centre(); + + m_textCtrlFileName->Connect( wxEVT_COMMAND_TEXT_UPDATED, + wxCommandEventHandler( DIALOG_IMPORT_GFX::onFilename ), + NULL, this ); } @@ -148,16 +155,37 @@ DIALOG_IMPORT_GFX::~DIALOG_IMPORT_GFX() cfg->m_ImportGraphics.layer = m_layer; cfg->m_ImportGraphics.interactive_placement = m_placementInteractive; cfg->m_ImportGraphics.last_file = m_filename; - cfg->m_ImportGraphics.line_width = m_lineWidth; - cfg->m_ImportGraphics.line_width_units = m_lineWidthUnits; + cfg->m_ImportGraphics.dxf_line_width = m_dxfLineWidth; + cfg->m_ImportGraphics.dxf_line_width_units = m_dxfLineWidthUnits; cfg->m_ImportGraphics.origin_units = m_originUnits; cfg->m_ImportGraphics.origin_x = m_origin.x; cfg->m_ImportGraphics.origin_y = m_origin.y; cfg->m_ImportGraphics.dxf_units = m_dxfUnits; + + m_textCtrlFileName->Disconnect( wxEVT_COMMAND_TEXT_UPDATED, + wxCommandEventHandler( DIALOG_IMPORT_GFX::onFilename ), + NULL, this ); } -void DIALOG_IMPORT_GFX::DIALOG_IMPORT_GFX::onUnitPositionSelection( wxCommandEvent& event ) +void DIALOG_IMPORT_GFX::onFilename( wxCommandEvent& event ) +{ + bool enableDXFControls = true; + wxString filename = m_textCtrlFileName->GetValue(); + + if( auto plugin = m_gfxImportMgr->GetPluginByExt( wxFileName( filename ).GetExt() ) ) + enableDXFControls = dynamic_cast( plugin.get() ) != nullptr; + + m_staticTextLineWidth->Enable( enableDXFControls ); + m_textCtrlLineWidth->Enable( enableDXFControls ); + m_choiceUnitLineWidth->Enable( enableDXFControls ); + + m_staticTextLineWidth1->Enable( enableDXFControls ); + m_choiceDxfUnits->Enable( enableDXFControls ); +} + + +void DIALOG_IMPORT_GFX::onUnitPositionSelection( wxCommandEvent& event ) { // Collect last entered values: updatePcbImportOffsets_mm(); @@ -167,11 +195,11 @@ void DIALOG_IMPORT_GFX::DIALOG_IMPORT_GFX::onUnitPositionSelection( wxCommandEve } -double DIALOG_IMPORT_GFX::getPCBdefaultLineWidthMM() +double DIALOG_IMPORT_GFX::getDXFDefaultLineWidthMM() { double value = DoubleValueFromString( EDA_UNITS::UNSCALED, m_textCtrlLineWidth->GetValue() ); - switch( m_lineWidthUnits ) + switch( m_dxfLineWidthUnits ) { default: case 0: break; // display units = mm @@ -185,11 +213,11 @@ double DIALOG_IMPORT_GFX::getPCBdefaultLineWidthMM() void DIALOG_IMPORT_GFX::onUnitWidthSelection( wxCommandEvent& event ) { - m_lineWidth = getPCBdefaultLineWidthMM(); + m_dxfLineWidth = getDXFDefaultLineWidthMM(); // Switch to new units - m_lineWidthUnits = m_choiceUnitLineWidth->GetSelection(); - showPCBdefaultLineWidth(); + m_dxfLineWidthUnits = m_choiceUnitLineWidth->GetSelection(); + showDXFDefaultLineWidth(); } @@ -207,16 +235,16 @@ void DIALOG_IMPORT_GFX::showPcbImportOffsets() } -void DIALOG_IMPORT_GFX::showPCBdefaultLineWidth() +void DIALOG_IMPORT_GFX::showDXFDefaultLineWidth() { double value; - switch( m_lineWidthUnits ) + switch( m_dxfLineWidthUnits ) { default: - case 0: value = m_lineWidth; break; // display units = mm - case 1: value = m_lineWidth / 25.4 * 1000; break; // display units = mil - case 2: value = m_lineWidth / 25.4; break; // display units = inch + case 0: value = m_dxfLineWidth; break; // display units = mm + case 1: value = m_dxfLineWidth / 25.4 * 1000; break; // display units = mil + case 2: value = m_dxfLineWidth / 25.4; break; // display units = inch } m_textCtrlLineWidth->SetValue( wxString::Format( wxT( "%f" ), value ) ); @@ -239,10 +267,10 @@ void DIALOG_IMPORT_GFX::onBrowseFiles( wxCommandEvent& event ) wxString wildcardsDesc; wxString allWildcards; - for( auto pluginType : m_gfxImportMgr->GetImportableFileTypes() ) + for( GRAPHICS_IMPORT_MGR::GFX_FILE_T pluginType : m_gfxImportMgr->GetImportableFileTypes() ) { - auto plugin = m_gfxImportMgr->GetPlugin( pluginType ); - const auto extensions = plugin->GetFileExtensions(); + std::unique_ptr plugin = m_gfxImportMgr->GetPlugin( pluginType ); + const std::vector extensions = plugin->GetFileExtensions(); wildcardsDesc += wxT( "|" ) + plugin->GetName() + AddFileExtListToFilter( extensions ); allWildcards += plugin->GetWildcards() + wxT( ";" ); @@ -290,19 +318,18 @@ bool DIALOG_IMPORT_GFX::TransferDataFromWindow() return false; } - m_lineWidthUnits = m_choiceUnitLineWidth->GetSelection(); - m_lineWidth = getPCBdefaultLineWidthMM(); + m_dxfLineWidthUnits = m_choiceUnitLineWidth->GetSelection(); + m_dxfLineWidth = getDXFDefaultLineWidthMM(); m_dxfUnits = m_choiceDxfUnits->GetSelection(); m_importer->SetLayer( PCB_LAYER_ID( m_layer ) ); - auto plugin = m_gfxImportMgr->GetPluginByExt( wxFileName( m_filename ).GetExt() ); - - if( plugin ) + if( auto plugin = m_gfxImportMgr->GetPluginByExt( wxFileName( m_filename ).GetExt() ) ) { DXF_IMPORT_PLUGIN* dxfPlugin = dynamic_cast( plugin.get() ); - if( dxfPlugin != nullptr ) + + if( dxfPlugin ) { auto it = dxfUnitsMap.begin(); std::advance( it, m_dxfUnits ); @@ -311,6 +338,12 @@ bool DIALOG_IMPORT_GFX::TransferDataFromWindow() dxfPlugin->SetUnit( DXF_IMPORT_UNITS::DEFAULT ); else dxfPlugin->SetUnit( it->first ); + + m_importer->SetLineWidthMM( m_dxfLineWidth ); + } + else + { + m_importer->SetLineWidthMM( 0.0 ); } // Set coordinates offset for import (offset is given in mm) @@ -318,9 +351,6 @@ bool DIALOG_IMPORT_GFX::TransferDataFromWindow() m_scaleImport = DoubleValueFromString( EDA_UNITS::UNSCALED, m_textCtrlImportScale->GetValue() ); - // The line width is meant to be in pcbnew units, so we scale the import width before - // applying - m_importer->SetLineWidthMM( m_lineWidth ); m_importer->SetPlugin( std::move( plugin ) ); LOCALE_IO dummy; // Ensure floats can be read. diff --git a/pcbnew/import_gfx/dialog_import_gfx.h b/pcbnew/import_gfx/dialog_import_gfx.h index b6d75bbfce..6522fcd022 100644 --- a/pcbnew/import_gfx/dialog_import_gfx.h +++ b/pcbnew/import_gfx/dialog_import_gfx.h @@ -71,6 +71,7 @@ private: void onUnitPositionSelection( wxCommandEvent& event ) override; void onUnitWidthSelection( wxCommandEvent& event ) override; void onBrowseFiles( wxCommandEvent& event ) override; + void onFilename( wxCommandEvent& event ); void originOptionOnUpdateUI( wxUpdateUIEvent& event ) override; void onInteractivePlacement( wxCommandEvent& event ) override @@ -89,8 +90,8 @@ private: } void updatePcbImportOffsets_mm(); - double getPCBdefaultLineWidthMM(); - void showPCBdefaultLineWidth(); + double getDXFDefaultLineWidthMM(); + void showDXFDefaultLineWidth(); void showPcbImportOffsets(); PCB_BASE_FRAME* m_parent; @@ -104,9 +105,9 @@ private: static bool m_shouldGroupItems; static bool m_placementInteractive; static int m_layer; - double m_lineWidth; // always in mm: line width when a line width + double m_dxfLineWidth; // always in mm: line width when a line width // is not specified - static int m_lineWidthUnits; + static int m_dxfLineWidthUnits; static double m_scaleImport; // a scale factor to change the size of imported // items m_scaleImport =1.0 means keep original size static int m_dxfUnits; diff --git a/pcbnew/import_gfx/svg_import_plugin.cpp b/pcbnew/import_gfx/svg_import_plugin.cpp index 8f85af609b..38238f7478 100644 --- a/pcbnew/import_gfx/svg_import_plugin.cpp +++ b/pcbnew/import_gfx/svg_import_plugin.cpp @@ -87,8 +87,10 @@ bool SVG_IMPORT_PLUGIN::Import() m_internalImporter.NewShape( rule ); for( NSVGpath* path = shape->paths; path != nullptr; path = path->next ) + { DrawPath( path->pts, path->npts, path->closed, shape->fill.type == NSVG_PAINT_COLOR, lineWidth ); + } } m_internalImporter.PostprocessNestedPolygons(); diff --git a/pcbnew/pcbnew_settings.cpp b/pcbnew/pcbnew_settings.cpp index 3bf88adf09..05eb0b9c36 100644 --- a/pcbnew/pcbnew_settings.cpp +++ b/pcbnew/pcbnew_settings.cpp @@ -379,10 +379,10 @@ PCBNEW_SETTINGS::PCBNEW_SETTINGS() &m_ImportGraphics.interactive_placement, true ) ); m_params.emplace_back( new PARAM( "import_graphics.line_width_units", - &m_ImportGraphics.line_width_units, 0 ) ); + &m_ImportGraphics.dxf_line_width_units, 0 ) ); m_params.emplace_back( new PARAM( "import_graphics.line_width", - &m_ImportGraphics.line_width, 0.2 ) ); + &m_ImportGraphics.dxf_line_width, 0.2 ) ); m_params.emplace_back( new PARAM( "import_graphics.origin_units", &m_ImportGraphics.origin_units, 0 ) ); diff --git a/pcbnew/pcbnew_settings.h b/pcbnew/pcbnew_settings.h index 6c88c194e4..728171aea7 100644 --- a/pcbnew/pcbnew_settings.h +++ b/pcbnew/pcbnew_settings.h @@ -175,8 +175,8 @@ public: int layer; bool interactive_placement; wxString last_file; - double line_width; - int line_width_units; + double dxf_line_width; + int dxf_line_width_units; int origin_units; double origin_x; double origin_y;