REMOVED new footprint dialog.

We now just create an "Untitled" footprint.

Also fixes a bug where the preview of new footprints
would zoom in too far.

Fixes https://gitlab.com/kicad/code/kicad/-/issues/17573
This commit is contained in:
Jeff Young 2024-05-31 10:17:17 +01:00
parent 015b93b474
commit 1eb26b439a
9 changed files with 53 additions and 92 deletions

View File

@ -267,10 +267,8 @@ public:
* *
* @param aFootprintName is the name of the new footprint in library. * @param aFootprintName is the name of the new footprint in library.
* @param aLibName optional, if specified is the library for the new footprint * @param aLibName optional, if specified is the library for the new footprint
* @param aQuiet prevents user dialogs from being shown
*/ */
FOOTPRINT* CreateNewFootprint( const wxString& aFootprintName, const wxString& aLibName, FOOTPRINT* CreateNewFootprint( wxString aFootprintName, const wxString& aLibName );
bool aQuiet );
/** /**
* Places \a aFootprint at the current cursor position and updates footprint coordinates * Places \a aFootprint at the current cursor position and updates footprint coordinates

View File

@ -1220,6 +1220,21 @@ BOX2I FOOTPRINT::GetFpPadsLocalBbox() const
} }
bool FOOTPRINT::TextOnly() const
{
for( BOARD_ITEM* item : m_drawings )
{
if( m_privateLayers.test( item->GetLayer() ) )
continue;
if( item->Type() != PCB_FIELD_T && item->Type() != PCB_TEXT_T )
return false;
}
return true;
}
const BOX2I FOOTPRINT::GetBoundingBox() const const BOX2I FOOTPRINT::GetBoundingBox() const
{ {
return GetBoundingBox( true, true ); return GetBoundingBox( true, true );

View File

@ -171,6 +171,8 @@ public:
*/ */
SHAPE_POLY_SET GetBoundingHull() const; SHAPE_POLY_SET GetBoundingHull() const;
bool TextOnly() const;
// Virtual function // Virtual function
const BOX2I GetBoundingBox() const override; const BOX2I GetBoundingBox() const override;
const BOX2I GetBoundingBox( bool aIncludeText, bool aIncludeInvisibleText ) const; const BOX2I GetBoundingBox( bool aIncludeText, bool aIncludeInvisibleText ) const;

View File

@ -26,7 +26,6 @@
#include <kiface_base.h> #include <kiface_base.h>
#include <confirm.h> #include <confirm.h>
#include <kidialog.h> #include <kidialog.h>
#include <string_utils.h>
#include <macros.h> #include <macros.h>
#include <pcb_edit_frame.h> #include <pcb_edit_frame.h>
#include <eda_list_dialog.h> #include <eda_list_dialog.h>
@ -41,10 +40,8 @@
#include <footprint.h> #include <footprint.h>
#include <zone.h> #include <zone.h>
#include <pcb_group.h> #include <pcb_group.h>
#include <board_commit.h>
#include <footprint_edit_frame.h> #include <footprint_edit_frame.h>
#include <wildcards_and_files_ext.h> #include <wildcards_and_files_ext.h>
#include <pcb_io/kicad_legacy/pcb_io_kicad_legacy.h>
#include <pcb_io/kicad_sexpr/pcb_io_kicad_sexpr.h> #include <pcb_io/kicad_sexpr/pcb_io_kicad_sexpr.h>
#include <env_paths.h> #include <env_paths.h>
#include <paths.h> #include <paths.h>
@ -1229,97 +1226,45 @@ bool FOOTPRINT_EDIT_FRAME::RevertFootprint()
} }
class NEW_FP_DIALOG : public WX_TEXT_ENTRY_DIALOG FOOTPRINT* PCB_BASE_FRAME::CreateNewFootprint( wxString aFootprintName, const wxString& aLibName )
{ {
public: if( aFootprintName.IsEmpty() )
NEW_FP_DIALOG( PCB_BASE_FRAME* aParent, const wxString& aName, int aFootprintType, aFootprintName = _( "Untitled" );
std::function<bool( wxString newName )> aValidator ) :
WX_TEXT_ENTRY_DIALOG( aParent, _( "Enter footprint name:" ), _( "New Footprint" ),
aName, _( "Footprint type:" ),
{ _( "Through hole" ), _( "SMD" ), _( "Other" ) },
aFootprintType ),
m_validator( std::move( aValidator ) )
{ }
wxString GetFPName() int footprintAttrs = FP_SMD;
if( !aLibName.IsEmpty() )
{ {
wxString name = m_textCtrl->GetValue(); FP_LIB_TABLE* tbl = PROJECT_PCB::PcbFootprintLibs( &Prj() );
name.Trim( true ).Trim( false ); wxArrayString fpnames;
return name; wxString baseName = aFootprintName;
} int idx = 1;
protected: // Make sure the name is unique
bool TransferDataFromWindow() override while( tbl->FootprintExists( aLibName, aFootprintName ) )
{ aFootprintName = baseName + wxString::Format( wxS( "_%d" ), idx++ );
return m_validator( GetFPName() );
}
private: // Try to infer the footprint attributes from an existing footprint in the library
std::function<bool( wxString newName )> m_validator; try
};
FOOTPRINT* PCB_BASE_FRAME::CreateNewFootprint( const wxString& aFootprintName,
const wxString& aLibName, bool aQuiet )
{
FP_LIB_TABLE* tbl = PROJECT_PCB::PcbFootprintLibs( &Prj() );
wxString footprintName = aFootprintName;
wxString msg;
// Static to store user preference for a session
static int footprintType = 1;
int footprintTranslated = FP_SMD;
// Ask for the new footprint name
if( footprintName.IsEmpty() && !aQuiet )
{
NEW_FP_DIALOG dlg( this, footprintName, footprintType,
[&]( wxString newName )
{
if( newName.IsEmpty() )
{
wxMessageBox( _( "Footprint must have a name." ) );
return false;
}
if( !aLibName.IsEmpty() && tbl->FootprintExists( aLibName, newName ) )
{
msg = wxString::Format( _( "Footprint '%s' already exists in library '%s'." ),
newName, aLibName );
KIDIALOG errorDlg( this, msg, _( "Confirmation" ),
wxOK | wxCANCEL | wxICON_WARNING );
errorDlg.SetOKLabel( _( "Overwrite" ) );
return errorDlg.ShowModal() == wxID_OK;
}
return true;
} );
dlg.SetTextValidator( FOOTPRINT_NAME_VALIDATOR( &footprintName ) );
if( dlg.ShowModal() != wxID_OK )
return nullptr; //Aborted by user
footprintName = dlg.GetFPName();
footprintType = dlg.GetChoice();
switch( footprintType )
{ {
case 0: footprintTranslated = FP_THROUGH_HOLE; break; tbl->FootprintEnumerate( fpnames, aLibName, true );
case 1: footprintTranslated = FP_SMD; break;
default: footprintTranslated = 0; break; if( !fpnames.empty() )
footprintAttrs = tbl->FootprintLoad( aLibName, fpnames.Last() )->GetAttributes();
}
catch( ... )
{
// best efforts
} }
} }
// Creates the new footprint and add it to the head of the linked list of footprints // Create the new footprint and add it to the head of the linked list of footprints
FOOTPRINT* footprint = new FOOTPRINT( GetBoard() ); FOOTPRINT* footprint = new FOOTPRINT( GetBoard() );
// Update its name in lib // Update its name in lib
footprint->SetFPID( LIB_ID( wxEmptyString, footprintName ) ); footprint->SetFPID( LIB_ID( wxEmptyString, aFootprintName ) );
footprint->SetAttributes( footprintTranslated ); footprint->SetAttributes( footprintAttrs );
PCB_LAYER_ID txt_layer; PCB_LAYER_ID txt_layer;
VECTOR2I default_pos; VECTOR2I default_pos;
@ -1355,10 +1300,10 @@ FOOTPRINT* PCB_BASE_FRAME::CreateNewFootprint( const wxString& aFootprintName,
} }
if( footprint->GetReference().IsEmpty() ) if( footprint->GetReference().IsEmpty() )
footprint->SetReference( footprintName ); footprint->SetReference( aFootprintName );
if( footprint->GetValue().IsEmpty() ) if( footprint->GetValue().IsEmpty() )
footprint->SetValue( footprintName ); footprint->SetValue( aFootprintName );
footprint->RunOnDescendants( footprint->RunOnDescendants(
[&]( BOARD_ITEM* aChild ) [&]( BOARD_ITEM* aChild )

View File

@ -143,7 +143,8 @@ void FOOTPRINT_PREVIEW_PANEL::renderFootprint( std::shared_ptr<FOOTPRINT> aFootp
void FOOTPRINT_PREVIEW_PANEL::fitToCurrentFootprint() void FOOTPRINT_PREVIEW_PANEL::fitToCurrentFootprint()
{ {
BOX2I bbox = m_currentFootprint->GetBoundingBox( false, false ); bool includeText = m_currentFootprint->TextOnly();
BOX2I bbox = m_currentFootprint->GetBoundingBox( includeText, false );
if( bbox.GetSize().x > 0 && bbox.GetSize().y > 0 ) if( bbox.GetSize().x > 0 && bbox.GetSize().y > 0 )
{ {

View File

@ -194,7 +194,7 @@ FOOTPRINT* MICROWAVE_TOOL::createBaseFootprint( const wxString& aValue,
{ {
PCB_EDIT_FRAME& editFrame = *getEditFrame<PCB_EDIT_FRAME>(); PCB_EDIT_FRAME& editFrame = *getEditFrame<PCB_EDIT_FRAME>();
FOOTPRINT* footprint = editFrame.CreateNewFootprint( aValue, wxEmptyString, true ); FOOTPRINT* footprint = editFrame.CreateNewFootprint( aValue, wxEmptyString );
footprint->SetAttributes( FP_EXCLUDE_FROM_POS_FILES | FP_EXCLUDE_FROM_BOM ); footprint->SetAttributes( FP_EXCLUDE_FROM_POS_FILES | FP_EXCLUDE_FROM_BOM );

View File

@ -409,7 +409,7 @@ FOOTPRINT* MICROWAVE_TOOL::createMicrowaveInductor( MICROWAVE_INDUCTOR_PATTERN&
if( ( cmpdlg.ShowQuasiModal() != wxID_OK ) || msg.IsEmpty() ) if( ( cmpdlg.ShowQuasiModal() != wxID_OK ) || msg.IsEmpty() )
return nullptr; // Aborted by user return nullptr; // Aborted by user
FOOTPRINT* footprint = editFrame->CreateNewFootprint( msg, wxEmptyString, true ); FOOTPRINT* footprint = editFrame->CreateNewFootprint( msg, wxEmptyString );
footprint->SetFPID( LIB_ID( wxEmptyString, wxT( "mw_inductor" ) ) ); footprint->SetFPID( LIB_ID( wxEmptyString, wxT( "mw_inductor" ) ) );
footprint->SetAttributes( FP_EXCLUDE_FROM_POS_FILES | FP_EXCLUDE_FROM_BOM ); footprint->SetAttributes( FP_EXCLUDE_FROM_POS_FILES | FP_EXCLUDE_FROM_BOM );

View File

@ -171,9 +171,9 @@ bool FOOTPRINT_EDITOR_CONTROL::Init()
int FOOTPRINT_EDITOR_CONTROL::NewFootprint( const TOOL_EVENT& aEvent ) int FOOTPRINT_EDITOR_CONTROL::NewFootprint( const TOOL_EVENT& aEvent )
{ {
LIB_ID selected = m_frame->GetTreeFPID(); LIB_ID selected = m_frame->GetTargetFPID();
wxString libraryName = selected.GetUniStringLibNickname(); wxString libraryName = selected.GetUniStringLibNickname();
FOOTPRINT* newFootprint = m_frame->CreateNewFootprint( wxEmptyString, libraryName, false ); FOOTPRINT* newFootprint = m_frame->CreateNewFootprint( wxEmptyString, libraryName );
if( !newFootprint ) if( !newFootprint )
return 0; return 0;

View File

@ -708,7 +708,7 @@ TOOL_ACTION PCB_ACTIONS::newFootprint( TOOL_ACTION_ARGS()
.Scope( AS_GLOBAL ) .Scope( AS_GLOBAL )
.DefaultHotkey( MD_CTRL + 'N' ) .DefaultHotkey( MD_CTRL + 'N' )
.LegacyHotkeyName( "New" ) .LegacyHotkeyName( "New" )
.FriendlyName( _( "New Footprint..." ) ) .FriendlyName( _( "New Footprint" ) )
.Tooltip( _( "Create a new, empty footprint" ) ) .Tooltip( _( "Create a new, empty footprint" ) )
.Icon( BITMAPS::new_footprint ) ); .Icon( BITMAPS::new_footprint ) );