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 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#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
122
123 void LoadSettings( APP_SETTINGS_BASE* aCfg ) override;
124 void SaveSettings( APP_SETTINGS_BASE* aCfg ) override;
125
127
128 COLOR4D GetDrawBgColor() const override;
129
133 virtual bool GetShowAllPins() const { return true; }
134
135 void SetPageSettings( const PAGE_INFO& aPageSettings ) override;
136 const PAGE_INFO& GetPageSettings () const override;
137 const VECTOR2I GetPageSizeIU() const override;
138
139 const VECTOR2I& GetGridOrigin() const override
140 {
141 static VECTOR2I zero;
142 return zero;
143 }
144 void SetGridOrigin( const VECTOR2I& aPoint ) override {}
145
146 const TITLE_BLOCK& GetTitleBlock() const override;
147 void SetTitleBlock( const TITLE_BLOCK& aTitleBlock ) override;
148
149 void UpdateStatusBar() override;
150
151
171 std::vector<PICKED_SYMBOL>& aHistoryList,
172 std::vector<PICKED_SYMBOL>& aAlreadyPlaced,
173 bool aShowFootprints, const LIB_ID* aHighlight = nullptr,
174 bool aAllowFields = true );
175
185 LIB_SYMBOL* GetLibSymbol( const LIB_ID& aLibId, bool aUseCacheLib = false,
186 bool aShowErrorMsg = false );
187
195 wxString SelectLibraryFromList();
196
203 SYMBOL_LIB_TABLE* SelectSymLibTable( bool aOptional = false );
204
205 virtual void RedrawScreen( const VECTOR2I& aCenterPoint, bool aWarpPointer );
206
207 void HardRedraw() override;
208
213 void AddToScreen( EDA_ITEM* aItem, SCH_SCREEN* aScreen = nullptr );
214
219 void RemoveFromScreen( EDA_ITEM* aItem, SCH_SCREEN* aScreen );
220
224 virtual void UpdateItem( EDA_ITEM* aItem, bool isAddOrDelete = false,
225 bool aUpdateRtree = false );
226
231
235 void SyncView();
236
237 void CommonSettingsChanged( bool aEnvVarsChanged, bool aTextVarsChanged ) override;
238
243
244 COLOR_SETTINGS* GetColorSettings( bool aForceRefresh = false ) const override;
245
246 void ActivateGalCanvas() override;
247
251 void OnSymChange( wxFileSystemWatcherEvent& aEvent );
252
256 void OnSymChangeDebounceTimer( wxTimerEvent& aEvent );
257
265 void SetSymModificationTime( const wxDateTime& aTime )
266 {
267 m_watcherLastModified = aTime;
268 }
269
270protected:
271 void handleActivateEvent( wxActivateEvent& aEvent ) override;
272
273 void handleIconizeEvent( wxIconizeEvent& aEvent ) override;
274
282 bool saveSymbolLibTables( bool aGlobal, bool aProject );
283
288 void setSymWatcher( const LIB_ID* aSymbol );
289
295
299
301
302private:
303
305 std::unique_ptr<wxFileSystemWatcher> m_watcher;
309
310 std::unique_ptr<NL_SCHEMATIC_PLUGIN> m_spaceMouse;
311};
312
313#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:285
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:84
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.
APP_SETTINGS_BASE * GetViewerSettingsBase() const
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:51
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.
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 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()
Needs to be in the cpp file to encode the sizeof() for std::unique_ptr.
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.
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:401
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