KiCad PCB EDA Suite
Loading...
Searching...
No Matches
footprint_edit_frame.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
5 *
6 * This program is free software: you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation, either version 3 of the License, or (at your
9 * option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <https://www.gnu.org/licenses/>.
18 */
19
20#ifndef FOOTPRINT_EDIT_FRAME_H
21#define FOOTPRINT_EDIT_FRAME_H
22
23#include <pcb_base_frame.h>
24#include <pcb_base_edit_frame.h>
25#include <pcb_io/pcb_io_mgr.h>
26#include <widgets/lib_tree.h>
27#include <footprint_tree_pane.h>
29
31class FP_LIB_TABLE;
35class EDA_LIST_DIALOG;
39
42
43namespace PCB { struct IFACE; } // A KIFACE coded in pcbnew.cpp
44
45
47{
48public:
50
55 static const wxChar* GetFootprintEditorFrameName();
56
58 BOARD_ITEM_CONTAINER* GetModel() const override;
60
66 bool IsContentModified() const override;
67
68 bool IsCurrentFPFromBoard() const;
69
70 bool CanCloseFPFromBoard( bool doClose );
71
73
77 EDA_ANGLE GetRotationAngle() const override;
78
79 APP_SETTINGS_BASE* config() const override;
80
82
83 const PCB_PLOT_PARAMS& GetPlotSettings() const override;
84 void SetPlotSettings( const PCB_PLOT_PARAMS& aSettings ) override;
85
87
88 void LoadSettings( APP_SETTINGS_BASE* aCfg ) override;
89 void SaveSettings( APP_SETTINGS_BASE* aCfg ) override;
90
91 COLOR_SETTINGS* GetColorSettings( bool aForceRefresh = false ) const override;
92
93 std::unique_ptr<GRID_HELPER> MakeGridHelper() override;
94
95 const BOX2I GetDocumentExtents( bool aIncludeAllVisible = true ) const override;
96
97 bool canCloseWindow( wxCloseEvent& Event ) override;
98 void doCloseWindow() override;
99 void CloseFootprintEditor( wxCommandEvent& Event );
100 void OnExitKiCad( wxCommandEvent& aEvent );
101
107 void SwitchCanvas( EDA_DRAW_PANEL_GAL::GAL_TYPE aCanvasType ) override;
108
113 void UpdateUserInterface();
114
116 void UpdateMsgPanel() override;
117
121 void HardRedraw() override;
122
131 void ReCreateLayerBox( bool aForceResizeToolbar = true );
132
133 // The Tool Framework initialization, for GAL mode
134 void setupTools();
135
136 void OnSaveFootprintAsPng( wxCommandEvent& event );
137
138 bool IsLibraryTreeShown() const override;
139 void ToggleLibraryTree() override;
140 void FocusLibraryTreeInput() override;
141
142 void ToggleLayersManager();
143
151 bool SaveLibraryAs( const wxString& aLibraryPath );
152
154 void OnEditItemRequest( BOARD_ITEM* aItem ) override;
155
156 void LoadFootprintFromLibrary( LIB_ID aFPID );
157
164 bool BeginNewFootprint( const wxString& aLibrary );
165
170 void CloseFootprintTab( const LIB_ID& aFPID );
171
176 void RenameFootprintTab( const LIB_ID& aOldId, const LIB_ID& aNewId );
177
181 wxObjectDataPtr<LIB_TREE_MODEL_ADAPTER>& GetLibTreeAdapter() { return m_adapter; }
182
189 bool SaveFootprint( FOOTPRINT* aFootprint );
190 bool DuplicateFootprint( FOOTPRINT* aFootprint );
191 bool SaveFootprintAs( FOOTPRINT* aFootprint );
192 bool SaveFootprintToBoard( bool aAddNew );
193 bool SaveFootprintInLibrary( FOOTPRINT* aFootprint, const wxString& aLibraryName );
194 bool RevertFootprint();
195
202 void OnModify() override;
203
210 bool Clear_Pcb( bool doAskAboutUnsavedChanges );
211
213 LIB_ID GetLoadedFPID() const;
214
217 LIB_ID GetTargetFPID() const;
218
219 void ClearModify();
220
224 void ExportFootprint( FOOTPRINT* aFootprint );
225
232 FOOTPRINT* ImportFootprint( const wxString& aName = wxT( "" ) );
233
241 bool LoadFootprintFromBoard( FOOTPRINT* aFootprint );
242
249
253 bool DeleteFootprintFromLibrary( const LIB_ID& aFPID, bool aConfirm );
254
258 COLOR4D GetGridColor() override;
259
261 void SetActiveLayer( PCB_LAYER_ID aLayer ) override;
262
263 void OnDisplayOptionsChanged() override;
264
266 void ActivateGalCanvas() override;
267
277 bool OpenProjectFiles( const std::vector<wxString>& aFileSet, int aCtl = 0 ) override;
278
283 void AddFootprintToBoard( FOOTPRINT* aFootprint ) override;
284
289 void ReloadFootprint( FOOTPRINT* aFootprint ) override;
290
294 void ShowChangedLanguage() override;
295
299 void CommonSettingsChanged( int aFlags ) override;
300
301 LIB_TREE* GetLibTree() const override
302 {
303 return m_treePane->GetLibTree();
304 }
305
310 void SyncLibraryTree( [[maybe_unused]] bool aProgress );
311
315 void RefreshLibraryTree();
316
320 void UpdateLibraryTree( const wxDataViewItem& treeItem, FOOTPRINT* aFootprint );
321
323 void UpdateView();
324
325 void UpdateTitle();
326
327 void FocusOnLibID( const LIB_ID& aLibID );
328
329 void KiwayMailIn( KIWAY_MAIL_EVENT& mail ) override;
330
335
339 void AdvanceFootprintTab( bool aForward );
340
345
346 DECLARE_EVENT_TABLE()
347
348protected:
350 FOOTPRINT_EDIT_FRAME( KIWAY* aKiway, wxWindow* aParent );
351
355 void resolveCanvasType() override;
356
361 void initLibraryTree();
362
364 void retainLastFootprint();
365
366 void updateEnabledLayers();
367
371 void doReCreateMenuBar() override;
372
376 void editFootprintProperties( FOOTPRINT* aFootprint );
377
378 void setupUIConditions() override;
379
380 void centerItemIdleHandler( wxIdleEvent& aEvent );
381
388 void OnTabCharHook( wxKeyEvent& aEvent );
389
390protected:
392
393private:
394 friend struct PCB::IFACE;
395
399 FOOTPRINT_EDITOR_TAB_CONTEXT* findOrCreateFootprintTab( const LIB_ID& aLibId, bool aAsPreview );
400
410
415
424
432
437 void borrowBoardNonDestructive( BOARD* aBoard );
438
442 bool promptAndCloseFootprintTab( int aIdx );
443
450
455 bool hasDirtyInactiveInstanceTabs() const;
456
462
470
475
483 void detachTabsForFullClear( BOARD* aReplacement );
484
488 bool activeBoardOwnedByTab() const;
489
492
494
496
500
504
508
511
514};
515
516#endif // FOOTPRINT_EDIT_FRAME_H
BOX2< VECTOR2I > BOX2I
Definition box2.h:918
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
Container for design settings for a BOARD object.
Abstract interface for BOARD_ITEMs capable of storing other items inside.
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:81
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:372
Color settings are a bit different than most of the settings objects in that there can be more than o...
A dialog which shows:
The tab strip plus the single shared GAL canvas.
One open footprint tab owning its fp-holder board, lent to the frame by raw pointer while active.
EDITOR_TABS_PANEL * GetTabsPanel() const
Return the tabbed-document strip, or nullptr if the tabs UI is not mounted.
void CloseFootprintEditor(wxCommandEvent &Event)
BOARD_DESIGN_SETTINGS & GetDesignSettings() const override
Return the BOARD_DESIGN_SETTINGS for the open project.
void setupUIConditions() override
Setup the UI conditions for the various actions and their controls in this frame.
void ActivateGalCanvas() override
Use to start up the GAL drawing canvas.
void editFootprintProperties(FOOTPRINT *aFootprint)
Run the Footprint Properties dialog and handle changes made in it.
void detachTabsForFullClear(BOARD *aReplacement)
Install aReplacement as the active document non-destructively, then drop every tab context and free t...
void HardRedraw() override
Refresh the library tree and redraw the window.
void UpdateLibraryTree(const wxDataViewItem &treeItem, FOOTPRINT *aFootprint)
Update a single node in the library tree.
static const wxChar * GetFootprintEditorFrameName()
void SyncLibraryTree(bool aProgress)
Synchronize the footprint library tree to the current state of the footprint library table.
bool SaveFootprintInLibrary(FOOTPRINT *aFootprint, const wxString &aLibraryName)
FOOTPRINT_EDITOR_TAB_CONTEXT * m_activeTab
bool SaveLibraryAs(const wxString &aLibraryPath)
Save a library to a new name and/or library type.
void OnSaveFootprintAsPng(wxCommandEvent &event)
bool SaveFootprintAs(FOOTPRINT *aFootprint)
bool promptToSaveInactiveInstanceTabs()
Prompt to save each dirty instance (board) tab that is not the active one, since the active tab's uns...
bool DuplicateFootprint(FOOTPRINT *aFootprint)
void FocusLibraryTreeInput() override
BOARD_ITEM_CONTAINER * GetModel() const override
void ReCreateLayerBox(bool aForceResizeToolbar=true)
Re create the layer Box by clearing the old list, and building a new one from the new layers names an...
LIB_TREE * GetLibTree() const override
bool canCloseWindow(wxCloseEvent &Event) override
void UpdateMsgPanel() override
Redraw the message panel.
void ExportFootprint(FOOTPRINT *aFootprint)
Create a file containing only one footprint.
LIB_ID GetTargetFPID() const
Return the LIB_ID of the part selected in the footprint tree, or the loaded part if there is no selec...
LIB_ID GetLoadedFPID() const
Return the LIB_ID of the part being edited.
APP_SETTINGS_BASE * config() const override
Return the settings object used in SaveSettings(), and is overloaded in KICAD_MANAGER_FRAME.
void refreshFootprintTabState()
Re-query and re-render the tab labels from the active context's modified state.
bool SaveFootprintToBoard(bool aAddNew)
EDITOR_TABS_PANEL * m_tabsPanel
FOOTPRINT_EDITOR_TAB_CONTEXT * findOrCreateFootprintInstanceTab(FOOTPRINT *aBoardFootprint)
Find or create the instance tab for a placed board footprint and make it the active tab.
void detachActiveFootprintTab()
Snapshot the active tab's view/selection, fold the dirty state back into it, and clear m_activeTab.
void SetPlotSettings(const PCB_PLOT_PARAMS &aSettings) override
bool SaveFootprint(FOOTPRINT *aFootprint)
Save in an existing library a given footprint.
void OnTabCharHook(wxKeyEvent &aEvent)
Cycle footprint tabs from the CHAR_HOOK stream, since GTK cannot register WXK_TAB as a menu accelerat...
void CloseFootprintTab(const LIB_ID &aFPID)
Close the open tab for aFPID, if any, without prompting and leaving the other tabs open.
std::unique_ptr< API_HANDLER_FOOTPRINT > m_apiHandler
void initLibraryTree()
Make sure the footprint info list is loaded (with a progress dialog) and then initialize the footprin...
void LoadFootprintFromLibrary(LIB_ID aFPID)
bool BeginNewFootprint(const wxString &aLibrary)
Prepare the editor for a new footprint, returning false if the user cancels.
wxObjectDataPtr< LIB_TREE_MODEL_ADAPTER > & GetLibTreeAdapter()
Return the adapter object that provides the stored data.
bool hasDirtyInactiveInstanceTabs() const
True if any non-active instance (board) tab has unsaved edits.
bool m_silentFootprintTabClose
While true, promptAndCloseFootprintTab() skips the unsaved-changes dialog.
FOOTPRINT * ImportFootprint(const wxString &aName=wxT(""))
Read a file containing only one footprint.
std::map< KIID, KIID > m_boardFootprintUuids
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
FOOTPRINT * SelectFootprintFromBoard(BOARD *aPcb)
Display the list of footprints currently existing on the BOARD.
std::unique_ptr< API_HANDLER_COMMON > m_apiHandlerCommon
void ShowChangedLanguage() override
Update visible items after a language change.
void resolveCanvasType() override
Determines the Canvas type to load (with prompt if required) and initializes m_canvasType.
void CommonSettingsChanged(int aFlags) override
Called after the preferences dialog is run.
bool IsContentModified() const override
Get if any footprints or libraries have been modified but not saved.
void UpdateUserInterface()
Update the layer manager and other widgets from the board setup (layer and items visibility,...
wxObjectDataPtr< LIB_TREE_MODEL_ADAPTER > m_adapter
bool IsLibraryTreeShown() const override
FOOTPRINT_EDITOR_SETTINGS * m_editorSettings
void centerItemIdleHandler(wxIdleEvent &aEvent)
const BOX2I GetDocumentExtents(bool aIncludeAllVisible=true) const override
Return bounding box of document with option to not include some items.
bool Clear_Pcb(bool doAskAboutUnsavedChanges)
Delete all and reinitialize the current board.
Definition initpcb.cpp:104
void RenameFootprintTab(const LIB_ID &aOldId, const LIB_ID &aNewId)
Update the open tab for aOldId, if any, to the renamed footprint aNewId so its label and key track th...
void borrowBoardNonDestructive(BOARD *aBoard)
Swap the frame's borrowed board pointer to aBoard without deleting the previous board,...
FOOTPRINT_EDIT_FRAME(KIWAY *aKiway, wxWindow *aParent)
protected so only friend PCB::IFACE::CreateWindow() can act as sole factory.
void KiwayMailIn(KIWAY_MAIL_EVENT &mail) override
Receive #KIWAY_ROUTED_EVENT messages from other players.
void OnEditItemRequest(BOARD_ITEM *aItem) override
Install the corresponding dialog editor for the given item.
SELECTION & GetCurrentSelection() override
Get the current selection from the canvas area.
void AdvanceFootprintTab(bool aForward)
Advance the active tab forward or backward in MRU order.
bool CanCloseFPFromBoard(bool doClose)
void activateFootprintTab(FOOTPRINT_EDITOR_TAB_CONTEXT *aCtx)
Make aCtx the active tab, borrowing its board without deleting the outgoing one.
void freeFootprintTabUndoRedo(FOOTPRINT_EDITOR_TAB_CONTEXT &aCtx)
Free the transient board items a detached context's lists own before it is destroyed,...
void SetActiveLayer(PCB_LAYER_ID aLayer) override
void AddFootprintToBoard(FOOTPRINT *aFootprint) override
Override from PCB_BASE_EDIT_FRAME which adds a footprint to the editor's dummy board,...
bool DeleteFootprintFromLibrary(const LIB_ID &aFPID, bool aConfirm)
Delete the given footprint from its library.
bool activeBoardOwnedByTab() const
True when a tab context owns the frame's borrowed board, so the frame must not delete it.
void OnModify() override
Must be called after a footprint change in order to set the "modify" flag of the current screen and p...
std::vector< std::unique_ptr< FOOTPRINT_EDITOR_TAB_CONTEXT > > m_tabContexts
void CloseActiveFootprintTab()
Request closing the active tab, prompting to save if it is modified.
FOOTPRINT_TREE_PANE * m_treePane
std::unique_ptr< GRID_HELPER > MakeGridHelper() override
void OnDisplayOptionsChanged() override
void doReCreateMenuBar() override
(Re)Create the menubar for the Footprint Editor frame
void FocusOnLibID(const LIB_ID &aLibID)
const PCB_PLOT_PARAMS & GetPlotSettings() const override
Return the PCB_PLOT_PARAMS for the BOARD owned by this frame.
bool m_suppressTabActivation
Set while a full clear tears the tab strip down so the panel's close-driven re-activation does not re...
std::unique_ptr< FOOTPRINT > m_originalFootprintCopy
void ReloadFootprint(FOOTPRINT *aFootprint) override
Override from PCB_BASE_FRAME which reloads the footprint from the library without setting the footpri...
EDA_ANGLE GetRotationAngle() const override
Return the angle used for rotate operations.
void RefreshLibraryTree()
Redisplay the library tree.
void installFootprintTabBoard(FOOTPRINT_EDITOR_TAB_CONTEXT *aCtx, BOARD *aBoard)
Install aBoard as the active document non-destructively, wiring the tool environment and resetting th...
void OnExitKiCad(wxCommandEvent &aEvent)
bool OpenProjectFiles(const std::vector< wxString > &aFileSet, int aCtl=0) override
Load a KiCad board (.kicad_pcb) from aFileName.
bool promptAndCloseFootprintTab(int aIdx)
Prompt to save if needed, then drop the tab context at aIdx.
void SaveSettings(APP_SETTINGS_BASE *aCfg) override
Save common frame parameters to a configuration data file.
MAGNETIC_SETTINGS * GetMagneticItemsSettings() override
FOOTPRINT_EDITOR_SETTINGS * GetSettings()
FOOTPRINT_EDITOR_TAB_CONTEXT * findOrCreateFootprintTab(const LIB_ID &aLibId, bool aAsPreview)
Find or create the tab for aLibId over its own fp-holder board and make it the active tab.
void SwitchCanvas(EDA_DRAW_PANEL_GAL::GAL_TYPE aCanvasType) override
Switch the currently used canvas (Cairo / OpenGL).
void freeUndoRedoCommandsWithItems(UNDO_REDO_CONTAINER &aUndo, UNDO_REDO_CONTAINER &aRedo)
Free both the transient board items and the command wrappers in the given lists.
bool LoadFootprintFromBoard(FOOTPRINT *aFootprint)
Load a footprint from the main board into the Footprint Editor.
COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const override
Helper to retrieve the current color settings.
Footprint Editor pane with footprint library tree.
A color representation with 4 components: red, green, blue, alpha.
Definition color4d.h:101
Definition kiid.h:44
Carry a payload from one KIWAY_PLAYER to another within a PROJECT.
Definition kiway_mail.h:34
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition kiway.h:311
A logical library item identifier and consists of various portions much like a URI.
Definition lib_id.h:45
Widget displaying a tree of symbols with optional search text control and description panel.
Definition lib_tree.h:46
PCB_BASE_EDIT_FRAME(KIWAY *aKiway, wxWindow *aParent, FRAME_T aFrameType, const wxString &aTitle, const wxPoint &aPos, const wxSize &aSize, long aStyle, const wxString &aFrameName)
Class to display a pcb layer list in a wxBitmapComboBox.
Parameters and options when plotting/printing a board.
Class to handle modifications to the symbol libraries.
A holder to handle a list of undo (or redo) commands.
STL class.
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:56
STL namespace.