KiCad PCB EDA Suite
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
footprint_wizard_frame.cpp
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 (C) 2012-2015 Miguel Angel Ajo Pelayo <miguelangel@nbee.es>
5 * Copyright (C) 2012-2019 Jean-Pierre Charras, jp.charras at wanadoo.fr
6 * Copyright (C) 2008 Wayne Stambaugh <stambaughw@gmail.com>
7 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, you may find one here:
21 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
22 * or you may search the http://www.gnu.org website for the version 2 license,
23 * or you may write to the Free Software Foundation, Inc.,
24 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
25 */
26
27#include <kiface_base.h>
28#include <pcb_draw_panel_gal.h>
29#include <pcb_edit_frame.h>
31#include <widgets/msgpanel.h>
32#include <bitmaps.h>
33#include <grid_tricks.h>
34#include <board.h>
37#include <pcbnew_id.h>
38#include <pcbnew_settings.h>
40#include <wx/listbox.h>
41#include <wx/statline.h>
42#include <wx/tokenzr.h>
43#include <wx/numformatter.h>
45#include <base_units.h>
46#include <pgm_base.h>
49#include <tool/tool_manager.h>
51#include <tool/action_toolbar.h>
52#include <tool/common_tools.h>
54#include "tools/pcb_control.h"
55#include "tools/pcb_actions.h"
58
59
61
62 // Window events
65
66 // Toolbar events
72
73 // listbox events
76 FOOTPRINT_WIZARD_FRAME::ParametersUpdated )
77END_EVENT_TABLE()
78
79
80// Note: our FOOTPRINT_WIZARD_FRAME is always modal.
81
82FOOTPRINT_WIZARD_FRAME::FOOTPRINT_WIZARD_FRAME( KIWAY* aKiway, wxWindow* aParent,
83 FRAME_T aFrameType ) :
84 PCB_BASE_EDIT_FRAME( aKiway, aParent, aFrameType, _( "Footprint Wizard" ),
85 wxDefaultPosition, wxDefaultSize,
86 aParent ? KICAD_DEFAULT_DRAWFRAME_STYLE | wxFRAME_FLOAT_ON_PARENT
87 : KICAD_DEFAULT_DRAWFRAME_STYLE | wxSTAY_ON_TOP,
89 m_wizardListShown( false )
90{
91 wxASSERT( aFrameType == FRAME_FOOTPRINT_WIZARD );
92
93 // This frame is always show modal:
94 SetModal( true );
95
96 // Give an icon
97 wxIcon icon;
98 icon.CopyFromBitmap( KiBitmap( BITMAPS::module_wizard ) );
99 SetIcon( icon );
100
101 m_wizardName.Empty();
102
103 // Create the GAL canvas.
104 // Must be created before calling LoadSettings() that needs a valid GAL canvas
105 PCB_DRAW_PANEL_GAL* gal_drawPanel = new PCB_DRAW_PANEL_GAL( this, -1, wxPoint( 0, 0 ),
106 m_frameSize,
107 GetGalDisplayOptions(),
109 SetCanvas( gal_drawPanel );
110
111 SetBoard( new BOARD() );
112
113 // Ensure all layers and items are visible:
115 SetScreen( new PCB_SCREEN( GetPageSizeIU() ) );
116 GetScreen()->m_Center = true; // Center coordinate origins on screen.
117
118 LoadSettings( config() );
119
120 SetSize( m_framePos.x, m_framePos.y, m_frameSize.x, m_frameSize.y );
121
122 // Set some display options here, because the FOOTPRINT_WIZARD_FRAME
123 // does not have a config menu to do that:
124
125 // the footprint wizard frame has no config menu. so use some settings
126 // from the caller, or force some options:
127 PCB_BASE_FRAME* caller = dynamic_cast<PCB_BASE_FRAME*>( aParent );
128
129 if( caller )
130 SetUserUnits( caller->GetUserUnits() );
131
132 // In viewer, the default net clearance is not known (it depends on the actual board).
133 // So we do not show the default clearance, by setting it to 0
134 // The footprint or pad specific clearance will be shown
135 GetBoard()->GetDesignSettings().m_NetSettings->GetDefaultNetclass()->SetClearance( 0 );
136
137 // Create the manager and dispatcher & route draw panel events to the dispatcher
138 m_toolManager = new TOOL_MANAGER;
139 m_toolManager->SetEnvironment( GetBoard(), gal_drawPanel->GetView(),
140 gal_drawPanel->GetViewControls(), config(), this );
141 m_actions = new PCB_ACTIONS();
142 m_toolDispatcher = new TOOL_DISPATCHER( m_toolManager );
143 gal_drawPanel->SetEventDispatcher( m_toolDispatcher );
144
145 m_toolManager->RegisterTool( new PCB_CONTROL );
146 m_toolManager->RegisterTool( new PCB_SELECTION_TOOL ); // for std context menus (zoom & grid)
147 m_toolManager->RegisterTool( new SCRIPTING_TOOL );
148 m_toolManager->RegisterTool( new COMMON_TOOLS );
149 m_toolManager->InitTools();
150
151 // Run the control tool, it is supposed to be always active
152 m_toolManager->InvokeTool( "common.InteractiveSelection" );
153
154 // Create the toolbars
155 m_toolbarSettings = Pgm().GetSettingsManager().GetToolbarSettings<FOOTPRINT_WIZARD_TOOLBAR_SETTINGS>( "fpwizard-toolbars" );
156 configureToolbars();
157 RecreateToolbars();
158
159 // Create the parameters panel
160 m_parametersPanel = new wxPanel( this, wxID_ANY );
161
162 m_pageList = new wxListBox( m_parametersPanel, ID_FOOTPRINT_WIZARD_PAGE_LIST,
163 wxDefaultPosition, wxDefaultSize, 0, nullptr,
164 wxLB_HSCROLL | wxNO_BORDER );
165
166 auto divider = new wxStaticLine( m_parametersPanel, wxID_ANY,
167 wxDefaultPosition, wxDefaultSize, wxLI_VERTICAL );
168
169 m_parameterGrid = new WX_GRID( m_parametersPanel, ID_FOOTPRINT_WIZARD_PARAMETER_LIST );
170 initParameterGrid();
171 m_parameterGrid->PushEventHandler( new GRID_TRICKS( m_parameterGrid ) );
172
173 ReCreatePageList();
174
175 wxBoxSizer* parametersSizer = new wxBoxSizer( wxHORIZONTAL );
176 parametersSizer->Add( m_pageList, 0, wxEXPAND, 5 );
177 parametersSizer->Add( divider, 0, wxEXPAND, 5 );
178 parametersSizer->Add( m_parameterGrid, 1, wxEXPAND, 5 );
179 m_parametersPanel->SetSizer( parametersSizer );
180 m_parametersPanel->Layout();
181
182 // Create the build message box
183 m_buildMessageBox = new wxTextCtrl( this, wxID_ANY, wxEmptyString,
184 wxDefaultPosition, wxDefaultSize,
185 wxTE_MULTILINE | wxTE_READONLY | wxNO_BORDER );
186
187 DisplayWizardInfos();
188
189 m_auimgr.SetManagedWindow( this );
190
191 m_auimgr.AddPane( m_tbTopMain, EDA_PANE().HToolbar().Name( "TopMainToolbar" ).Top().Layer(6) );
192 m_auimgr.AddPane( m_messagePanel, EDA_PANE().Messages().Name( "MsgPanel" ).Bottom().Layer(6)
193 .BestSize( -1, m_msgFrameHeight ) );
194
195 m_auimgr.AddPane( m_parametersPanel, EDA_PANE().Palette().Name( "Params" ).Left().Position(0)
196 .Caption( _( "Parameters" ) ).MinSize( 360, 180 ) );
197 m_auimgr.AddPane( m_buildMessageBox, EDA_PANE().Palette().Name( "Output" ).Left().Position(1)
198 .CaptionVisible( false ).MinSize( 360, -1 ) );
199
200 m_auimgr.AddPane( GetCanvas(), wxAuiPaneInfo().Name( "DrawFrame" ).CentrePane() );
201
202 auto& galOpts = GetGalDisplayOptions();
203 galOpts.m_fullscreenCursor = true;
204 galOpts.m_forceDisplayCursor = true;
205 galOpts.m_axesEnabled = true;
206
207 ActivateGalCanvas();
208 updateView();
209
210 SetActiveLayer( F_Cu );
211 GetToolManager()->PostAction( ACTIONS::zoomFitScreen );
212
213 // Do not Run a dialog here: on some Window Managers, it creates issues.
214 // Reason: the FOOTPRINT_WIZARD_FRAME is run as modal;
215 // It means the call to FOOTPRINT_WIZARD_FRAME::ShowModal will change the
216 // Event Loop Manager, and stop the one created by the dialog.
217 // It does not happen on all W.M., perhaps due to the way the order events are called
218 // See the call in onActivate instead
219}
220
221
223{
224 // Delete the GRID_TRICKS.
225 m_parameterGrid->PopEventHandler( true );
226
228 // Be sure any event cannot be fired after frame deletion:
229 GetCanvas()->SetEvtHandlerEnabled( false );
230
231 // Be sure a active tool (if exists) is deactivated:
232 if( m_toolManager )
234
235 EDA_3D_VIEWER_FRAME* draw3DFrame = Get3DViewerFrame();
236
237 if( draw3DFrame )
238 draw3DFrame->Destroy();
239
240 // Now this frame can be deleted
241}
242
243
245{
246 SaveSettings( config() );
247
248 if( IsModal() )
249 {
250 // Only dismiss a modal frame once, so that the return values set by
251 // the prior DismissModal() are not bashed for ShowModal().
252 if( !IsDismissed() )
253 DismissModal( false );
254 }
255}
256
257
259{
260 DismissModal( true );
261 Close();
262}
263
264
265void FOOTPRINT_WIZARD_FRAME::OnGridSize( wxSizeEvent& aSizeEvent )
266{
267 // Resize the parameter columns
269
270 aSizeEvent.Skip();
271}
272
273
274void FOOTPRINT_WIZARD_FRAME::OnSize( wxSizeEvent& SizeEv )
275{
276 if( m_auimgr.GetManagedWindow() )
277 m_auimgr.Update();
278
279 SizeEv.Skip();
280}
281
282
284{
285 wxString currentTheme = GetFootprintEditorSettings()->m_ColorTheme;
286
287 return Pgm().GetSettingsManager().GetColorSettings( currentTheme );
288}
289
290
292{
298}
299
300
302{
303 BOARD_ITEM* footprint = GetBoard()->GetFirstFootprint();
304
305 if( footprint )
306 {
307 std::vector<MSG_PANEL_ITEM> items;
308
309 footprint->GetMsgPanelInfo( this, items );
310 SetMsgPanel( items );
311 }
312 else
313 {
315 }
316}
317
318
320{
322
323 // Prepare the grid where parameters are displayed
324
325 m_parameterGrid->CreateGrid( 0, 3 );
326
327 m_parameterGrid->SetColLabelValue( WIZ_COL_NAME, _( "Parameter" ) );
328 m_parameterGrid->SetColLabelValue( WIZ_COL_VALUE, _( "Value" ) );
329 m_parameterGrid->SetColLabelValue( WIZ_COL_UNITS, _( "Units" ) );
330
332 m_parameterGrid->SetColLabelAlignment( wxALIGN_LEFT, wxALIGN_CENTRE );
333 m_parameterGrid->AutoSizeColumns();
334
335 m_parameterGrid->AutoSizeRows();
336 m_parameterGrid->SetRowLabelSize( 0 );
337
338 m_parameterGrid->DisableDragGridSize();
339 m_parameterGrid->DisableDragColSize();
340
341 m_parameterGrid->Connect( wxEVT_SIZE,
342 wxSizeEventHandler( FOOTPRINT_WIZARD_FRAME::OnGridSize ),
343 nullptr, this );
344}
345
346
348{
349 if( m_pageList == nullptr )
350 return;
351
352 FOOTPRINT_WIZARD* footprintWizard = GetMyWizard();
353
354 if( !footprintWizard )
355 return;
356
357 m_pageList->Clear();
358 int max_page = footprintWizard->GetNumParameterPages();
359
360 for( int i = 0; i < max_page; i++ )
361 {
362 wxString name = footprintWizard->GetParameterPageName( i );
363 m_pageList->Append( name );
364 }
365
366 m_pageList->SetSelection( 0, true );
367
371 GetCanvas()->Refresh();
372}
373
374
376{
377 if( m_parameterGrid == nullptr )
378 return;
379
380 FOOTPRINT_WIZARD* footprintWizard = GetMyWizard();
381
382 if( footprintWizard == nullptr )
383 return;
384
385 m_parameterGrid->Freeze();
386
387 m_parameterGrid->ClearGrid();
388 m_parameterGridPage = m_pageList->GetSelection();
389
390 if( m_parameterGridPage < 0 ) // Should not happen
391 return;
392
393 // Get the list of names, values, types, hints and designators
394 wxArrayString designatorsList = footprintWizard->GetParameterDesignators( m_parameterGridPage );
395 wxArrayString namesList = footprintWizard->GetParameterNames( m_parameterGridPage );
396 wxArrayString valuesList = footprintWizard->GetParameterValues( m_parameterGridPage );
397 wxArrayString typesList = footprintWizard->GetParameterTypes( m_parameterGridPage );
398 wxArrayString hintsList = footprintWizard->GetParameterHints( m_parameterGridPage );
399
400 // Dimension the wxGrid
402 m_parameterGrid->AppendRows( namesList.size() );
403
404 wxString designator, name, value, units, hint;
405
406 for( unsigned int i = 0; i < namesList.size(); i++ )
407 {
408 designator = designatorsList[i];
409 name = namesList[i];
410 value = valuesList[i];
411 units = typesList[i];
412 hint = hintsList[i];
413
414 m_parameterGrid->SetRowLabelValue( i, designator );
415
416 // Set the 'Name'
417 m_parameterGrid->SetCellValue( i, WIZ_COL_NAME, name );
418 m_parameterGrid->SetReadOnly( i, WIZ_COL_NAME );
419
420 // Boolean parameters are displayed using a checkbox
421 if( units == WIZARD_PARAM_UNITS_BOOL )
422 {
423 // Set to ReadOnly as we delegate interactivity to GRID_TRICKS
424 m_parameterGrid->SetReadOnly( i, WIZ_COL_VALUE );
425 m_parameterGrid->SetCellRenderer( i, WIZ_COL_VALUE, new wxGridCellBoolRenderer );
426 }
427 // Parameters that can be selected from a list of multiple options
428 else if( units.Contains( wxT( "," ) ) ) // Indicates list of available options
429 {
430 wxStringTokenizer tokenizer( units, wxT( "," ) );
431 wxArrayString options;
432
433 while( tokenizer.HasMoreTokens() )
434 {
435 options.Add( tokenizer.GetNextToken() );
436 }
437
438 m_parameterGrid->SetCellEditor( i, WIZ_COL_VALUE,
439 new wxGridCellChoiceEditor( options ) );
440
441 units = wxT( "" );
442 }
443 else if( units == WIZARD_PARAM_UNITS_INTEGER ) // Integer parameters
444 {
445 m_parameterGrid->SetCellEditor( i, WIZ_COL_VALUE, new wxGridCellNumberEditor );
446 }
447 else if( ( units == WIZARD_PARAM_UNITS_MM ) ||
448 ( units == WIZARD_PARAM_UNITS_MILS ) ||
449 ( units == WIZARD_PARAM_UNITS_FLOAT ) ||
450 ( units == WIZARD_PARAM_UNITS_RADIANS ) ||
451 ( units == WIZARD_PARAM_UNITS_DEGREES ) ||
452 ( units == WIZARD_PARAM_UNITS_PERCENT ) )
453 {
454 // Non-integer numerical parameters
455 m_parameterGrid->SetCellEditor( i, WIZ_COL_VALUE, new wxGridCellFloatEditor );
456
457 // Convert separators to the locale-specific character
458 value.Replace( ",", wxNumberFormatter::GetDecimalSeparator() );
459 value.Replace( ".", wxNumberFormatter::GetDecimalSeparator() );
460 }
461
462 // Set the 'Units'
463 m_parameterGrid->SetCellValue( i, WIZ_COL_UNITS, units );
464 m_parameterGrid->SetReadOnly( i, WIZ_COL_UNITS );
465
466 // Set the 'Value'
467 m_parameterGrid->SetCellValue( i, WIZ_COL_VALUE, value );
468 }
469
471
472 m_parameterGrid->Thaw();
473}
474
476{
477 // Parameter grid is not yet configured
478 if( ( m_parameterGrid == nullptr ) || ( m_parameterGrid->GetNumberCols() == 0 ) )
479 return;
480
481 // first auto-size the columns to ensure enough space around text
482 m_parameterGrid->AutoSizeColumns();
483
484 // Auto-size the value column
485 int width = m_parameterGrid->GetClientSize().GetWidth() -
486 m_parameterGrid->GetRowLabelSize() -
487 m_parameterGrid->GetColSize( WIZ_COL_NAME ) -
488 m_parameterGrid->GetColSize( WIZ_COL_UNITS );
489
490 if( width > m_parameterGrid->GetColMinimalAcceptableWidth() )
491 {
492 m_parameterGrid->SetColSize( WIZ_COL_VALUE, width );
493 }
494}
495
496
497void FOOTPRINT_WIZARD_FRAME::ClickOnPageList( wxCommandEvent& event )
498{
499 if( m_pageList->GetSelection() >= 0 )
500 {
502 GetCanvas()->Refresh();
504 }
505}
506
507
509{
510 PCBNEW_SETTINGS* cfg = dynamic_cast<PCBNEW_SETTINGS*>( aCfg );
511 wxCHECK( cfg, /*void*/ );
512
514
516}
517
518
520{
521 PCBNEW_SETTINGS* cfg = dynamic_cast<PCBNEW_SETTINGS*>( aCfg );
522 wxCHECK( cfg, /*void*/ );
523
525
526 cfg->m_FootprintViewer.perspective = m_auimgr.SavePerspective().ToStdString();
527}
528
529
531{
532 auto cfg = dynamic_cast<PCBNEW_SETTINGS*>( aCfg );
533 wxASSERT( cfg );
534
535 return cfg ? &cfg->m_FootprintWizard : nullptr;
536}
537
538
539void FOOTPRINT_WIZARD_FRAME::OnActivate( wxActivateEvent& event )
540{
541 // Ensure we do not have old selection:
542 if( !event.GetActive() )
543 return;
544
545 if( !m_wizardListShown )
546 {
547 m_wizardListShown = true;
548 wxPostEvent( this, wxCommandEvent( wxEVT_TOOL, ID_FOOTPRINT_WIZARD_SELECT_WIZARD ) );
549 }
550#if 0
551 // Currently, we do not have a way to see if a Python wizard has changed,
552 // therefore the lists of parameters and option has to be rebuilt
553 // This code could be enabled when this way exists
554 bool footprintWizardsChanged = false;
555
556 if( footprintWizardsChanged )
557 {
558 // If we are here, the library list has changed, rebuild it
561 }
562#endif
563}
564
565
566void FOOTPRINT_WIZARD_FRAME::Update3DView( bool aMarkDirty, bool aRefresh, const wxString* aTitle )
567{
568 wxString frm3Dtitle;
569 frm3Dtitle.Printf( _( "ModView: 3D Viewer [%s]" ), m_wizardName );
570 PCB_BASE_FRAME::Update3DView( aMarkDirty, aRefresh, &frm3Dtitle );
571}
572
573
575{
576 return GetBoard()->GetFirstFootprint();
577}
578
579
581{
582 // Reload the Python plugins
583 // Because the board editor has also a plugin python menu,
584 // call the PCB_EDIT_FRAME RunAction() if the board editor is running
585 // Otherwise run the current RunAction().
586 PCB_EDIT_FRAME* pcbframe = static_cast<PCB_EDIT_FRAME*>( Kiway().Player( FRAME_PCB_EDITOR, false ) );
587
588 if( pcbframe )
590 else
592}
const char * name
Definition: DXF_plotter.cpp:59
wxBitmap KiBitmap(BITMAPS aBitmap, int aHeightTag)
Construct a wxBitmap from an image identifier Returns the image from the active theme if the image ha...
Definition: bitmap.cpp:104
@ module_wizard
static TOOL_ACTION pluginsReload
Definition: actions.h:285
static TOOL_ACTION zoomFitScreen
Definition: actions.h:141
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
Definition: app_settings.h:92
wxString m_ColorTheme
Active color theme name.
Definition: app_settings.h:216
std::shared_ptr< NET_SETTINGS > m_NetSettings
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:78
Information pertinent to a Pcbnew printed circuit board.
Definition: board.h:297
FOOTPRINT * GetFirstFootprint() const
Get the first footprint on the board or nullptr.
Definition: board.h:463
void SetVisibleAlls()
Change the bit-mask of visible element categories and layers.
Definition: board.cpp:878
BOARD_DESIGN_SETTINGS & GetDesignSettings() const
Definition: board.cpp:946
Color settings are a bit different than most of the settings objects in that there can be more than o...
Handles action that are shared between different applications.
Definition: common_tools.h:38
Create and handle a window for the 3d viewer connected to a Kiway and a pcbboard.
wxAuiManager m_auimgr
virtual void ClearMsgPanel()
Clear all messages from the message panel.
void SetMsgPanel(const std::vector< MSG_PANEL_ITEM > &aList)
Clear the message panel and populates it with the contents of aList.
virtual void ReCreateHToolbar()
static constexpr GAL_TYPE GAL_FALLBACK
void StopDrawing()
Prevent the GAL canvas from further drawing until it is recreated or StartDrawing() is called.
KIGFX::VIEW_CONTROLS * GetViewControls() const
Return a pointer to the #VIEW_CONTROLS instance used in the panel.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
void SetEventDispatcher(TOOL_DISPATCHER *aEventDispatcher)
Set a dispatcher that processes events and forwards them to tools.
virtual void GetMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList)
Populate aList of MSG_PANEL_ITEM objects with it's internal state for display purposes.
Definition: eda_item.h:212
Specialization of the wxAuiPaneInfo class for KiCad panels.
BOARD_ITEM_CONTAINER * GetModel() const override
void PythonPluginsReload()
Reload the Python plugins if they are newer than the already loaded, and load new plugins if any.
void initParameterGrid()
Prepare the grid where parameters are displayed.
void OnSize(wxSizeEvent &event) override
Recalculate the size of toolbars and display panel when the frame size changes.
void SaveSettings(APP_SETTINGS_BASE *aCfg) override
Save common frame parameters to a configuration data file.
int m_parameterGridPage
the page currently displayed by m_parameterGrid it is most of time the m_pageList selection,...
wxListBox * m_pageList
The list of pages.
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
void ReCreateParameterList()
Create the list of parameters for the current page.
void DisplayWizardInfos()
Show all the details about the current wizard.
COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const override
Helper to retrieve the current color settings.
wxString m_wizardName
name of the current wizard
bool m_wizardListShown
A show-once flag for the wizard list.
void updateView()
Rebuild the GAL view (reint tool manager, colors and drawings) must be run after any footprint change...
void Update3DView(bool aMarkDirty, bool aRefresh, const wxString *aTitle=nullptr) override
Update the 3D view, if the viewer is opened by this frame.
void ClickOnPageList(wxCommandEvent &event)
WX_GRID * m_parameterGrid
The list of parameters.
FOOTPRINT_WIZARD * GetMyWizard()
Reloads the wizard by name.
void ResizeParamColumns()
Expand the 'Value' column to fill available.
void UpdateMsgPanel() override
Redraw the message panel.
void ReCreatePageList()
Create or recreate the list of parameter pages for the current wizard.
void Process_Special_Functions(wxCommandEvent &event)
wxString m_auiPerspective
Encoded string describing the AUI layout.
void DefaultParameters(wxCommandEvent &event)
void ExportSelectedFootprint(wxCommandEvent &aEvent)
Will let the caller exit from the wait loop, and get the built footprint.
void SelectCurrentWizard(wxCommandEvent &event)
void OnGridSize(wxSizeEvent &aSizeEvent)
WINDOW_SETTINGS * GetWindowSettings(APP_SETTINGS_BASE *aCfg) override
Return a pointer to the window settings for this frame.
void OnActivate(wxActivateEvent &event)
Called when the frame frame is activate to reload the libraries and component lists that can be chang...
Toolbar configuration for the footprint wizard frame.
The parent class from where any footprint wizard class must derive.
virtual wxArrayString GetParameterHints(int aPage)=0
virtual wxArrayString GetParameterNames(int aPage)=0
virtual wxArrayString GetParameterValues(int aPage)=0
virtual wxString GetParameterPageName(int aPage)=0
virtual wxArrayString GetParameterTypes(int aPage)=0
virtual int GetNumParameterPages()=0
virtual wxArrayString GetParameterDesignators(int aPage)=0
Add mouse and command handling (such as cut, copy, and paste) to a WX_GRID instance.
Definition: grid_tricks.h:61
bool IsDismissed()
bool Destroy() override
Our version of Destroy() which is virtual from wxWidgets.
void DismissModal(bool aRetVal, const wxString &aResult=wxEmptyString)
bool IsModal() const override
Return true if the frame is shown in our modal mode and false if the frame is shown as an usual frame...
Definition: kiway_player.h:154
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition: kiway.h:285
virtual KIWAY_PLAYER * Player(FRAME_T aFrameType, bool doCreate=true, wxTopLevelWindow *aParent=nullptr)
Return the KIWAY_PLAYER* given a FRAME_T.
Definition: kiway.cpp:406
WINDOW_SETTINGS m_FootprintViewer
Gather all the actions that are shared by tools.
Definition: pcb_actions.h:51
Common, abstract interface for edit frames.
Base PCB main window class for Pcbnew, Gerbview, and CvPcb footprint viewer.
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
PCB_DRAW_PANEL_GAL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
void SaveSettings(APP_SETTINGS_BASE *aCfg) override
Save common frame parameters to a configuration data file.
BOARD * GetBoard() const
FOOTPRINT_EDITOR_SETTINGS * GetFootprintEditorSettings() const
EDA_3D_VIEWER_FRAME * Get3DViewerFrame()
virtual void Update3DView(bool aMarkDirty, bool aRefresh, const wxString *aTitle=nullptr)
Update the 3D view, if the viewer is opened by this frame.
Handle actions that are shared between different frames in PcbNew.
Definition: pcb_control.h:47
void UpdateColors()
Update the color settings in the painter and GAL.
virtual KIGFX::PCB_VIEW * GetView() const override
Return a pointer to the #VIEW instance used in the panel.
void DisplayBoard(BOARD *aBoard, PROGRESS_REPORTER *aReporter=nullptr)
Add all items from the current board to the VIEW, so they can be displayed by GAL.
The main frame for Pcbnew.
The selection tool: currently supports:
virtual SETTINGS_MANAGER & GetSettingsManager() const
Definition: pgm_base.h:125
Tool relating to pads and pad settings.
COLOR_SETTINGS * GetColorSettings(const wxString &aName="user")
Retrieve a color settings object that applications can read colors from.
T * GetToolbarSettings(const wxString &aFilename)
Return a handle to the given toolbar settings.
TOOL_MANAGER * m_toolManager
Definition: tools_holder.h:171
TOOL_MANAGER * GetToolManager() const
Return the MVC controller.
Definition: tools_holder.h:55
@ MODEL_RELOAD
Model changes (the sheet for a schematic)
Definition: tool_base.h:80
Master controller class:
Definition: tool_manager.h:62
void DeactivateTool()
Deactivate the currently active tool.
bool RunAction(const std::string &aActionName, T aParam)
Run the specified action immediately, pausing the current action to run the new one.
Definition: tool_manager.h:150
void ResetTools(TOOL_BASE::RESET_REASON aReason)
Reset all tools (i.e.
void SetEnvironment(EDA_ITEM *aModel, KIGFX::VIEW *aView, KIGFX::VIEW_CONTROLS *aViewControls, APP_SETTINGS_BASE *aSettings, TOOLS_HOLDER *aFrame)
Set the work environment (model, view, view controls and the parent window).
EDA_UNITS GetUserUnits() const
void SetColLabelSize(int aHeight)
Hide wxGrid's SetColLabelSize() method with one which makes sure the size is tall enough for the syst...
Definition: wx_grid.cpp:254
void ClearRows()
wxWidgets recently added an ASSERT which fires if the position is greater than or equal to the number...
Definition: wx_grid.h:193
#define _(s)
Declaration of the eda_3d_viewer class.
#define KICAD_DEFAULT_DRAWFRAME_STYLE
#define FOOTPRINT_WIZARD_FRAME_NAME
const wxString WIZARD_PARAM_UNITS_PERCENT
const wxString WIZARD_PARAM_UNITS_RADIANS
const wxString WIZARD_PARAM_UNITS_MM
const wxString WIZARD_PARAM_UNITS_INTEGER
const wxString WIZARD_PARAM_UNITS_BOOL
const wxString WIZARD_PARAM_UNITS_FLOAT
const wxString WIZARD_PARAM_UNITS_MILS
const wxString WIZARD_PARAM_UNITS_DEGREES
EVT_GRID_CMD_CELL_CHANGED(ID_FOOTPRINT_WIZARD_PARAMETER_LIST, FOOTPRINT_WIZARD_FRAME::ParametersUpdated) FOOTPRINT_WIZARD_FRAME
@ WIZ_COL_VALUE
@ WIZ_COL_NAME
@ WIZ_COL_UNITS
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
Definition: frame_type.h:33
@ FRAME_PCB_EDITOR
Definition: frame_type.h:42
@ FRAME_FOOTPRINT_WIZARD
Definition: frame_type.h:46
@ F_Cu
Definition: layer_ids.h:64
Message panel definition file.
@ ID_FOOTPRINT_WIZARD_PREVIOUS
Definition: pcbnew_id.h:105
@ ID_FOOTPRINT_WIZARD_NEXT
Definition: pcbnew_id.h:104
@ ID_FOOTPRINT_WIZARD_DONE
Definition: pcbnew_id.h:106
@ ID_FOOTPRINT_WIZARD_SELECT_WIZARD
Definition: pcbnew_id.h:109
@ ID_FOOTPRINT_WIZARD_RESET_TO_DEFAULT
Definition: pcbnew_id.h:110
@ ID_FOOTPRINT_WIZARD_PARAMETER_LIST
Definition: pcbnew_id.h:108
@ ID_FOOTPRINT_WIZARD_PAGE_LIST
Definition: pcbnew_id.h:107
BOARD * GetBoard()
PGM_BASE & Pgm()
The global program "get" accessor.
Definition: pgm_base.cpp:1071
see class PGM_BASE
KIWAY Kiway(KFCTL_STANDALONE)
Store the common settings that are saved and loaded for each window / frame.
Definition: app_settings.h:74
wxString perspective
Definition: app_settings.h:77
Definition of file extensions used in Kicad.