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>
31#include <sch_draw_panel.h>
32#include <sch_screen.h>
33#include <schematic_settings.h>
34
35#include <stddef.h>
36#include <utility>
37#include <future>
38#include <vector>
39#include <wx/event.h>
40#include <wx/datetime.h>
41#include <wx/gdicmn.h>
42#include <wx/string.h>
43#include <wx/timer.h>
44
45#include <template_fieldnames.h>
46
47
49class PAGE_INFO;
50class TITLE_BLOCK;
53class LIB_SYMBOL;
56class LIB_ID;
61
62#ifndef __linux__
64#else
65class SPNAV_2D_PLUGIN;
66#endif
67
69class DIALOG_SCH_FIND;
70struct BACKGROUND_JOB;
71
72#ifdef wxHAS_INOTIFY
73#define wxFileSystemWatcher wxInotifyFileSystemWatcher
74#elif defined( wxHAS_KQUEUE ) && defined( wxHAVE_FSEVENTS_FILE_NOTIFICATIONS )
75#define wxFileSystemWatcher wxFsEventsFileSystemWatcher
76#elif defined( wxHAS_KQUEUE )
77#define wxFileSystemWatcher wxKqueueFileSystemWatcher
78#elif defined( __WINDOWS__ )
79#define wxFileSystemWatcher wxMSWFileSystemWatcher
80#else
81#define wxFileSystemWatcher wxPollingFileSystemWatcher
82#endif
83
85class wxFileSystemWatcherEvent;
86
102 LEGACY_SYMBOL_LIB* aCacheLib = nullptr, wxWindow* aParent = nullptr,
103 bool aShowErrorMsg = false );
104
115{
116public:
117 SCH_BASE_FRAME( KIWAY* aKiway, wxWindow* aParent, FRAME_T aWindowType, const wxString& aTitle,
118 const wxPoint& aPosition, const wxSize& aSize, long aStyle,
119 const wxString & aFrameName );
120
121 virtual ~SCH_BASE_FRAME();
122
123 void createCanvas();
124
125 SCH_DRAW_PANEL* GetCanvas() const override;
126 SCH_SCREEN* GetScreen() const override;
127
129
131
133
134 void LoadSettings( APP_SETTINGS_BASE* aCfg ) override;
135 void SaveSettings( APP_SETTINGS_BASE* aCfg ) override;
136
138
139 COLOR4D GetDrawBgColor() const override;
140
144 virtual bool GetShowAllPins() const { return true; }
145
146 void SetPageSettings( const PAGE_INFO& aPageSettings ) override;
147 const PAGE_INFO& GetPageSettings () const override;
148 const VECTOR2I GetPageSizeIU() const override;
149
150 const VECTOR2I& GetGridOrigin() const override
151 {
152 static VECTOR2I zero;
153 return zero;
154 }
155 void SetGridOrigin( const VECTOR2I& aPoint ) override {}
156
157 const TITLE_BLOCK& GetTitleBlock() const override;
158 void SetTitleBlock( const TITLE_BLOCK& aTitleBlock ) override;
159
160 void UpdateStatusBar() override;
161
181 std::vector<PICKED_SYMBOL>& aHistoryList,
182 std::vector<PICKED_SYMBOL>& aAlreadyPlaced,
183 bool aShowFootprints, const LIB_ID* aHighlight = nullptr,
184 bool aAllowFields = true );
185
195 LIB_SYMBOL* GetLibSymbol( const LIB_ID& aLibId, bool aUseCacheLib = false,
196 bool aShowErrorMsg = false );
197
208 wxString SelectLibrary( const wxString& aDialogTitle, const wxString& aListLabel,
209 const std::vector<std::pair<wxString, bool*>>& aExtraCheckboxes = {} );
210
211 virtual void RedrawScreen( const VECTOR2I& aCenterPoint, bool aWarpPointer );
212
213 void HardRedraw() override;
214
219 void AddToScreen( EDA_ITEM* aItem, SCH_SCREEN* aScreen = nullptr ) override;
220
225 void RemoveFromScreen( EDA_ITEM* aItem, SCH_SCREEN* aScreen ) override;
226
230 virtual void UpdateItem( EDA_ITEM* aItem, bool isAddOrDelete = false,
231 bool aUpdateRtree = false );
232
237
241 void SyncView();
242
246 void ShowFindReplaceDialog( bool aReplace );
247
249
250 void ShowFindReplaceStatus( const wxString& aMsg, int aStatusTime );
252
256 void OnFindDialogClose();
257
258 void CommonSettingsChanged( int aFlags ) override;
259
264
265 COLOR_SETTINGS* GetColorSettings( bool aForceRefresh = false ) const override;
266
267 void ActivateGalCanvas() override;
268
272 void OnSymChange( wxFileSystemWatcherEvent& aEvent );
273
277 void OnSymChangeDebounceTimer( wxTimerEvent& aEvent );
278
286 void SetSymModificationTime( const wxDateTime& aTime )
287 {
288 m_watcherLastModified = aTime;
289 }
290
292
293 void GetLibraryItemsForListDialog( wxArrayString& aHeaders, std::vector<wxArrayString>& aItemsToDisplay );
294
296
297protected:
298 void handleActivateEvent( wxActivateEvent& aEvent ) override;
299
300 void handleIconizeEvent( wxIconizeEvent& aEvent ) override;
301
302 void doCloseWindow() override;
303
308 void setSymWatcher( const LIB_ID* aSymbol );
309
315
316protected:
319
322
323private:
324
326 std::unique_ptr<wxFileSystemWatcher> m_watcher;
331
332#ifndef __linux__
333 std::unique_ptr<NL_SCHEMATIC_PLUGIN> m_spaceMouse;
334#else
335 std::unique_ptr<SPNAV_2D_PLUGIN> m_spaceMouse;
336#endif
337};
338
339#endif // SCH_BASE_FRAME_H_
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
Color settings are a bit different than most of the settings objects in that there can be more than o...
EDA_DRAW_FRAME(KIWAY *aKiway, wxWindow *aParent, FRAME_T aFrameType, const wxString &aTitle, const wxPoint &aPos, const wxSize &aSize, long aStyle, const wxString &aFrameName, const EDA_IU_SCALE &aIuScale)
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:292
Object used to load, save, search, and otherwise manipulate symbol library files.
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:85
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:79
This is a bridge class to help the schematic be able to affect SCH_EDIT_FRAME without doing anything ...
These are loaded from Eeschema settings but then overwritten by the project settings.
void SetGridOrigin(const VECTOR2I &aPoint) override
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.
void RemoveFromScreen(EDA_ITEM *aItem, SCH_SCREEN *aScreen) override
Remove an item from the screen (and view) aScreen is the screen the item is located on,...
SCH_RENDER_SETTINGS * GetRenderSettings()
void doCloseWindow() override
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 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 HighlightSelectionFilter(const SCH_SELECTION_FILTER_OPTIONS &aOptions)
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.
DIALOG_SCH_FIND * m_findReplaceDialog
SCHEMATIC_SETTINGS m_base_frame_defaults
Only used by symbol_editor. Eeschema should be using the one inside the SCHEMATIC.
wxTimer m_watcherDebounceTimer
DIALOG_SCH_FIND * GetFindReplaceDialog() const
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
void ShowFindReplaceDialog(bool aReplace)
Run the Find or Find & Replace dialog.
SCH_SELECTION_TOOL * GetSelectionTool() override
void SyncView()
Mark all items for refresh.
std::unique_ptr< NL_SCHEMATIC_PLUGIN > m_spaceMouse
void GetLibraryItemsForListDialog(wxArrayString &aHeaders, std::vector< wxArrayString > &aItemsToDisplay)
wxDateTime m_watcherLastModified
std::unique_ptr< wxFileSystemWatcher > m_watcher
These are file watchers for the symbol library tables.
wxString SelectLibrary(const wxString &aDialogTitle, const wxString &aListLabel, const std::vector< std::pair< wxString, bool * > > &aExtraCheckboxes={})
Display a list of loaded libraries and allows the user to select a library.
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
const VECTOR2I & GetGridOrigin() const override
Return the absolute coordinates of the origin of the snap grid.
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.
void OnFindDialogClose()
Notification that the Find dialog has closed.
wxFileName m_watcherFileName
void setSymWatcher(const LIB_ID *aSymbol)
Creates (or removes) a watcher on the specified symbol library.
void AddToScreen(EDA_ITEM *aItem, SCH_SCREEN *aScreen=nullptr) override
Add an item to the screen (and view) aScreen is the screen the item is located on,...
const PAGE_INFO & GetPageSettings() const override
void ShowFindReplaceStatus(const wxString &aMsg, int aStatusTime)
COLOR4D GetDrawBgColor() const override
void OnSymChangeDebounceTimer(wxTimerEvent &aEvent)
Handler for the filesystem watcher debounce timer.
void ClearFindReplaceStatus()
COLOR4D GetLayerColor(SCH_LAYER_ID aLayer)
Helper to retrieve a layer color from the global color settings.
The symbol library editor main window.
An interface to the global shared library manager that is schematic-specific and linked to one projec...
Helper object to filter a list of libraries.
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:449
LIB_SYMBOL * SchGetLibSymbol(const LIB_ID &aLibId, SYMBOL_LIBRARY_ADAPTER *aLibMgr, LEGACY_SYMBOL_LIB *aCacheLib=nullptr, wxWindow *aParent=nullptr, bool aShowErrorMsg=false)
Load symbol from symbol library table.
#define wxFileSystemWatcher
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:695