KiCad PCB EDA Suite
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
sch_base_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 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, you may find one here:
19 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20 * or you may search the http://www.gnu.org website for the version 2 license,
21 * or you may write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23 */
24
25#include <advanced_config.h>
26#include <base_units.h>
27#include <kiway.h>
29#include <pgm_base.h>
30#include <eda_list_dialog.h>
31#include <eeschema_settings.h>
35#include <sch_draw_panel.h>
36#include <sch_view.h>
37#include <sch_painter.h>
39#include <confirm.h>
41#include <project_sch.h>
42#include <symbol_library.h>
43#include <symbol_lib_table.h>
44#include <sch_base_frame.h>
45#include <design_block.h>
47#include <tool/action_toolbar.h>
48#include <tool/tool_manager.h>
51#include <view/view_controls.h>
52#include <wx/choicdlg.h>
53#include <wx/fswatcher.h>
54#include <wx/log.h>
55#include <wx/msgdlg.h>
56
58
59
61 SYMBOL_LIB* aCacheLib, wxWindow* aParent, bool aShowErrorMsg )
62{
63 wxCHECK_MSG( aLibTable, nullptr, wxS( "Invalid symbol library table." ) );
64
65 LIB_SYMBOL* symbol = nullptr;
66
67 try
68 {
69 symbol = aLibTable->LoadSymbol( aLibId );
70
71 if( !symbol && aCacheLib )
72 {
73 wxCHECK_MSG( aCacheLib->IsCache(), nullptr, wxS( "Invalid cache library." ) );
74
75 wxString cacheName = aLibId.GetLibNickname().wx_str();
76 cacheName << "_" << aLibId.GetLibItemName();
77 symbol = aCacheLib->FindSymbol( cacheName );
78 }
79 }
80 catch( const IO_ERROR& ioe )
81 {
82 if( aShowErrorMsg )
83 {
84 wxString msg = wxString::Format( _( "Error loading symbol %s from library '%s'." ),
85 aLibId.GetLibItemName().wx_str(),
86 aLibId.GetLibNickname().wx_str() );
87 DisplayErrorMessage( aParent, msg, ioe.What() );
88 }
89 }
90
91 return symbol;
92}
93
94
95SCH_BASE_FRAME::SCH_BASE_FRAME( KIWAY* aKiway, wxWindow* aParent, FRAME_T aWindowType,
96 const wxString& aTitle, const wxPoint& aPosition,
97 const wxSize& aSize, long aStyle, const wxString& aFrameName ) :
98 EDA_DRAW_FRAME( aKiway, aParent, aWindowType, aTitle, aPosition, aSize, aStyle,
99 aFrameName, schIUScale ),
100 m_base_frame_defaults( nullptr, "base_Frame_defaults" ),
101 m_selectionFilterPanel( nullptr )
102{
103 if( ( aStyle & wxFRAME_NO_TASKBAR ) == 0 )
104 createCanvas();
105
106 Bind( wxEVT_IDLE,
107 [this]( wxIdleEvent& aEvent )
108 {
109 // Handle cursor adjustments. While we can get motion and key events through
110 // wxWidgets, we can't get modifier-key-up events.
111 if( m_toolManager )
112 {
114
115 if( selTool )
116 selTool->OnIdle( aEvent );
117 }
118 } );
119
121}
122
123
126{}
127
128
130{
132}
133
134
136{
137 return dynamic_cast<EESCHEMA_SETTINGS*>( config() );
138}
139
140
142{
143 return dynamic_cast<SYMBOL_EDITOR_SETTINGS*>( config() );
144}
145
146
148{
149 switch( GetFrameType() )
150 {
151 case FRAME_SCH:
152 default:
153 return Pgm().GetSettingsManager().GetAppSettings<EESCHEMA_SETTINGS>( "eeschema" );
154
156 case FRAME_SCH_VIEWER:
158 return Pgm().GetSettingsManager().GetAppSettings<SYMBOL_EDITOR_SETTINGS>( "symbol_editor" );
159 }
160}
161
162
163void SCH_BASE_FRAME::SetPageSettings( const PAGE_INFO& aPageSettings )
164{
165 GetScreen()->SetPageSettings( aPageSettings );
166}
167
168
170{
171 return GetScreen()->GetPageSettings();
172}
173
174
176{
177 // GetSizeIU is compile time dependent:
179}
180
181
183{
184 wxASSERT( GetScreen() );
185 return GetScreen()->GetTitleBlock();
186}
187
188
190{
191 wxASSERT( GetScreen() );
192 GetScreen()->SetTitleBlock( aTitleBlock );
193}
194
195
197{
198 wxString line;
199 BASE_SCREEN* screen = GetScreen();
200
201 if( !screen )
202 return;
203
205
206 // Display absolute and relative coordinates
208 VECTOR2D d = cursorPos - screen->m_LocalOrigin;
209
210 line.Printf( wxS( "X %s Y %s" ),
211 MessageTextFromValue( cursorPos.x, false ),
212 MessageTextFromValue( cursorPos.y, false ) );
213 SetStatusText( line, 2 );
214
215 line.Printf( wxS( "dx %s dy %s dist %s" ),
216 MessageTextFromValue( d.x, false ),
217 MessageTextFromValue( d.y, false ),
218 MessageTextFromValue( hypot( d.x, d.y ), false ) );
219 SetStatusText( line, 3 );
220
223}
224
225
226LIB_SYMBOL* SCH_BASE_FRAME::GetLibSymbol( const LIB_ID& aLibId, bool aUseCacheLib,
227 bool aShowErrorMsg )
228{
229 SYMBOL_LIB* cache =
230 ( aUseCacheLib ) ? PROJECT_SCH::SchLibs( &Prj() )->GetCacheLibrary() : nullptr;
231
232 return SchGetLibSymbol( aLibId, PROJECT_SCH::SchSymbolLibTable( &Prj() ), cache, this,
233 aShowErrorMsg );
234}
235
236
237bool SCH_BASE_FRAME::saveSymbolLibTables( bool aGlobal, bool aProject )
238{
239 wxString msg;
240 bool success = true;
241
242 if( aGlobal )
243 {
244 try
245 {
247 }
248 catch( const IO_ERROR& ioe )
249 {
250 success = false;
251 msg.Printf( _( "Error saving global symbol library table:\n%s" ), ioe.What() );
252 DisplayErrorMessage( this, msg );
253 }
254 }
255
256 if( aProject && !Prj().GetProjectName().IsEmpty() )
257 {
258 wxFileName fn( Prj().GetProjectPath(), SYMBOL_LIB_TABLE::GetSymbolLibTableFileName() );
259
260 try
261 {
262 PROJECT_SCH::SchSymbolLibTable( &Prj() )->Save( fn.GetFullPath() );
263 }
264 catch( const IO_ERROR& ioe )
265 {
266 success = false;
267 msg.Printf( _( "Error saving project-specific symbol library table:\n%s" ),
268 ioe.What() );
269 DisplayErrorMessage( this, msg );
270 }
271 }
272
273 return success;
274}
275
276
278{
279 // If no project is loaded, always work with the global table
280 if( Prj().IsNullProject() )
281 {
283
284 if( aOptional )
285 {
286 wxMessageDialog dlg( this, _( "Add the library to the global library table?" ),
287 _( "Add To Global Library Table" ), wxYES_NO );
288
289 if( dlg.ShowModal() != wxID_OK )
290 ret = nullptr;
291 }
292
293 return ret;
294 }
295
296 wxArrayString libTableNames;
297 libTableNames.Add( _( "Global" ) );
298 libTableNames.Add( _( "Project" ) );
299
300 wxSingleChoiceDialog dlg( this, _( "Choose the Library Table to add the library to:" ),
301 _( "Add To Library Table" ), libTableNames );
302
303 if( aOptional )
304 {
305 dlg.FindWindow( wxID_CANCEL )->SetLabel( _( "Skip" ) );
306 dlg.FindWindow( wxID_OK )->SetLabel( _( "Add" ) );
307 }
308
309 if( dlg.ShowModal() != wxID_OK )
310 return nullptr;
311
312 switch( dlg.GetSelection() )
313 {
314 case 0: return &SYMBOL_LIB_TABLE::GetGlobalLibTable();
315 case 1: return PROJECT_SCH::SchSymbolLibTable( &Prj() );
316 default: return nullptr;
317 }
318}
319
320
321void SCH_BASE_FRAME::RedrawScreen( const VECTOR2I& aCenterPoint, bool aWarpPointer )
322{
323 GetCanvas()->GetView()->SetCenter( aCenterPoint );
324
325 if( aWarpPointer )
327
328 GetCanvas()->Refresh();
329}
330
331
333{
334 if( GetCanvas() && GetCanvas()->GetView() )
335 {
338 }
339}
340
341
343{
344 return static_cast<SCH_DRAW_PANEL*>( EDA_DRAW_FRAME::GetCanvas() );
345}
346
347
349{
350 if( GetCanvas() && GetCanvas()->GetView() )
351 {
352 if( KIGFX::PAINTER* painter = GetCanvas()->GetView()->GetPainter() )
353 return static_cast<SCH_RENDER_SETTINGS*>( painter->GetSettings() );
354 }
355
356 return nullptr;
357}
358
359
361{
363
364 SetCanvas( new SCH_DRAW_PANEL( this, wxID_ANY, wxPoint( 0, 0 ), m_frameSize,
367}
368
369
371{
373
374 try
375 {
376 if( !m_spaceMouse )
377 m_spaceMouse = std::make_unique<NL_SCHEMATIC_PLUGIN>();
378
379 m_spaceMouse->SetCanvas( GetCanvas() );
380 }
381 catch( const std::system_error& e )
382 {
383 wxLogTrace( wxT( "KI_TRACE_NAVLIB" ), e.what() );
384 }
385}
386
387
388void SCH_BASE_FRAME::UpdateItem( EDA_ITEM* aItem, bool isAddOrDelete, bool aUpdateRtree )
389{
390 EDA_ITEM* parent = aItem->GetParent();
391
392 if( aItem->Type() == SCH_SHEET_PIN_T )
393 {
394 // Sheet pins aren't in the view. Refresh their parent.
395 if( parent )
396 GetCanvas()->GetView()->Update( parent );
397 }
398 else
399 {
400 if( !isAddOrDelete )
401 GetCanvas()->GetView()->Update( aItem );
402
403 // Some children are drawn from their parents. Mark them for re-paint.
404 if( parent
405 && parent->IsType( { SCH_SYMBOL_T, SCH_SHEET_T, SCH_LABEL_LOCATE_ANY_T, SCH_TABLE_T } ) )
406 GetCanvas()->GetView()->Update( parent, KIGFX::REPAINT );
407 }
408
409 /*
410 * Be careful when calling this. Update will invalidate RTree iterators, so you cannot
411 * call this while doing things like `for( SCH_ITEM* item : screen->Items() )`
412 */
413 if( aUpdateRtree && dynamic_cast<SCH_ITEM*>( aItem ) )
414 GetScreen()->Update( static_cast<SCH_ITEM*>( aItem ) );
415
416 // Calling Refresh() here introduces a bi-stable state: when doing operations on a
417 // large number of items if at some point the refresh timer times out and does a
418 // refresh it will take long enough that the next item will also time out, and the
419 // next, and the next, etc.
420 // GetCanvas()->Refresh();
421}
422
423
425{
426 // We currently have two zoom-dependent renderings: text, which is rendered as bitmap text
427 // when too small to see the difference, and selection shadows.
428 //
429 // Because non-selected text is cached by OpenGL, we only apply the bitmap performance hack
430 // to selected text items.
431 //
432 // Thus, as it currently stands, all zoom-dependent items can be found in the list of selected
433 // items.
434 if( m_toolManager )
435 {
437 SELECTION& selection = selectionTool->GetSelection();
438 KIGFX::SCH_VIEW* view = GetCanvas()->GetView();
439
440 for( EDA_ITEM* item : selection )
441 {
442 if( item->RenderAsBitmap( view->GetGAL()->GetWorldScale() ) != item->IsShownAsBitmap()
444 {
445 view->Update( item, KIGFX::REPAINT );
446
447 EDA_ITEM* parent = item->GetParent();
448
449 // Symbol children are drawn from their parents. Mark them for re-paint.
450 if( parent && parent->Type() == SCH_SYMBOL_T )
451 GetCanvas()->GetView()->Update( parent, KIGFX::REPAINT );
452 }
453 }
454 }
455}
456
457
459{
460 // Null pointers will cause boost::ptr_vector to raise a boost::bad_pointer exception which
461 // will be unhandled. There is no valid reason to pass an invalid EDA_ITEM pointer to the
462 // screen append function.
463 wxCHECK( aItem, /* void */ );
464
465 SCH_SCREEN* screen = aScreen;
466
467 if( aScreen == nullptr )
468 screen = GetScreen();
469
470 if( aItem->Type() != SCH_TABLECELL_T )
471 screen->Append( (SCH_ITEM*) aItem );
472
473 if( screen == GetScreen() )
474 {
475 GetCanvas()->GetView()->Add( aItem );
476 UpdateItem( aItem, true ); // handle any additional parent semantics
477 }
478}
479
480
482{
483 auto screen = aScreen;
484
485 if( aScreen == nullptr )
486 screen = GetScreen();
487
488 if( screen == GetScreen() )
489 GetCanvas()->GetView()->Remove( aItem );
490
491 if( aItem->Type() != SCH_TABLECELL_T )
492 screen->Remove( (SCH_ITEM*) aItem );
493
494 if( screen == GetScreen() )
495 UpdateItem( aItem, true ); // handle any additional parent semantics
496}
497
498
500{
501 // Let tools add things to the view if necessary
502 if( m_toolManager )
504
506}
507
508
510{
511 return GetColorSettings()->GetColor( aLayer );
512}
513
514
516{
518
519 COLOR_SETTINGS* colorSettings = GetColorSettings( true );
520
521 GetCanvas()->GetView()->GetPainter()->GetSettings()->LoadColors( colorSettings );
523
527}
528
529
531{
532 if( !m_colorSettings || aForceRefresh )
533 {
535 EESCHEMA_SETTINGS* cfg = mgr.GetAppSettings<EESCHEMA_SETTINGS>( "eeschema" );
536 wxString colorTheme = cfg->m_ColorTheme;
537
539 {
540 SYMBOL_EDITOR_SETTINGS* symCfg =
541 mgr.GetAppSettings<SYMBOL_EDITOR_SETTINGS>( "symbol_editor" );
542
543 if( !symCfg->m_UseEeschemaColorSettings )
544 colorTheme = symCfg->m_ColorTheme;
545 }
546
547 COLOR_SETTINGS* colorSettings = mgr.GetColorSettings( colorTheme );
548
549 const_cast<SCH_BASE_FRAME*>( this )->m_colorSettings = colorSettings;
550 }
551
552 return m_colorSettings;
553}
554
555
557{
559}
560
561
562void SCH_BASE_FRAME::handleActivateEvent( wxActivateEvent& aEvent )
563{
565
566 if( m_spaceMouse )
567 m_spaceMouse->SetFocus( aEvent.GetActive() );
568}
569
570
571void SCH_BASE_FRAME::handleIconizeEvent( wxIconizeEvent& aEvent )
572{
574
575 if( m_spaceMouse )
576 m_spaceMouse->SetFocus( false );
577}
578
579
581{
583 PROJECT& prj = Prj();
584
585 if( PROJECT_SCH::SchSymbolLibTable( &prj )->IsEmpty() )
586 {
587 ShowInfoBarError( _( "No symbol libraries are loaded." ) );
588 return wxEmptyString;
589 }
590
591 wxArrayString headers;
592
593 headers.Add( _( "Library" ) );
594
595 std::vector< wxArrayString > itemsToDisplay;
596 std::vector< wxString > libNicknames = PROJECT_SCH::SchSymbolLibTable( &prj )->GetLogicalLibs();
597
598 for( const wxString& name : libNicknames )
599 {
600 // Exclude read only libraries.
601 if( !PROJECT_SCH::SchSymbolLibTable( &prj )->IsSymbolLibWritable( name ) )
602 continue;
603
606 {
607 wxArrayString item;
608
610 itemsToDisplay.push_back( item );
611 }
612 }
613
614 for( const wxString& name : libNicknames )
615 {
616 // Exclude read only libraries.
617 if( !PROJECT_SCH::SchSymbolLibTable( &prj )->IsSymbolLibWritable( name ) )
618 continue;
619
622 {
623 wxArrayString item;
624
625 item.Add( name );
626 itemsToDisplay.push_back( item );
627 }
628 }
629
630 wxString oldLibName = prj.GetRString( PROJECT::SCH_LIB_SELECT );
631
632 EDA_LIST_DIALOG dlg( this, _( "Select Symbol Library" ), headers, itemsToDisplay, oldLibName,
633 false );
634
635 if( dlg.ShowModal() != wxID_OK )
636 return wxEmptyString;
637
638 wxString libName = dlg.GetTextSelection();
639
640 if( !libName.empty() )
641 {
642 if( PROJECT_SCH::SchSymbolLibTable( &prj )->HasLibrary( libName ) )
643 prj.SetRString( PROJECT::SCH_LIB_SELECT, libName );
644 else
645 libName = wxEmptyString;
646 }
647
648 return libName;
649}
650
651
653{
654 Unbind( wxEVT_FSWATCHER, &SCH_BASE_FRAME::OnSymChange, this );
655
656 if( m_watcher )
657 {
658 wxLogTrace( "KICAD_LIB_WATCH", "Remove watch" );
659 m_watcher->RemoveAll();
660 m_watcher->SetOwner( nullptr );
661 m_watcher.reset();
662 }
663
664 wxString libfullname;
666
667 if( !aID || !tbl )
668 return;
669
670 try
671 {
672 const SYMBOL_LIB_TABLE_ROW* row = tbl->FindRow( aID->GetLibNickname() );
673
674 if( !row )
675 return;
676
677 libfullname = row->GetFullURI( true );
678 }
679 catch( const std::exception& e )
680 {
681 DisplayInfoMessage( this, e.what() );
682 return;
683 }
684 catch( const IO_ERROR& error )
685 {
686 wxLogTrace( "KICAD_LIB_WATCH", "Error: %s", error.What() );
687 return;
688 }
689
690 wxLogTrace( "KICAD_LIB_WATCH", "Setting up watcher for %s", libfullname );
691 m_watcherFileName.Assign( libfullname );
692
693 if( !m_watcherFileName.FileExists() )
694 return;
695
696 wxLog::EnableLogging( false );
697 m_watcherLastModified = m_watcherFileName.GetModificationTime();
698 wxLog::EnableLogging( true );
699
700 Bind( wxEVT_FSWATCHER, &SCH_BASE_FRAME::OnSymChange, this );
701 m_watcher = std::make_unique<wxFileSystemWatcher>();
702 m_watcher->SetOwner( this );
703
704 wxFileName fn;
705 fn.AssignDir( m_watcherFileName.GetPath() );
706 fn.DontFollowLink();
707
708 {
709 // Silence OS errors that come from the watcher
710 wxLogNull silence;
711 m_watcher->Add( fn );
712 }
713}
714
715
716void SCH_BASE_FRAME::OnSymChange( wxFileSystemWatcherEvent& aEvent )
717{
719
720 wxLogTrace( "KICAD_LIB_WATCH", "OnSymChange: %s, watcher file: %s",
721 aEvent.GetPath().GetFullPath(), m_watcherFileName.GetFullPath() );
722
723 if( !libs || !m_watcher || !m_watcher.get() || m_watcherFileName.GetPath().IsEmpty() )
724 return;
725
726 if( aEvent.GetPath() != m_watcherFileName )
727 return;
728
729 // Start the debounce timer (set to 1 second)
730 if( !m_watcherDebounceTimer.StartOnce( 1000 ) )
731 {
732 wxLogTrace( "KICAD_LIB_WATCH", "Failed to start the debounce timer" );
733 return;
734 }
735}
736
737
739{
740 wxLogTrace( "KICAD_LIB_WATCH", "OnSymChangeDebounceTimer" );
741
742 // Disable logging to avoid spurious messages and check if the file has changed
743 wxLog::EnableLogging( false );
744 wxDateTime lastModified = m_watcherFileName.GetModificationTime();
745 wxLog::EnableLogging( true );
746
747 if( lastModified == m_watcherLastModified || !lastModified.IsValid() )
748 return;
749
750 m_watcherLastModified = lastModified;
751
753 || IsOK( this, _( "The library containing the current symbol has changed.\n"
754 "Do you want to reload the library?" ) ) )
755 {
756 wxLogTrace( "KICAD_LIB_WATCH", "Sending refresh symbol mail" );
757 std::string libName = m_watcherFileName.GetFullPath().ToStdString();
760 }
761}
const char * name
Definition: DXF_plotter.cpp:59
constexpr EDA_IU_SCALE schIUScale
Definition: base_units.h:110
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
Handles how to draw a screen (a board, a schematic ...)
Definition: base_screen.h:41
VECTOR2D m_LocalOrigin
Relative Screen cursor coordinate (on grid) in user units.
Definition: base_screen.h:90
Color settings are a bit different than most of the settings objects in that there can be more than o...
COLOR4D GetColor(int aLayer) const
int ShowModal() override
FRAME_T GetFrameType() const
virtual APP_SETTINGS_BASE * config() const
Return the settings object used in SaveSettings(), and is overloaded in KICAD_MANAGER_FRAME.
virtual void handleIconizeEvent(wxIconizeEvent &aEvent)
Handle a window iconize event.
virtual bool IsContentModified() const
Get if the contents of the frame have been modified since the last save.
void ShowInfoBarError(const wxString &aErrorMsg, bool aShowCloseButton=false, WX_INFOBAR::MESSAGE_TYPE aType=WX_INFOBAR::MESSAGE_TYPE::GENERIC)
Show the WX_INFOBAR displayed on the top of the canvas with a message and an error icon on the left o...
bool IsType(FRAME_T aType) const
The base class for create windows for drawing purpose.
virtual void ActivateGalCanvas()
Use to start up the GAL drawing canvas.
COLOR_SETTINGS * m_colorSettings
EDA_DRAW_PANEL_GAL::GAL_TYPE m_canvasType
The current canvas type.
virtual BASE_SCREEN * GetScreen() const
Return a pointer to a BASE_SCREEN or one of its derivatives.
void DisplayUnitsMsg()
Display current unit pane in the status bar.
EDA_DRAW_PANEL_GAL::GAL_TYPE loadCanvasTypeSetting(APP_SETTINGS_BASE *aCfg=nullptr)
Return the canvas type stored in the application settings.
GAL_DISPLAY_OPTIONS_IMPL & GetGalDisplayOptions()
Return a reference to the gal rendering options used by GAL for rendering.
void SetCanvas(EDA_DRAW_PANEL_GAL *aPanel)
virtual void handleActivateEvent(wxActivateEvent &aEvent)
Handle a window activation event.
void UpdateStatusBar() override
Update the status bar information.
virtual EDA_DRAW_PANEL_GAL * GetCanvas() const
Return a pointer to GAL-based canvas of given EDA draw frame.
virtual void DisplayGridMsg()
Display current grid size in the status bar.
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
KIGFX::VIEW_CONTROLS * GetViewControls() const
Return a pointer to the #VIEW_CONTROLS instance used in the panel.
void ForceRefresh()
Force a redraw.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
KIGFX::GAL * GetGAL() const
Return a pointer to the GAL instance used in the panel.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition: eda_item.h:95
KICAD_T Type() const
Returns the type of object.
Definition: eda_item.h:107
virtual bool IsType(const std::vector< KICAD_T > &aScanTypes) const
Check whether the item is one of the listed types.
Definition: eda_item.h:180
EDA_ITEM * GetParent() const
Definition: eda_item.h:109
A dialog which shows:
wxString GetTextSelection(int aColumn=0)
Return the selected text from aColumn in the wxListCtrl in the dialog.
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
Definition: ki_exception.h:77
virtual const wxString What() const
A composite of Problem() and Where()
Definition: exceptions.cpp:30
A color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:104
void SetAxesColor(const COLOR4D &aAxesColor)
Set the axes color.
double GetWorldScale() const
Get the world scale.
Contains all the knowledge about how to draw graphical object onto any particular output device.
Definition: painter.h:59
virtual RENDER_SETTINGS * GetSettings()=0
Return a pointer to current settings that are going to be used when drawing items.
virtual void LoadColors(const COLOR_SETTINGS *aSettings)
static std::vector< KICAD_T > g_ScaledSelectionTypes
Definition: sch_painter.h:142
virtual void CenterOnCursor()=0
Set the viewport center to the current cursor position and warps the cursor to the screen center.
VECTOR2D GetCursorPosition() const
Return the current cursor position in world coordinates.
virtual void Add(VIEW_ITEM *aItem, int aDrawPriority=-1)
Add a VIEW_ITEM to the view.
Definition: view.cpp:297
virtual void Remove(VIEW_ITEM *aItem)
Remove a VIEW_ITEM from the view.
Definition: view.cpp:332
virtual void Update(const VIEW_ITEM *aItem, int aUpdateFlags) const
For dynamic VIEWs, inform the associated VIEW that the graphical representation of this item has chan...
Definition: view.cpp:1673
GAL * GetGAL() const
Return the #GAL this view is using to draw graphical primitives.
Definition: view.h:198
void RecacheAllItems()
Rebuild GAL display lists.
Definition: view.cpp:1439
void UpdateAllItems(int aUpdateFlags)
Update all items in the view according to the given flags.
Definition: view.cpp:1549
PAINTER * GetPainter() const
Return the painter object used by the view for drawing #VIEW_ITEMS.
Definition: view.h:216
void SetCenter(const VECTOR2D &aCenter)
Set the center point of the VIEW (i.e.
Definition: view.cpp:586
void MarkTargetDirty(int aTarget)
Set or clear target 'dirty' flag.
Definition: view.h:635
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition: kiway.h:285
virtual void ExpressMail(FRAME_T aDestination, MAIL_T aCommand, std::string &aPayload, wxWindow *aSource=nullptr)
Send aPayload to aDestination from aSource.
Definition: kiway.cpp:527
A logical library item identifier and consists of various portions much like a URI.
Definition: lib_id.h:49
const UTF8 & GetLibItemName() const
Definition: lib_id.h:102
const UTF8 & GetLibNickname() const
Return the logical library name portion of a LIB_ID.
Definition: lib_id.h:87
Define a library symbol object.
Definition: lib_symbol.h:85
const wxString GetFullURI(bool aSubstituted=false) const
Return the full location specifying URI for the LIB, either in original UI form or in environment var...
std::vector< wxString > GetLogicalLibs()
Return the logical library names, all of them that are pertinent to a look up done on this LIB_TABLE.
void Save(const wxString &aFileName) const
Write this library table to aFileName in s-expression form.
static const wxString GetPinningSymbol()
Describe the page size and margins of a paper page on which to eventually print or plot.
Definition: page_info.h:59
const VECTOR2D GetSizeIU(double aIUScale) const
Gets the page size in internal units.
Definition: page_info.h:171
virtual COMMON_SETTINGS * GetCommonSettings() const
Definition: pgm_base.cpp:687
virtual SETTINGS_MANAGER & GetSettingsManager() const
Definition: pgm_base.h:125
std::vector< wxString > m_PinnedSymbolLibs
Below are project-level settings that have not been moved to a dedicated file.
Definition: project_file.h:133
static SYMBOL_LIB_TABLE * SchSymbolLibTable(PROJECT *aProject)
Accessor for project symbol library table.
static SYMBOL_LIBS * SchLibs(PROJECT *aProject)
These are all prefaced with "Sch".
Definition: project_sch.cpp:90
Container for project specific data.
Definition: project.h:64
@ SCH_LIB_SELECT
Definition: project.h:220
virtual PROJECT_FILE & GetProjectFile() const
Definition: project.h:203
virtual void SetRString(RSTRING_T aStringId, const wxString &aString)
Store a "retained string", which is any session and project specific string identified in enum RSTRIN...
Definition: project.cpp:318
virtual const wxString & GetRString(RSTRING_T aStringId)
Return a "retained string", which is any session and project specific string identified in enum RSTRI...
Definition: project.cpp:329
A shim class between EDA_DRAW_FRAME and several derived classes: SYMBOL_EDIT_FRAME,...
virtual void RedrawScreen(const VECTOR2I &aCenterPoint, bool aWarpPointer)
SCH_BASE_FRAME(KIWAY *aKiway, wxWindow *aParent, FRAME_T aWindowType, const wxString &aTitle, const wxPoint &aPosition, const wxSize &aSize, long aStyle, const wxString &aFrameName)
void UpdateStatusBar() override
Update the status bar information.
SCH_RENDER_SETTINGS * GetRenderSettings()
void ActivateGalCanvas() override
Use to start up the GAL drawing canvas.
const VECTOR2I GetPageSizeIU() const override
Works off of GetPageSettings() to return the size of the paper page in the internal units of this par...
void SetPageSettings(const PAGE_INFO &aPageSettings) override
void handleIconizeEvent(wxIconizeEvent &aEvent) override
Handle a window iconize event.
void AddToScreen(EDA_ITEM *aItem, SCH_SCREEN *aScreen=nullptr)
Add an item to the screen (and view) aScreen is the screen the item is located on,...
void OnSymChange(wxFileSystemWatcherEvent &aEvent)
Handler for Symbol change events.
SCH_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
SYMBOL_EDITOR_SETTINGS * libeditconfig() const
SCH_DRAW_PANEL * GetCanvas() const override
Return a pointer to GAL-based canvas of given EDA draw frame.
APP_SETTINGS_BASE * GetViewerSettingsBase() const
void HardRedraw() override
Rebuild the GAL and redraws the screen.
wxTimer m_watcherDebounceTimer
SYMBOL_LIB_TABLE * SelectSymLibTable(bool aOptional=false)
Display a dialog asking the user to select a symbol library table.
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
wxString SelectLibraryFromList()
Display a list of loaded libraries and allows the user to select a library.
void SyncView()
Mark all items for refresh.
std::unique_ptr< NL_SCHEMATIC_PLUGIN > m_spaceMouse
wxDateTime m_watcherLastModified
std::unique_ptr< wxFileSystemWatcher > m_watcher
These are file watchers for the symbol library tables.
virtual ~SCH_BASE_FRAME()
Needs to be in the cpp file to encode the sizeof() for std::unique_ptr.
const TITLE_BLOCK & GetTitleBlock() const override
bool saveSymbolLibTables(bool aGlobal, bool aProject)
Save Symbol Library Tables to disk.
void RefreshZoomDependentItems()
Mark selected items for refresh.
EESCHEMA_SETTINGS * eeconfig() const
void SetTitleBlock(const TITLE_BLOCK &aTitleBlock) override
LIB_SYMBOL * GetLibSymbol(const LIB_ID &aLibId, bool aUseCacheLib=false, bool aShowErrorMsg=false)
Load symbol from symbol library table.
virtual void UpdateItem(EDA_ITEM *aItem, bool isAddOrDelete=false, bool aUpdateRtree=false)
Mark an item for refresh.
void handleActivateEvent(wxActivateEvent &aEvent) override
Handle a window activation event.
COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const override
Returns a pointer to the active color theme settings.
wxFileName m_watcherFileName
void setSymWatcher(const LIB_ID *aSymbol)
Creates (or removes) a watcher on the specified symbol library.
const PAGE_INFO & GetPageSettings() const override
COLOR4D GetDrawBgColor() const override
void OnSymChangeDebounceTimer(wxTimerEvent &aEvent)
Handler for the filesystem watcher debounce timer.
void RemoveFromScreen(EDA_ITEM *aItem, SCH_SCREEN *aScreen)
Remove an item from the screen (and view) aScreen is the screen the item is located on,...
COLOR4D GetLayerColor(SCH_LAYER_ID aLayer)
Helper to retrieve a layer color from the global color settings.
KIGFX::SCH_VIEW * GetView() const override
Return a pointer to the #VIEW instance used in the panel.
Base class for any item which can be embedded within the SCHEMATIC container class,...
Definition: sch_item.h:168
const PAGE_INFO & GetPageSettings() const
Definition: sch_screen.h:134
void SetTitleBlock(const TITLE_BLOCK &aTitleBlock)
Definition: sch_screen.h:160
void Append(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Definition: sch_screen.cpp:155
void SetPageSettings(const PAGE_INFO &aPageSettings)
Definition: sch_screen.h:135
const TITLE_BLOCK & GetTitleBlock() const
Definition: sch_screen.h:158
void Update(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Update aItem's bounding box in the tree.
Definition: sch_screen.cpp:318
SCH_SELECTION & GetSelection()
void OnIdle(wxIdleEvent &aEvent)
Zoom the screen to fit the bounding box for cross probing/selection sync.
COLOR_SETTINGS * GetColorSettings(const wxString &aName="user")
Retrieve a color settings object that applications can read colors from.
T * GetAppSettings(const wxString &aFilename)
Return a handle to the a given settings by type.
A collection of SYMBOL_LIB objects.
Hold a record identifying a symbol library accessed by the appropriate symbol library SCH_IO object i...
static SYMBOL_LIB_TABLE & GetGlobalLibTable()
static const wxString GetSymbolLibTableFileName()
static wxString GetGlobalTableFileName()
Fetch the global symbol library table file name.
LIB_SYMBOL * LoadSymbol(const wxString &aNickname, const wxString &aName)
Load a LIB_SYMBOL having aName from the library given by aNickname.
SYMBOL_LIB_TABLE_ROW * FindRow(const wxString &aNickName, bool aCheckIfEnabled=false)
Return an SYMBOL_LIB_TABLE_ROW if aNickName is found in this table or in any chained fallBack table f...
Object used to load, save, search, and otherwise manipulate symbol library files.
bool IsCache() const
LIB_SYMBOL * FindSymbol(const wxString &aName) const
Find LIB_SYMBOL by aName.
Hold the information shown in the lower right corner of a plot, printout, or editing view.
Definition: title_block.h:41
TOOL_MANAGER * m_toolManager
Definition: tools_holder.h:171
@ MODEL_RELOAD
Model changes (the sheet for a schematic)
Definition: tool_base.h:80
void ResetTools(TOOL_BASE::RESET_REASON aReason)
Reset all tools (i.e.
wxString MessageTextFromValue(double aValue, bool aAddUnitLabel=true, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE) const
A lower-precision version of StringFromValue().
wxString wx_str() const
Definition: utf8.cpp:45
bool IsOK(wxWindow *aParent, const wxString &aMessage)
Display a yes/no dialog with aMessage and returns the user response.
Definition: confirm.cpp:249
void DisplayInfoMessage(wxWindow *aParent, const wxString &aMessage, const wxString &aExtraInfo)
Display an informational message box with aMessage.
Definition: confirm.cpp:221
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
Definition: confirm.cpp:194
This file is part of the common library.
#define _(s)
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
Definition: frame_type.h:33
@ FRAME_SCH_SYMBOL_EDITOR
Definition: frame_type.h:35
@ FRAME_SCH_VIEWER
Definition: frame_type.h:36
@ FRAME_SCH
Definition: frame_type.h:34
@ FRAME_SYMBOL_CHOOSER
Definition: frame_type.h:37
SCH_LAYER_ID
Eeschema drawing layers.
Definition: layer_ids.h:438
@ LAYER_SCHEMATIC_GRID_AXES
Definition: layer_ids.h:476
@ LAYER_SCHEMATIC_BACKGROUND
Definition: layer_ids.h:477
@ MAIL_REFRESH_SYMBOL
Definition: mail_type.h:59
@ REPAINT
Item needs to be redrawn.
Definition: view_item.h:58
@ ALL
All except INITIAL_ADD.
Definition: view_item.h:59
@ TARGET_NONCACHED
Auxiliary rendering target (noncached)
Definition: definitions.h:38
bool contains(const _Container &__container, _Value __value)
Returns true if the container contains the given value.
Definition: kicad_algo.h:100
Declaration of the NL_SCHEMATIC_PLUGIN class.
PGM_BASE & Pgm()
The global program "get" accessor.
Definition: pgm_base.cpp:1071
see class PGM_BASE
LIB_SYMBOL * SchGetLibSymbol(const LIB_ID &aLibId, SYMBOL_LIB_TABLE *aLibTable, SYMBOL_LIB *aCacheLib, wxWindow *aParent, bool aShowErrorMsg)
Load symbol from symbol library table.
LIB_SYMBOL * SchGetLibSymbol(const LIB_ID &aLibId, SYMBOL_LIB_TABLE *aLibTable, SYMBOL_LIB *aCacheLib=nullptr, wxWindow *aParent=nullptr, bool aShowErrorMsg=false)
Load symbol from symbol library table.
KIWAY Kiway(KFCTL_STANDALONE)
std::vector< wxString > pinned_symbol_libs
const double IU_PER_MILS
Definition: base_units.h:77
Definition for symbol library class.
@ SCH_SYMBOL_T
Definition: typeinfo.h:172
@ SCH_TABLECELL_T
Definition: typeinfo.h:166
@ SCH_SHEET_PIN_T
Definition: typeinfo.h:173