KiCad PCB EDA Suite
Loading...
Searching...
No Matches
sch_base_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 (C) 2015 SoftPLC Corporation, Dick Hollenbeck <[email protected]>
5 * Copyright (C) 2015-2022 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#ifndef SCH_BASE_FRAME_H_
26#define SCH_BASE_FRAME_H_
27
28#include <eda_draw_frame.h>
29#include <frame_type.h>
30#include <sch_draw_panel.h>
31#include <sch_screen.h>
32#include <schematic_settings.h>
33
34#include <stddef.h>
35#include <utility>
36#include <vector>
37#include <wx/event.h>
38#include <wx/datetime.h>
39#include <wx/gdicmn.h>
40#include <wx/string.h>
41#include <wx/timer.h>
42
43#include <template_fieldnames.h>
44
45
47class PAGE_INFO;
48class TITLE_BLOCK;
51class LIB_SYMBOL;
52class SYMBOL_LIB;
54class LIB_ID;
60
61#ifdef wxHAS_INOTIFY
62#define wxFileSystemWatcher wxInotifyFileSystemWatcher
63#elif defined( wxHAS_KQUEUE ) && defined( wxHAVE_FSEVENTS_FILE_NOTIFICATIONS )
64#define wxFileSystemWatcher wxFsEventsFileSystemWatcher
65#elif defined( wxHAS_KQUEUE )
66#define wxFileSystemWatcher wxKqueueFileSystemWatcher
67#elif defined( __WINDOWS__ )
68#define wxFileSystemWatcher wxMSWFileSystemWatcher
69#else
70#define wxFileSystemWatcher wxPollingFileSystemWatcher
71#endif
72
74class wxFileSystemWatcherEvent;
75
90LIB_SYMBOL* SchGetLibSymbol( const LIB_ID& aLibId, SYMBOL_LIB_TABLE* aLibTable,
91 SYMBOL_LIB* aCacheLib = nullptr, wxWindow* aParent = nullptr,
92 bool aShowErrorMsg = false );
93
104{
105public:
106 SCH_BASE_FRAME( KIWAY* aKiway, wxWindow* aParent, FRAME_T aWindowType, const wxString& aTitle,
107 const wxPoint& aPosition, const wxSize& aSize, long aStyle,
108 const wxString & aFrameName );
109
110 virtual ~SCH_BASE_FRAME();
111
112 void createCanvas();
113
114 SCH_DRAW_PANEL* GetCanvas() const override;
115 SCH_SCREEN* GetScreen() const override;
116
118
120
121 void LoadSettings( APP_SETTINGS_BASE* aCfg ) override;
122 void SaveSettings( APP_SETTINGS_BASE* aCfg ) override;
123
125
126 COLOR4D GetDrawBgColor() const override;
127
131 virtual bool GetShowAllPins() const { return true; }
132
133 void SetPageSettings( const PAGE_INFO& aPageSettings ) override;
134 const PAGE_INFO& GetPageSettings () const override;
135 const VECTOR2I GetPageSizeIU() const override;
136
137 const VECTOR2I& GetGridOrigin() const override
138 {
139 static VECTOR2I zero;
140 return zero;
141 }
142 void SetGridOrigin( const VECTOR2I& aPoint ) override {}
143
144 const TITLE_BLOCK& GetTitleBlock() const override;
145 void SetTitleBlock( const TITLE_BLOCK& aTitleBlock ) override;
146
147 void UpdateStatusBar() override;
148
168 std::vector<PICKED_SYMBOL>& aHistoryList,
169 std::vector<PICKED_SYMBOL>& aAlreadyPlaced,
170 bool aShowFootprints, const LIB_ID* aHighlight = nullptr,
171 bool aAllowFields = true );
172
182 LIB_SYMBOL* GetLibSymbol( const LIB_ID& aLibId, bool aUseCacheLib = false,
183 bool aShowErrorMsg = false );
184
192 wxString SelectLibraryFromList();
193
200 SYMBOL_LIB_TABLE* SelectSymLibTable( bool aOptional = false );
201
202 virtual void RedrawScreen( const VECTOR2I& aCenterPoint, bool aWarpPointer );
203
204 void HardRedraw() override;
205
210 void AddToScreen( EDA_ITEM* aItem, SCH_SCREEN* aScreen = nullptr );
211
216 void RemoveFromScreen( EDA_ITEM* aItem, SCH_SCREEN* aScreen );
217
221 virtual void UpdateItem( EDA_ITEM* aItem, bool isAddOrDelete = false,
222 bool aUpdateRtree = false );
223
228
232 void SyncView();
233
234 void CommonSettingsChanged( bool aEnvVarsChanged, bool aTextVarsChanged ) override;
235
240
241 COLOR_SETTINGS* GetColorSettings( bool aForceRefresh = false ) const override;
242
243 void ActivateGalCanvas() override;
244
248 void OnSymChange( wxFileSystemWatcherEvent& aEvent );
249
253 void OnSymChangeDebounceTimer( wxTimerEvent& aEvent );
254
262 void SetSymModificationTime( const wxDateTime& aTime )
263 {
264 m_watcherLastModified = aTime;
265 }
266
267protected:
268 void handleActivateEvent( wxActivateEvent& aEvent ) override;
269
270 void handleIconizeEvent( wxIconizeEvent& aEvent ) override;
271
279 bool saveSymbolLibTables( bool aGlobal, bool aProject );
280
285 void setSymWatcher( const LIB_ID* aSymbol );
286
292
296
298
299private:
300
302 std::unique_ptr<wxFileSystemWatcher> m_watcher;
306
308};
309
310#endif // SCH_BASE_FRAME_H_
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
Definition: app_settings.h:92
Color settings are a bit different than most of the settings objects in that there can be more than o...
The base class for create windows for drawing purpose.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition: eda_item.h:89
A color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:104
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition: kiway.h:279
A logical library item identifier and consists of various portions much like a URI.
Definition: lib_id.h:49
Define a library symbol object.
Definition: lib_symbol.h:78
The class that implements the public interface to the SpaceMouse plug-in.
Describe the page size and margins of a paper page on which to eventually print or plot.
Definition: page_info.h:59
These are loaded from Eeschema settings but then overwritten by the project settings.
A shim class between EDA_DRAW_FRAME and several derived classes: SYMBOL_EDIT_FRAME,...
void SetGridOrigin(const VECTOR2I &aPoint) override
virtual void RedrawScreen(const VECTOR2I &aCenterPoint, bool aWarpPointer)
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 SaveSettings(APP_SETTINGS_BASE *aCfg) override
Save common frame parameters to a configuration data file.
void handleIconizeEvent(wxIconizeEvent &aEvent) override
Handle a window iconize event.
void LoadSettings(APP_SETTINGS_BASE *aCfg) override
Load common frame parameters from a configuration file.
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.
void HardRedraw() override
Rebuild the GAL and redraws the screen.
PICKED_SYMBOL PickSymbolFromLibrary(const SYMBOL_LIBRARY_FILTER *aFilter, std::vector< PICKED_SYMBOL > &aHistoryList, std::vector< PICKED_SYMBOL > &aAlreadyPlaced, bool aShowFootprints, const LIB_ID *aHighlight=nullptr, bool aAllowFields=true)
Call the library viewer to select symbol to import into schematic.
Definition: picksymbol.cpp:49
SCHEMATIC_SETTINGS m_base_frame_defaults
These are only used by symbol_editor.
wxTimer m_watcherDebounceTimer
SYMBOL_LIB_TABLE * SelectSymLibTable(bool aOptional=false)
Display a dialog asking the user to select a symbol library table.
wxString SelectLibraryFromList()
Display a list of loaded libraries and allows the user to select a library.
void SyncView()
Mark all items for refresh.
wxDateTime m_watcherLastModified
std::unique_ptr< wxFileSystemWatcher > m_watcher
These are file watchers for the symbol library tables.
virtual void updateSelectionFilterVisbility()
Selection filter panel doesn't have a dedicated visibility control, so show it if any other AUI panel...
void SetSymModificationTime(const wxDateTime &aTime)
Set the modification time of the symbol library table file.
virtual ~SCH_BASE_FRAME()
const TITLE_BLOCK & GetTitleBlock() const override
void CommonSettingsChanged(bool aEnvVarsChanged, bool aTextVarsChanged) override
Notification event that some of the common (suite-wide) settings have changed.
const VECTOR2I & GetGridOrigin() const override
Return the absolute coordinates of the origin of the snap grid.
NL_SCHEMATIC_PLUGIN * m_spaceMouse
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
PANEL_SCH_SELECTION_FILTER * m_selectionFilterPanel
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.
virtual bool GetShowAllPins() const
Allow some frames to show/hide hidden pins.
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.
The symbol library editor main window.
Helper object to filter a list of libraries.
Object used to load, save, search, and otherwise manipulate symbol library files.
Symbol library viewer main window.
Hold the information shown in the lower right corner of a plot, printout, or editing view.
Definition: title_block.h:41
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
Definition: frame_type.h:33
SCH_LAYER_ID
Eeschema drawing layers.
Definition: layer_ids.h:354
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.
#define wxFileSystemWatcher