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, see <https://www.gnu.org/licenses/>.
22 */
23
24#ifndef PANELGAL_WXSTRUCT_H
25#define PANELGAL_WXSTRUCT_H
26
27#include <wx/window.h>
28#include <wx/timer.h>
29#include <wx/grid.h> // needed for MSVC to see wxScrolledCanvas indirectly exported
30#include <math/box2.h>
31#include <math/vector2d.h>
32#include <widgets/msgpanel.h>
33#include <memory>
34#include <mutex>
35
36#include <gal/cursors.h>
37
38class BOARD;
39class EDA_DRAW_FRAME;
40class TOOL_DISPATCHER;
41class PROF_COUNTER;
42class wxImage;
43
44namespace KIGFX
45{
46class GAL;
47class VIEW;
49class VIEW_CONTROLS;
50class PAINTER;
52class VIEW_OVERLAY;
53struct VC_SETTINGS;
54}
55
56
57class EDA_DRAW_PANEL_GAL : public wxScrolledCanvas
58{
59public:
67
68#ifdef __WXMAC__
69 // Cairo doesn't work on OSX so we really have no fallback available.
70 static constexpr GAL_TYPE GAL_FALLBACK = GAL_TYPE_OPENGL;
71#else
73#endif
75
84 EDA_DRAW_PANEL_GAL( wxWindow* aParentWindow, wxWindowID aWindowId,
85 const wxPoint& aPosition, const wxSize& aSize,
87 GAL_TYPE aGalType = GAL_TYPE_OPENGL );
89
90 void SetFocus() override;
91
93 {
94 return m_statusPopup && m_statusPopup->HasFocus();
95 }
96
97 void SetStatusPopup( wxWindow* aPopup )
98 {
99 m_statusPopup = aPopup;
100 }
101
107 virtual bool SwitchBackend( GAL_TYPE aGalType );
108
112 inline GAL_TYPE GetBackend() const { return m_backend; }
113
119 KIGFX::GAL* GetGAL() const { return m_gal; }
120
126 virtual KIGFX::VIEW* GetView() const { return m_view; }
127
137
144 bool GetScreenshot( wxImage& aDstImage );
145
147 virtual void Refresh( bool aEraseBackground = true, const wxRect* aRect = nullptr ) override;
148
152 void ForceRefresh();
153
157 void RequestRefresh();
158
167 void SetEventDispatcher( TOOL_DISPATCHER* aEventDispatcher );
168
172 void StartDrawing();
173
178 void StopDrawing();
179
183 virtual void SetHighContrastLayer( int aLayer );
184
188 virtual void SetTopLayer( int aLayer );
189
190 virtual void GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector<MSG_PANEL_ITEM>& aList )
191 {
192 wxASSERT( false );
193 }
194
199
200 bool IsDialogPreview() const { return m_parent != (wxWindow*) m_edaFrame; }
201
205 virtual void OnShow() {}
206
213 void SetStealsFocus( bool aStealsFocus ) { m_stealsFocus = aStealsFocus; }
214
218 void SetCurrentCursor( KICURSOR aCursor );
219
226 virtual BOX2I GetDefaultViewBBox() const { return BOX2I(); }
227
231 void OnEvent( wxEvent& aEvent );
232
242 bool DoRePaint( bool aAllowSkip = true );
243
247 std::shared_ptr<KIGFX::VIEW_OVERLAY> DebugOverlay();
248
249
253 void ClearDebugOverlay();
254
255
260
267
268 std::unique_ptr<PROF_COUNTER> m_PaintEventCounter;
269
270protected:
271 virtual void onPaint( wxPaintEvent& WXUNUSED( aEvent ) );
272 void onSize( wxSizeEvent& aEvent );
273 void onEnter( wxMouseEvent& aEvent );
274 void onLostFocus( wxFocusEvent& aEvent );
275 void onIdle( wxIdleEvent& aEvent );
276 void onRefreshTimer( wxTimerEvent& aEvent );
277 void onShowEvent( wxShowEvent& aEvent );
278
279 bool recoverFromGalError( const std::exception& aErr );
280
281 wxWindow* m_parent;
283
285 wxLongLong m_lastRepaintEnd;
287
288 std::mutex m_refreshMutex;
289
292
295
298
301
304
307
309 std::unique_ptr<KIGFX::PAINTER> m_painter;
310
313
317
320
324
327
331
332 wxWindow* m_statusPopup;
333
335 std::shared_ptr<KIGFX::VIEW_OVERLAY> m_debugOverlay;
336};
337
338#endif
BOX2< VECTOR2I > BOX2I
Definition box2.h:918
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:372
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.
bool GetScreenshot(wxImage &aDstImage)
Capture the current canvas contents into aDstImage.
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:55
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:63
An implementation of class VIEW_CONTROLS for wxWidgets library.
A thread-safe event counter.
Definition profile.h:255
KICURSOR
Definition cursors.h:40
Message panel definition file.
The Cairo implementation of the graphics abstraction layer.
Definition eda_group.h:29
Structure to keep VIEW_CONTROLS settings for easy store/restore operations.
VECTOR2< double > VECTOR2D
Definition vector2d.h:682