KiCad PCB EDA Suite
Loading...
Searching...
No Matches
class_draw_panel_gal.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) 2013-2018 CERN
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * @author Tomasz Wlostowski <[email protected]>
8 * @author Maciej Suminski <[email protected]>
9 *
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License
12 * as published by the Free Software Foundation; either version 2
13 * of the License, or (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, you may find one here:
22 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
23 * or you may search the http://www.gnu.org website for the version 2 license,
24 * or you may write to the Free Software Foundation, Inc.,
25 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
26 */
27
28#ifndef PANELGAL_WXSTRUCT_H
29#define PANELGAL_WXSTRUCT_H
30
31#include <wx/window.h>
32#include <wx/timer.h>
33#include <wx/grid.h> // needed for MSVC to see wxScrolledCanvas indirectly exported
34#include <math/box2.h>
35#include <math/vector2d.h>
36#include <widgets/msgpanel.h>
37#include <memory>
38#include <mutex>
39
40#include <gal/cursors.h>
41
42class BOARD;
43class EDA_DRAW_FRAME;
44class TOOL_DISPATCHER;
45class PROF_COUNTER;
46
47namespace KIGFX
48{
49class GAL;
50class VIEW;
52class VIEW_CONTROLS;
53class PAINTER;
55class VIEW_OVERLAY;
56struct VC_SETTINGS;
57}
58
59
60class EDA_DRAW_PANEL_GAL : public wxScrolledCanvas
61{
62public:
70
71#ifdef __WXMAC__
72 // Cairo doesn't work on OSX so we really have no fallback available.
73 static constexpr GAL_TYPE GAL_FALLBACK = GAL_TYPE_OPENGL;
74#else
76#endif
78
87 EDA_DRAW_PANEL_GAL( wxWindow* aParentWindow, wxWindowID aWindowId,
88 const wxPoint& aPosition, const wxSize& aSize,
90 GAL_TYPE aGalType = GAL_TYPE_OPENGL );
92
93 void SetFocus() override;
94
96 {
97 return m_statusPopup && m_statusPopup->HasFocus();
98 }
99
100 void SetStatusPopup( wxWindow* aPopup )
101 {
102 m_statusPopup = aPopup;
103 }
104
110 virtual bool SwitchBackend( GAL_TYPE aGalType );
111
115 inline GAL_TYPE GetBackend() const { return m_backend; }
116
122 KIGFX::GAL* GetGAL() const { return m_gal; }
123
129 virtual KIGFX::VIEW* GetView() const { return m_view; }
130
140
142 virtual void Refresh( bool aEraseBackground = true, const wxRect* aRect = nullptr ) override;
143
147 void ForceRefresh();
148
152 void RequestRefresh();
153
162 void SetEventDispatcher( TOOL_DISPATCHER* aEventDispatcher );
163
167 void StartDrawing();
168
173 void StopDrawing();
174
178 virtual void SetHighContrastLayer( int aLayer );
179
183 virtual void SetTopLayer( int aLayer );
184
185 virtual void GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector<MSG_PANEL_ITEM>& aList )
186 {
187 wxASSERT( false );
188 }
189
194
195 bool IsDialogPreview() const { return m_parent != (wxWindow*) m_edaFrame; }
196
200 virtual void OnShow() {}
201
208 void SetStealsFocus( bool aStealsFocus ) { m_stealsFocus = aStealsFocus; }
209
213 void SetCurrentCursor( KICURSOR aCursor );
214
221 virtual BOX2I GetDefaultViewBBox() const { return BOX2I(); }
222
226 void OnEvent( wxEvent& aEvent );
227
237 bool DoRePaint( bool aAllowSkip = true );
238
242 std::shared_ptr<KIGFX::VIEW_OVERLAY> DebugOverlay();
243
244
248 void ClearDebugOverlay();
249
250
255
262
263 std::unique_ptr<PROF_COUNTER> m_PaintEventCounter;
264
265protected:
266 virtual void onPaint( wxPaintEvent& WXUNUSED( aEvent ) );
267 void onSize( wxSizeEvent& aEvent );
268 void onEnter( wxMouseEvent& aEvent );
269 void onLostFocus( wxFocusEvent& aEvent );
270 void onIdle( wxIdleEvent& aEvent );
271 void onRefreshTimer( wxTimerEvent& aEvent );
272 void onShowEvent( wxShowEvent& aEvent );
273
274 bool recoverFromGalError( const std::exception& aErr );
275
276 wxWindow* m_parent;
278
280 wxLongLong m_lastRepaintEnd;
282
283 std::mutex m_refreshMutex;
284
287
290
293
296
299
302
304 std::unique_ptr<KIGFX::PAINTER> m_painter;
305
308
312
315
319
322
326
327 wxWindow* m_statusPopup;
328
330 std::shared_ptr<KIGFX::VIEW_OVERLAY> m_debugOverlay;
331};
332
333#endif
BOX2< VECTOR2I > BOX2I
Definition box2.h:922
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
The base class for create windows for drawing purpose.
std::unique_ptr< PROF_COUNTER > m_PaintEventCounter
bool m_glRecoveryAttempted
Set after an OpenGL recovery attempt to prevent infinite retry loops.
EDA_DRAW_FRAME * m_edaFrame
Parent EDA_DRAW_FRAME (if available)
virtual void GetMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList)
void onLostFocus(wxFocusEvent &aEvent)
static constexpr GAL_TYPE GAL_FALLBACK
std::unique_ptr< KIGFX::PAINTER > m_painter
Contains information about how to draw items using GAL.
void onSize(wxSizeEvent &aEvent)
bool m_needIdleRefresh
True when canvas needs to be refreshed from idle handler.
GAL_TYPE GetBackend() const
Return the type of backend currently used by GAL canvas.
virtual void SetHighContrastLayer(int aLayer)
Take care of display settings for the given layer to be displayed in high contrast mode.
bool m_stealsFocus
Flag to indicate whether the panel should take focus at certain times (when moused over,...
virtual BOX2I GetDefaultViewBBox() const
Return the bounding box of the view that should be used if model is not valid.
KIGFX::GAL_DISPLAY_OPTIONS & m_options
void StopDrawing()
Prevent the GAL canvas from further drawing until it is recreated or StartDrawing() is called.
static KIGFX::VC_SETTINGS GetVcSettings()
Gets a populated View Controls settings object dervived from our program settings.
KIGFX::VIEW_CONTROLS * GetViewControls() const
Return a pointer to the #VIEW_CONTROLS instance used in the panel.
virtual void SetTopLayer(int aLayer)
Move the selected layer to the top, so it is displayed above all others.
void ClearDebugOverlay()
Clear the contents of the debug overlay and removes it from the VIEW.
virtual KIGFX::VIEW * GetView() const
Return a pointer to the #VIEW instance used in the panel.
void ForceRefresh()
Force a redraw.
bool recoverFromGalError(const std::exception &aErr)
bool m_drawing
True if GAL is currently redrawing the view.
KIGFX::GAL * m_gal
Interface for drawing objects on a 2D-surface.
EDA_DRAW_PANEL_GAL(wxWindow *aParentWindow, wxWindowID aWindowId, const wxPoint &aPosition, const wxSize &aSize, KIGFX::GAL_DISPLAY_OPTIONS &aOptions, GAL_TYPE aGalType=GAL_TYPE_OPENGL)
Create a drawing panel that is contained inside aParentWindow.
void onRefreshTimer(wxTimerEvent &aEvent)
void SetCurrentCursor(KICURSOR aCursor)
Set the current cursor shape for this panel.
virtual void onPaint(wxPaintEvent &WXUNUSED(aEvent))
bool m_lostFocus
Flag to indicate that focus should be regained on the next mouse event.
virtual void OnShow()
Called when the window is shown for the first time.
std::shared_ptr< KIGFX::VIEW_OVERLAY > m_debugOverlay
Optional overlay for drawing transient debug objects.
virtual void Refresh(bool aEraseBackground=true, const wxRect *aRect=nullptr) override
wxTimer m_refreshTimer
Timer to prevent too-frequent refreshing.
TOOL_DISPATCHER * m_eventDispatcher
Processes and forwards events to tools.
wxWindow * m_parent
Pointer to the parent window.
wxLongLong m_lastRepaintStart
Timestamp of the last repaint start.
@ GAL_TYPE_LAST
Sentinel, do not use as a parameter.
@ GAL_TYPE_UNKNOWN
not specified: a GAL engine must be set by the client
@ GAL_TYPE_OPENGL
OpenGL implementation.
@ GAL_TYPE_CAIRO
Cairo implementation.
@ GAL_TYPE_NONE
GAL not used (the legacy wxDC engine is used)
KIGFX::VIEW * m_view
Stores view settings (scale, center, etc.) and items to be drawn.
bool m_MouseCapturedLost
used on wxMSW: true after a wxEVT_MOUSE_CAPTURE_LOST was received false after the mouse is recaptured...
KIGFX::WX_VIEW_CONTROLS * m_viewControls
Control for VIEW (moving, zooming, etc.)
KIGFX::GAL * GetGAL() const
Return a pointer to the GAL instance used in the panel.
void SetFocus() override
void onIdle(wxIdleEvent &aEvent)
void SetEventDispatcher(TOOL_DISPATCHER *aEventDispatcher)
Set a dispatcher that processes events and forwards them to tools.
void onEnter(wxMouseEvent &aEvent)
void SetStatusPopup(wxWindow *aPopup)
void RequestRefresh()
Make sure a refresh gets done on the next idle event if it hasn't already.
std::mutex m_refreshMutex
Blocks multiple calls to the draw.
virtual bool SwitchBackend(GAL_TYPE aGalType)
Switch method of rendering graphics.
void StartDrawing()
Begin drawing if it was stopped previously.
wxLongLong m_lastRepaintEnd
Timestamp of the last repaint end.
bool DoRePaint(bool aAllowSkip=true)
Repaint the canvas, and fix scrollbar cursors.
void OnEvent(wxEvent &aEvent)
Used to forward events to the canvas from popups, etc.
void SetStealsFocus(bool aStealsFocus)
Set whether focus is taken on certain events (mouseover, keys, etc).
bool m_drawingEnabled
Flag that determines if VIEW may use GAL for redrawing the screen.
std::shared_ptr< KIGFX::VIEW_OVERLAY > DebugOverlay()
Create an overlay for rendering debug graphics.
void onShowEvent(wxShowEvent &aEvent)
static constexpr bool GAL_FALLBACK_AVAILABLE
GAL_TYPE m_backend
Currently used GAL.
VECTOR2D m_lastCursorPosition
Last cursor position sent to GAL for drawing.
EDA_DRAW_FRAME * GetParentEDAFrame() const
Returns parent EDA_DRAW_FRAME, if available or NULL otherwise.
Abstract interface for drawing on a 2D-surface.
Contains all the knowledge about how to draw graphical object onto any particular output device.
Definition painter.h:59
An interface for classes handling user events controlling the view behavior such as zooming,...
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
Definition view.h:67
An implementation of class VIEW_CONTROLS for wxWidgets library.
A thread-safe event counter.
Definition profile.h:248
KICURSOR
Definition cursors.h:44
Message panel definition file.
The Cairo implementation of the graphics abstraction layer.
Definition eda_group.h:33
Structure to keep VIEW_CONTROLS settings for easy store/restore operations.
VECTOR2< double > VECTOR2D
Definition vector2d.h:686