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;
46class wxImage;
47
48namespace KIGFX
49{
50class GAL;
51class VIEW;
53class VIEW_CONTROLS;
54class PAINTER;
56class VIEW_OVERLAY;
57struct VC_SETTINGS;
58}
59
60
61class EDA_DRAW_PANEL_GAL : public wxScrolledCanvas
62{
63public:
71
72#ifdef __WXMAC__
73 // Cairo doesn't work on OSX so we really have no fallback available.
74 static constexpr GAL_TYPE GAL_FALLBACK = GAL_TYPE_OPENGL;
75#else
77#endif
79
88 EDA_DRAW_PANEL_GAL( wxWindow* aParentWindow, wxWindowID aWindowId,
89 const wxPoint& aPosition, const wxSize& aSize,
91 GAL_TYPE aGalType = GAL_TYPE_OPENGL );
93
94 void SetFocus() override;
95
97 {
98 return m_statusPopup && m_statusPopup->HasFocus();
99 }
100
101 void SetStatusPopup( wxWindow* aPopup )
102 {
103 m_statusPopup = aPopup;
104 }
105
111 virtual bool SwitchBackend( GAL_TYPE aGalType );
112
116 inline GAL_TYPE GetBackend() const { return m_backend; }
117
123 KIGFX::GAL* GetGAL() const { return m_gal; }
124
130 virtual KIGFX::VIEW* GetView() const { return m_view; }
131
141
148 bool GetScreenshot( wxImage& aDstImage );
149
151 virtual void Refresh( bool aEraseBackground = true, const wxRect* aRect = nullptr ) override;
152
156 void ForceRefresh();
157
161 void RequestRefresh();
162
171 void SetEventDispatcher( TOOL_DISPATCHER* aEventDispatcher );
172
176 void StartDrawing();
177
182 void StopDrawing();
183
187 virtual void SetHighContrastLayer( int aLayer );
188
192 virtual void SetTopLayer( int aLayer );
193
194 virtual void GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector<MSG_PANEL_ITEM>& aList )
195 {
196 wxASSERT( false );
197 }
198
203
204 bool IsDialogPreview() const { return m_parent != (wxWindow*) m_edaFrame; }
205
209 virtual void OnShow() {}
210
217 void SetStealsFocus( bool aStealsFocus ) { m_stealsFocus = aStealsFocus; }
218
222 void SetCurrentCursor( KICURSOR aCursor );
223
230 virtual BOX2I GetDefaultViewBBox() const { return BOX2I(); }
231
235 void OnEvent( wxEvent& aEvent );
236
246 bool DoRePaint( bool aAllowSkip = true );
247
251 std::shared_ptr<KIGFX::VIEW_OVERLAY> DebugOverlay();
252
253
257 void ClearDebugOverlay();
258
259
264
271
272 std::unique_ptr<PROF_COUNTER> m_PaintEventCounter;
273
274protected:
275 virtual void onPaint( wxPaintEvent& WXUNUSED( aEvent ) );
276 void onSize( wxSizeEvent& aEvent );
277 void onEnter( wxMouseEvent& aEvent );
278 void onLostFocus( wxFocusEvent& aEvent );
279 void onIdle( wxIdleEvent& aEvent );
280 void onRefreshTimer( wxTimerEvent& aEvent );
281 void onShowEvent( wxShowEvent& aEvent );
282
283 bool recoverFromGalError( const std::exception& aErr );
284
285 wxWindow* m_parent;
287
289 wxLongLong m_lastRepaintEnd;
291
292 std::mutex m_refreshMutex;
293
296
299
302
305
308
311
313 std::unique_ptr<KIGFX::PAINTER> m_painter;
314
317
321
324
328
331
335
336 wxWindow* m_statusPopup;
337
339 std::shared_ptr<KIGFX::VIEW_OVERLAY> m_debugOverlay;
340};
341
342#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.
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: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:259
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