KiCad PCB EDA Suite
Loading...
Searching...
No Matches
graphics_abstraction_layer.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) 2012 Torsten Hueter, torstenhtr <at> gmx.de
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * Graphics Abstraction Layer (GAL) - base class
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, you may find one here:
21 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
22 * or you may search the http://www.gnu.org website for the version 2 license,
23 * or you may write to the Free Software Foundation, Inc.,
24 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
25 */
26
27#ifndef GRAPHICSABSTRACTIONLAYER_H_
28#define GRAPHICSABSTRACTIONLAYER_H_
29
30#include <deque>
31#include <stack>
32#include <limits>
33
34#include <math/matrix3x3.h>
35
36#include <gal/gal.h>
37#include <gal/color4d.h>
38#include <gal/cursors.h>
39#include <gal/definitions.h>
41#include <font/stroke_font.h>
42#include <geometry/eda_angle.h>
43
45class SHAPE_POLY_SET;
46class BITMAP_BASE;
47
48namespace KIGFX
49{
61{
62 // These friend declarations allow us to hide routines that should not be called. The
63 // corresponding RAII objects must be used instead.
64 friend class GAL_CONTEXT_LOCKER;
65 friend class GAL_UPDATE_CONTEXT;
66 friend class GAL_DRAWING_CONTEXT;
67
68public:
69 // Constructor / Destructor
70 GAL( GAL_DISPLAY_OPTIONS& aOptions );
71 virtual ~GAL();
72
74 virtual bool IsInitialized() const { return true; }
75
77 virtual bool IsVisible() const { return true; }
78
80 virtual bool IsCairoEngine() { return false; }
81
83 virtual bool IsOpenGlEngine() { return false; }
84
85 // ---------------
86 // Drawing methods
87 // ---------------
88
97 virtual void DrawLine( const VECTOR2D& aStartPoint, const VECTOR2D& aEndPoint ) {};
98
108 virtual void DrawSegment( const VECTOR2D& aStartPoint, const VECTOR2D& aEndPoint,
109 double aWidth ){};
110
117 virtual void DrawSegmentChain( const std::vector<VECTOR2D>& aPointList, double aWidth ){};
118 virtual void DrawSegmentChain( const SHAPE_LINE_CHAIN& aLineChain, double aWidth ){};
119
125 virtual void DrawPolyline( const std::deque<VECTOR2D>& aPointList ) {};
126 virtual void DrawPolyline( const std::vector<VECTOR2D>& aPointList ) {};
127 virtual void DrawPolyline( const VECTOR2D aPointList[], int aListSize ) {};
128 virtual void DrawPolyline( const SHAPE_LINE_CHAIN& aLineChain ) {};
129
135 virtual void DrawPolylines( const std::vector<std::vector<VECTOR2D>>& aPointLists ){};
136
143 virtual void DrawCircle( const VECTOR2D& aCenterPoint, double aRadius ) {};
144
153 virtual void DrawArc( const VECTOR2D& aCenterPoint, double aRadius,
154 const EDA_ANGLE& aStartAngle, const EDA_ANGLE& aAngle ){};
155
176 virtual void DrawArcSegment( const VECTOR2D& aCenterPoint, double aRadius,
177 const EDA_ANGLE& aStartAngle, const EDA_ANGLE& aAngle,
178 double aWidth, double aMaxError ){};
179
186 virtual void DrawRectangle( const VECTOR2D& aStartPoint, const VECTOR2D& aEndPoint ) {};
187
188 void DrawRectangle( const BOX2I& aRect )
189 {
190 DrawRectangle( aRect.GetOrigin(), aRect.GetEnd() );
191 }
192
196 virtual void DrawGlyph( const KIFONT::GLYPH& aGlyph, int aNth = 0, int aTotal = 1 ) {};
197
201 virtual void DrawGlyphs( const std::vector<std::unique_ptr<KIFONT::GLYPH>>& aGlyphs )
202 {
203 for( size_t i = 0; i < aGlyphs.size(); i++ )
204 DrawGlyph( *aGlyphs[i], i, aGlyphs.size() );
205 }
206
207
213 virtual void DrawPolygon( const std::deque<VECTOR2D>& aPointList ) {};
214 virtual void DrawPolygon( const VECTOR2D aPointList[], int aListSize ) {};
215 virtual void DrawPolygon( const SHAPE_POLY_SET& aPolySet,
216 bool aStrokeTriangulation = false ) {};
217 virtual void DrawPolygon( const SHAPE_LINE_CHAIN& aPolySet ) {};
218
230 virtual void DrawCurve( const VECTOR2D& startPoint, const VECTOR2D& controlPointA,
231 const VECTOR2D& controlPointB, const VECTOR2D& endPoint,
232 double aFilterValue = 0.0 ) {};
233
237 virtual void DrawBitmap( const BITMAP_BASE& aBitmap, double alphaBlend = 1.0 ) {};
238
239 // --------------
240 // Screen methods
241 // --------------
242
244 virtual void ResizeScreen( int aWidth, int aHeight ) {};
245
247 virtual bool Show( bool aShow ) { return true; };
248
251 {
252 return m_screenSize;
253 }
254
256 virtual int GetSwapInterval() const { return 0; };
257
259 virtual void Flush() {};
260
261 void SetClearColor( const COLOR4D& aColor )
262 {
263 m_clearColor = aColor;
264 }
265
266 const COLOR4D& GetClearColor( ) const
267 {
268 return m_clearColor;
269 }
270
276 virtual void ClearScreen() {};
277
278 // -----------------
279 // Attribute setting
280 // -----------------
281
287 virtual void SetIsFill( bool aIsFillEnabled )
288 {
289 m_isFillEnabled = aIsFillEnabled;
290 }
291
297 inline bool GetIsFill() const
298 {
299 return m_isFillEnabled;
300 }
301
307 virtual void SetIsStroke( bool aIsStrokeEnabled )
308 {
309 m_isStrokeEnabled = aIsStrokeEnabled;
310 }
311
317 inline bool GetIsStroke() const
318 {
319 return m_isStrokeEnabled;
320 }
321
327 virtual void SetFillColor( const COLOR4D& aColor )
328 {
329 m_fillColor = aColor;
330 }
331
337 inline const COLOR4D& GetFillColor() const
338 {
339 return m_fillColor;
340 }
341
347 virtual void SetStrokeColor( const COLOR4D& aColor )
348 {
349 m_strokeColor = aColor;
350 }
351
357 inline const COLOR4D& GetStrokeColor() const
358 {
359 return m_strokeColor;
360 }
361
367 virtual void SetLineWidth( float aLineWidth )
368 {
369 m_lineWidth = aLineWidth;
370 }
371
377 inline float GetLineWidth() const
378 {
379 return m_lineWidth;
380 }
381
390 virtual void SetLayerDepth( double aLayerDepth )
391 {
392 wxCHECK_MSG( aLayerDepth <= m_depthRange.y, /*void*/,
393 wxT( "SetLayerDepth: below minimum" ) );
394 wxCHECK_MSG( aLayerDepth >= m_depthRange.x, /*void*/,
395 wxT( "SetLayerDepth: above maximum" ) );
396
397 m_layerDepth = aLayerDepth;
398 }
399
407 inline void AdvanceDepth()
408 {
409 SetLayerDepth( m_layerDepth - 0.1 );
410 }
411
412 // ----
413 // Text
414 // ----
415
424 virtual void BitmapText( const wxString& aText, const VECTOR2I& aPosition,
425 const EDA_ANGLE& aAngle );
426
433 void ResetTextAttributes();
434
435 void SetGlyphSize( const VECTOR2I aSize ) { m_attributes.m_Size = aSize; }
436 const VECTOR2I& GetGlyphSize() const { return m_attributes.m_Size; }
437
438 inline void SetFontBold( const bool aBold ) { m_attributes.m_Bold = aBold; }
439 inline bool IsFontBold() const { return m_attributes.m_Bold; }
440
441 inline void SetFontItalic( bool aItalic ) { m_attributes.m_Italic = aItalic; }
442 inline bool IsFontItalic() const { return m_attributes.m_Italic; }
443
444 inline void SetFontUnderlined( bool aUnderlined ) { m_attributes.m_Underlined = aUnderlined; }
445 inline bool IsFontUnderlined() const { return m_attributes.m_Underlined; }
446
447 void SetTextMirrored( const bool aMirrored ) { m_attributes.m_Mirrored = aMirrored; }
448 bool IsTextMirrored() const { return m_attributes.m_Mirrored; }
449
450 void SetHorizontalJustify( const GR_TEXT_H_ALIGN_T aHorizontalJustify )
451 {
452 m_attributes.m_Halign = aHorizontalJustify;
453 }
454
455 GR_TEXT_H_ALIGN_T GetHorizontalJustify() const { return m_attributes.m_Halign; }
456
457 void SetVerticalJustify( const GR_TEXT_V_ALIGN_T aVerticalJustify )
458 {
459 m_attributes.m_Valign = aVerticalJustify;
460 }
461
462 GR_TEXT_V_ALIGN_T GetVerticalJustify() const { return m_attributes.m_Valign; }
463
464
465 // --------------
466 // Transformation
467 // --------------
468
474 virtual void Transform( const MATRIX3x3D& aTransformation ) {};
475
481 virtual void Rotate( double aAngle ) {};
482
488 virtual void Translate( const VECTOR2D& aTranslation ) {};
489
495 virtual void Scale( const VECTOR2D& aScale ) {};
496
498 virtual void Save() {};
499
501 virtual void Restore() {};
502
503 // --------------------------------------------
504 // Group methods
505 // ---------------------------------------------
506
515 virtual int BeginGroup() { return 0; };
516
518 virtual void EndGroup() {};
519
525 virtual void DrawGroup( int aGroupNumber ) {};
526
533 virtual void ChangeGroupColor( int aGroupNumber, const COLOR4D& aNewColor ) {};
534
541 virtual void ChangeGroupDepth( int aGroupNumber, int aDepth ) {};
542
548 virtual void DeleteGroup( int aGroupNumber ) {};
549
553 virtual void ClearCache() {};
554
555 // --------------------------------------------------------
556 // Handling the world <-> screen transformation
557 // --------------------------------------------------------
558
560 virtual void ComputeWorldScreenMatrix();
561
568 {
569 return m_worldScreenMatrix;
570 }
571
578 {
579 return m_screenWorldMatrix;
580 }
581
587 inline void SetWorldScreenMatrix( const MATRIX3x3D& aMatrix )
588 {
589 m_worldScreenMatrix = aMatrix;
590 }
591
595 BOX2D GetVisibleWorldExtents() const;
596
604 void SetWorldUnitLength( double aWorldUnitLength ) { m_worldUnitLength = aWorldUnitLength; }
605
606 void SetScreenSize( const VECTOR2I& aSize ) { m_screenSize = aSize; }
607
614 void SetScreenDPI( double aScreenDPI ) { m_screenDPI = aScreenDPI; }
615
621 void SetLookAtPoint( const VECTOR2D& aPoint ) { m_lookAtPoint = aPoint; }
622 const VECTOR2D& GetLookAtPoint() const { return m_lookAtPoint; }
623
624 void SetZoomFactor( double aZoomFactor ) { m_zoomFactor = aZoomFactor; }
625 double GetZoomFactor() const { return m_zoomFactor; }
626
630 void SetRotation( double aRotation ) { m_rotation = aRotation; }
631 double GetRotation() const { return m_rotation; }
632
641 void SetDepthRange( const VECTOR2D& aDepthRange ) { m_depthRange = aDepthRange; }
642 double GetMinDepth() const { return m_depthRange.x; }
643 double GetMaxDepth() const { return m_depthRange.y; }
644
650 double GetWorldScale() const { return m_worldScale; }
651
658 inline void SetFlip( bool xAxis, bool yAxis )
659 {
660 m_globalFlipX = xAxis;
661 m_globalFlipY = yAxis;
662 }
663
664 bool IsFlippedX() const { return m_globalFlipX; }
665 bool IsFlippedY() const { return m_globalFlipY; }
666
667 // ---------------------------
668 // Buffer manipulation methods
669 // ---------------------------
670
676 virtual void SetTarget( RENDER_TARGET aTarget ) {};
677
683 virtual RENDER_TARGET GetTarget() const { return TARGET_CACHED; };
684
690 virtual void ClearTarget( RENDER_TARGET aTarget ) {};
691
697 virtual bool HasTarget( RENDER_TARGET aTarget )
698 {
699 return true;
700 };
701
713 virtual void SetNegativeDrawMode( bool aSetting ) {};
714
722 virtual void StartDiffLayer() {};
723
729 virtual void EndDiffLayer() {};
730
739 virtual void StartNegativesLayer(){};
740
745 virtual void EndNegativesLayer(){};
746
747 // -------------
748 // Grid methods
749 // -------------
750
756 void SetGridVisibility( bool aVisibility ) { m_gridVisibility = aVisibility; }
757
758 bool GetGridVisibility() const { return m_gridVisibility; }
759
760 bool GetGridSnapping() const
761 {
762 return m_options.m_gridSnapping == KIGFX::GRID_SNAPPING::ALWAYS ||
763 ( m_gridVisibility && m_options.m_gridSnapping == KIGFX::GRID_SNAPPING::WITH_GRID );
764 }
765
771 inline void SetGridOrigin( const VECTOR2D& aGridOrigin )
772 {
773 m_gridOrigin = aGridOrigin;
774
775 if( m_gridSize.x == 0.0 || m_gridSize.y == 0.0 )
776 {
777 m_gridOffset = VECTOR2D( 0.0, 0.0);
778 }
779 else
780 {
781 m_gridOffset = VECTOR2D( (long) m_gridOrigin.x % (long) m_gridSize.x,
782 (long) m_gridOrigin.y % (long) m_gridSize.y );
783 }
784 }
785
786 inline const VECTOR2D& GetGridOrigin() const
787 {
788 return m_gridOrigin;
789 }
790
796 inline void SetGridSize( const VECTOR2D& aGridSize )
797 {
798 m_gridSize = aGridSize;
799
800 // Avoid stupid grid size values: a grid size should be >= 1 in internal units
801 m_gridSize.x = std::max( 1.0, m_gridSize.x );
802 m_gridSize.y = std::max( 1.0, m_gridSize.y );
803
804 m_gridOffset = VECTOR2D( (long) m_gridOrigin.x % (long) m_gridSize.x,
805 (long) m_gridOrigin.y % (long) m_gridSize.y );
806 }
807
813 inline const VECTOR2D& GetGridSize() const
814 {
815 return m_gridSize;
816 }
817
824 {
825 VECTOR2D gridScreenSize( m_gridSize );
826
827 double gridThreshold = computeMinGridSpacing() / m_worldScale;
828
829 if( m_gridStyle == GRID_STYLE::SMALL_CROSS )
830 gridThreshold *= 2.0;
831
832 // If we cannot display the grid density, scale down by a tick size and
833 // try again. Eventually, we get some representation of the grid
834 while( std::min( gridScreenSize.x, gridScreenSize.y ) <= gridThreshold )
835 {
836 gridScreenSize = gridScreenSize * static_cast<double>( m_gridTick );
837 }
838
839 return gridScreenSize;
840 }
841
847 inline void SetGridColor( const COLOR4D& aGridColor )
848 {
849 m_gridColor = aGridColor;
850 }
851
857 inline void SetAxesColor( const COLOR4D& aAxesColor )
858 {
859 m_axesColor = aAxesColor;
860 }
861
865 inline void SetAxesEnabled( bool aAxesEnabled )
866 {
867 m_axesEnabled = aAxesEnabled;
868 }
869
875 inline void SetCoarseGrid( int aInterval )
876 {
877 m_gridTick = aInterval;
878 }
879
885 inline float GetGridLineWidth() const
886 {
887 return m_gridLineWidth;
888 }
889
891 virtual void DrawGrid() {};
892
899 VECTOR2D GetGridPoint( const VECTOR2D& aPoint ) const;
900
907 inline VECTOR2D ToWorld( const VECTOR2D& aPoint ) const
908 {
909 return VECTOR2D( m_screenWorldMatrix * aPoint );
910 }
911
918 inline VECTOR2D ToScreen( const VECTOR2D& aPoint ) const
919 {
920 return VECTOR2D( m_worldScreenMatrix * aPoint );
921 }
922
929 virtual bool SetNativeCursorStyle( KICURSOR aCursor, bool aHiDPI );
930
936 inline void SetCursorEnabled( bool aCursorEnabled )
937 {
938 m_isCursorEnabled = aCursorEnabled;
939 }
940
946 bool IsCursorEnabled() const
947 {
948 return m_isCursorEnabled || m_forceDisplayCursor;
949 }
950
956 inline void SetCursorColor( const COLOR4D& aCursorColor )
957 {
958 m_cursorColor = aCursorColor;
959 }
960
966 virtual void DrawCursor( const VECTOR2D& aCursorPosition ) {};
967
968 virtual void EnableDepthTest( bool aEnabled = false ) {};
969
974 virtual bool IsContextLocked()
975 {
976 return false;
977 }
978
979
981 virtual void LockContext( int aClientCookie ) {}
982
983 virtual void UnlockContext( int aClientCookie ) {}
984
989
992 virtual void BeginDrawing() {};
993
996 virtual void EndDrawing() {};
997protected:
998
1001 virtual void beginUpdate() {}
1002
1004 virtual void endUpdate() {}
1005
1006
1007
1009 inline void computeWorldScale()
1010 {
1011 m_worldScale = m_screenDPI * m_worldUnitLength * m_zoomFactor;
1012 }
1013
1019 double computeMinGridSpacing() const;
1020
1022 static const int MIN_DEPTH;
1023 static const int MAX_DEPTH;
1024
1026 static const int GRID_DEPTH;
1027
1031 COLOR4D getCursorColor() const;
1032
1033 // ---------------
1034 // Settings observer interface
1035 // ---------------
1039 void OnGalDisplayOptionsChanged( const GAL_DISPLAY_OPTIONS& aOptions ) override;
1040
1049 virtual bool updatedGalDisplayOptions( const GAL_DISPLAY_OPTIONS& aOptions );
1050
1054 template <typename T>
1055 void normalize( T &a, T &b )
1056 {
1057 if( a > b )
1058 {
1059 T tmp = a;
1060 a = b;
1061 b = tmp;
1062 }
1063 }
1064
1067
1068 std::stack<double> m_depthStack;
1070
1074
1076 double m_rotation;
1080
1083
1085
1088
1092
1095
1096 // Grid settings
1109
1110 // Cursor settings
1116
1118
1119private:
1120
1121 inline double getLayerDepth() const
1122 {
1123 return m_layerDepth;
1124 }
1125
1127
1128 friend class GAL_SCOPED_ATTRS;
1129};
1130
1131
1133{
1134public:
1136 m_gal( aGal )
1137 {
1138 m_cookie = rand();
1140 }
1141
1143 {
1145 }
1146
1147protected:
1150};
1151
1152
1154{
1155public:
1157 GAL_CONTEXT_LOCKER( aGal )
1158 {
1159 m_gal->beginUpdate();
1160 }
1161
1163 {
1164 m_gal->endUpdate();
1165 }
1166};
1167
1168
1170{
1171public:
1173 GAL_CONTEXT_LOCKER( aGal )
1174 {
1176 }
1177
1178 ~GAL_DRAWING_CONTEXT() noexcept( false )
1179 {
1180 m_gal->EndDrawing();
1181 }
1182};
1183
1184
1189{
1190public:
1192 {
1199
1200 // It is not clear to me that GAL needs to save text attributes.
1201 // Only BitmapText uses it, and maybe that should be passed in
1202 // explicitly (like for Draw) - every caller of BitmapText sets
1203 // the text attributes anyway.
1204 // TEXT_ATTRS = 64,
1205
1206 // Convenience flags
1210
1212 };
1213
1219 GAL_SCOPED_ATTRS( KIGFX::GAL& aGal, int aFlags )
1220 : m_gal( aGal ), m_flags( aFlags )
1221 {
1222 // Save what we need to restore later.
1223 // These are all so cheap to copy, it's likely not worth if'ing
1224 m_strokeWidth = aGal.GetLineWidth();
1226 m_isStroke = aGal.GetIsStroke();
1227 m_fillColor = aGal.GetFillColor();
1228 m_isFill = aGal.GetIsFill();
1229 m_layerDepth = aGal.getLayerDepth();
1230 }
1231
1233 {
1234 // Restore the attributes that were saved
1235 // based on the flags that were set.
1236
1237 if( m_flags & STROKE_WIDTH )
1239
1240 if( m_flags & STROKE_COLOR )
1242
1243 if( m_flags & IS_STROKE )
1245
1246 if( m_flags & FILL_COLOR )
1248
1249 if( m_flags & IS_FILL )
1251
1252 if( m_flags & LAYER_DEPTH )
1254 }
1255
1256private:
1259
1263
1266
1268};
1269
1270
1271}; // namespace KIGFX
1272
1273#endif /* GRAPHICSABSTRACTIONLAYER_H_ */
This class handle bitmap images in KiCad.
Definition: bitmap_base.h:49
constexpr const Vec GetEnd() const
Definition: box2.h:212
constexpr const Vec & GetOrigin() const
Definition: box2.h:210
A color representation with 4 components: red, green, blue, alpha.
Definition: color4d.h:104
Attribute save/restore for GAL attributes.
GAL_SCOPED_ATTRS(KIGFX::GAL &aGal, int aFlags)
Instantiate a GAL_SCOPED_ATTRS object, saving the current attributes of the GAL.
Abstract interface for drawing on a 2D-surface.
const VECTOR2D & GetGridOrigin() const
virtual void ResizeScreen(int aWidth, int aHeight)
Resize the canvas.
virtual void DrawPolygon(const std::deque< VECTOR2D > &aPointList)
Draw a polygon.
bool IsTextMirrored() const
void SetGridColor(const COLOR4D &aGridColor)
Set the grid color.
float GetGridLineWidth() const
Get the grid line width.
virtual bool Show(bool aShow)
Show/hide the GAL canvas.
virtual void SetLayerDepth(double aLayerDepth)
Set the depth of the layer (position on the z-axis)
const MATRIX3x3D & GetWorldScreenMatrix() const
Get the world <-> screen transformation matrix.
bool IsCursorEnabled() const
Return information about cursor visibility.
virtual void SetIsFill(bool aIsFillEnabled)
Enable/disable fill.
virtual void EndDrawing()
End the drawing, needs to be called for every new frame.
virtual void StartDiffLayer()
Begins rendering of a differential layer.
bool m_isCursorEnabled
Is the cursor enabled?
virtual void DrawGlyph(const KIFONT::GLYPH &aGlyph, int aNth=0, int aTotal=1)
Draw a polygon representing a font glyph.
virtual void EndDiffLayer()
Ends rendering of a differential layer.
virtual void Rotate(double aAngle)
Rotate the context.
virtual void DrawRectangle(const VECTOR2D &aStartPoint, const VECTOR2D &aEndPoint)
Draw a rectangle.
MATRIX3x3D m_worldScreenMatrix
World transformation.
VECTOR2D GetVisibleGridSize() const
Return the visible grid size in x and y directions.
double m_layerDepth
The actual layer depth.
void SetVerticalJustify(const GR_TEXT_V_ALIGN_T aVerticalJustify)
bool GetIsFill() const
Get the fill status.
void AdvanceDepth()
Change the current depth to deeper, so it is possible to draw objects right beneath other.
const COLOR4D & GetFillColor() const
Get the fill color.
void SetFontBold(const bool aBold)
MATRIX3x3D m_screenWorldMatrix
Screen transformation.
void SetFontUnderlined(bool aUnderlined)
void SetHorizontalJustify(const GR_TEXT_H_ALIGN_T aHorizontalJustify)
virtual RENDER_TARGET GetTarget() const
Get the currently used target for rendering.
double GetMaxDepth() const
bool m_axesEnabled
Should the axes be drawn.
void SetRotation(double aRotation)
Get/set the rotation angle (in radians).
float m_gridLineWidth
Line width of the grid.
void SetFlip(bool xAxis, bool yAxis)
Sets flipping of the screen.
VECTOR2I m_screenSize
Screen size in screen (wx logical) coordinates.
virtual void Flush()
Force all remaining objects to be drawn.
virtual int GetSwapInterval() const
Return the swap interval. -1 for adaptive, 0 for disabled/unknown.
virtual void DeleteGroup(int aGroupNumber)
Delete the group from the memory.
std::stack< double > m_depthStack
Stored depth values.
GR_TEXT_H_ALIGN_T GetHorizontalJustify() const
void normalize(T &a, T &b)
Ensure that the first element is smaller than the second.
VECTOR2D m_depthRange
Range of the depth.
double GetZoomFactor() const
virtual void SetFillColor(const COLOR4D &aColor)
Set the fill color.
double m_zoomFactor
The zoom factor.
virtual void Translate(const VECTOR2D &aTranslation)
Translate the context.
VECTOR2D ToScreen(const VECTOR2D &aPoint) const
Compute the point position in screen coordinates from given world coordinates.
void SetCursorEnabled(bool aCursorEnabled)
Enable/disable cursor.
void SetAxesEnabled(bool aAxesEnabled)
Enable drawing the axes.
virtual void DrawPolylines(const std::vector< std::vector< VECTOR2D > > &aPointLists)
Draw multiple polylines.
virtual bool HasTarget(RENDER_TARGET aTarget)
Return true if the target exists.
GRID_STYLE m_gridStyle
Grid display style.
void SetCursorColor(const COLOR4D &aCursorColor)
Set the cursor color.
COLOR4D m_cursorColor
Cursor color.
COLOR4D m_axesColor
Color of the axes.
int m_gridMinSpacing
Minimum screen size of the grid (pixels) below which the grid is not drawn.
void SetGridSize(const VECTOR2D &aGridSize)
Set the grid size.
const VECTOR2D & GetLookAtPoint() const
double GetRotation() const
const MATRIX3x3D & GetScreenWorldMatrix() const
Get the screen <-> world transformation matrix.
bool IsFontUnderlined() const
virtual void DrawCircle(const VECTOR2D &aCenterPoint, double aRadius)
Draw a circle using world coordinates.
virtual void Restore()
Restore the context.
float m_lineWidth
The line width.
const COLOR4D & GetStrokeColor() const
Get the stroke color.
virtual void ClearTarget(RENDER_TARGET aTarget)
Clear the target for rendering.
void SetZoomFactor(double aZoomFactor)
virtual void BeginDrawing()
Start/end drawing functions, draw calls can be only made in between the calls to BeginDrawing()/EndDr...
void computeWorldScale()
Compute the scaling factor for the world->screen matrix.
virtual bool IsOpenGlEngine()
Return true if the GAL engine is a OpenGL based type.
virtual int BeginGroup()
Begin a group.
TEXT_ATTRIBUTES m_attributes
static const int MIN_DEPTH
Possible depth range.
const VECTOR2D & GetGridSize() const
Return the grid size.
virtual void DrawPolygon(const VECTOR2D aPointList[], int aListSize)
virtual void SetLineWidth(float aLineWidth)
Set the line width.
double m_rotation
Rotation transformation (radians)
VECTOR2D m_gridSize
The grid size.
virtual void DrawGrid()
virtual void DrawPolygon(const SHAPE_POLY_SET &aPolySet, bool aStrokeTriangulation=false)
virtual void ChangeGroupDepth(int aGroupNumber, int aDepth)
Change the depth (Z-axis position) of the group.
COLOR4D m_fillColor
The fill color.
virtual void EndNegativesLayer()
Ends rendering of a negatives layer and draws it to the main layer.
void DrawRectangle(const BOX2I &aRect)
double m_worldUnitLength
The unit length of the world coordinates [inch].
virtual void StartNegativesLayer()
Begins rendering in a new layer that will be copied to the main layer in EndNegativesLayer().
void SetTextMirrored(const bool aMirrored)
virtual void DrawPolyline(const std::deque< VECTOR2D > &aPointList)
Draw a polyline.
void SetCoarseGrid(int aInterval)
Draw every tick line wider.
void SetAxesColor(const COLOR4D &aAxesColor)
Set the axes color.
virtual void SetStrokeColor(const COLOR4D &aColor)
Set the stroke color.
virtual void ChangeGroupColor(int aGroupNumber, const COLOR4D &aNewColor)
Change the color used to draw the group.
virtual void DrawArcSegment(const VECTOR2D &aCenterPoint, double aRadius, const EDA_ANGLE &aStartAngle, const EDA_ANGLE &aAngle, double aWidth, double aMaxError)
Draw an arc segment.
virtual bool IsContextLocked()
Checks the state of the context lock.
VECTOR2D m_cursorPosition
Current cursor position (world coordinates)
VECTOR2D m_gridOffset
The grid offset to compensate cursor position.
virtual void SetIsStroke(bool aIsStrokeEnabled)
Enable/disable stroked outlines.
virtual void beginUpdate()
Enable item update mode.
virtual void DrawGroup(int aGroupNumber)
Draw the stored group.
double getLayerDepth() const
const VECTOR2I & GetGlyphSize() const
int m_gridTick
Every tick line gets the double width.
double m_worldScale
The scale factor world->screen.
void SetLookAtPoint(const VECTOR2D &aPoint)
Get/set the Point in world space to look at.
virtual void DrawPolygon(const SHAPE_LINE_CHAIN &aPolySet)
bool GetGridVisibility() const
void SetGridOrigin(const VECTOR2D &aGridOrigin)
Set the origin point for the grid.
virtual bool IsCairoEngine()
Return true if the GAL engine is a Cairo based type.
virtual void ClearScreen()
Clear the screen.
virtual void DrawLine(const VECTOR2D &aStartPoint, const VECTOR2D &aEndPoint)
Draw a line.
VECTOR2D m_gridOrigin
The grid origin.
virtual void endUpdate()
Disable item update mode.
void SetWorldUnitLength(double aWorldUnitLength)
Set the unit length.
virtual void DrawPolyline(const std::vector< VECTOR2D > &aPointList)
KICURSOR m_currentNativeCursor
Current cursor.
bool m_globalFlipY
Flag for Y axis flipping.
virtual void UnlockContext(int aClientCookie)
void SetClearColor(const COLOR4D &aColor)
void SetScreenSize(const VECTOR2I &aSize)
const COLOR4D & GetClearColor() const
bool m_fullscreenCursor
Shape of the cursor (fullscreen or small cross)
virtual void DrawSegmentChain(const SHAPE_LINE_CHAIN &aLineChain, double aWidth)
static const int GRID_DEPTH
Depth level on which the grid is drawn.
virtual bool IsInitialized() const
Return the initialization status for the canvas.
void SetGlyphSize(const VECTOR2I aSize)
virtual void DrawGlyphs(const std::vector< std::unique_ptr< KIFONT::GLYPH > > &aGlyphs)
Draw polygons representing font glyphs.
virtual void Scale(const VECTOR2D &aScale)
Scale the context.
virtual void DrawCurve(const VECTOR2D &startPoint, const VECTOR2D &controlPointA, const VECTOR2D &controlPointB, const VECTOR2D &endPoint, double aFilterValue=0.0)
Draw a cubic bezier spline.
bool m_isFillEnabled
Is filling of graphic objects enabled ?
bool GetGridSnapping() const
virtual void EndGroup()
End the group.
virtual void DrawArc(const VECTOR2D &aCenterPoint, double aRadius, const EDA_ANGLE &aStartAngle, const EDA_ANGLE &aAngle)
Draw an arc.
virtual void Transform(const MATRIX3x3D &aTransformation)
Transform the context.
virtual void SetNegativeDrawMode(bool aSetting)
Set negative draw mode in the renderer.
COLOR4D m_gridColor
Color of the grid.
VECTOR2D ToWorld(const VECTOR2D &aPoint) const
Compute the point position in world coordinates from given screen coordinates.
COLOR4D m_strokeColor
The color of the outlines.
void SetFontItalic(bool aItalic)
bool m_isStrokeEnabled
Are the outlines stroked ?
virtual void DrawBitmap(const BITMAP_BASE &aBitmap, double alphaBlend=1.0)
Draw a bitmap image.
GAL_DISPLAY_OPTIONS & m_options
bool m_gridVisibility
Should the grid be shown.
double GetMinDepth() const
virtual void ClearCache()
Delete all data created during caching of graphic items.
virtual void SetTarget(RENDER_TARGET aTarget)
Set the target for rendering.
virtual void DrawSegment(const VECTOR2D &aStartPoint, const VECTOR2D &aEndPoint, double aWidth)
Draw a rounded segment.
double m_screenDPI
The dots per inch of the screen.
virtual void DrawPolyline(const SHAPE_LINE_CHAIN &aLineChain)
const VECTOR2I & GetScreenPixelSize() const
Return GAL canvas size in pixels.
void SetGridVisibility(bool aVisibility)
Set the visibility setting of the grid.
float GetLineWidth() const
Get the line width.
virtual void Save()
Save the context.
bool m_globalFlipX
Flag for X axis flipping.
virtual void LockContext(int aClientCookie)
Use GAL_CONTEXT_LOCKER RAII object unless you know what you're doing.
virtual void DrawSegmentChain(const std::vector< VECTOR2D > &aPointList, double aWidth)
Draw a chain of rounded segments.
void SetWorldScreenMatrix(const MATRIX3x3D &aMatrix)
Set the world <-> screen transformation matrix.
GR_TEXT_V_ALIGN_T GetVerticalJustify() const
bool GetIsStroke() const
Get the stroke status.
virtual void DrawCursor(const VECTOR2D &aCursorPosition)
Draw the cursor.
void SetDepthRange(const VECTOR2D &aDepthRange)
Set the range of the layer depth.
double GetWorldScale() const
Get the world scale.
VECTOR2D m_lookAtPoint
Point to be looked at in world space.
virtual bool IsVisible() const
Return true if the GAL canvas is visible on the screen.
void SetScreenDPI(double aScreenDPI)
Set the dots per inch of the screen.
virtual void DrawPolyline(const VECTOR2D aPointList[], int aListSize)
virtual void EnableDepthTest(bool aEnabled=false)
bool m_forceDisplayCursor
Always show cursor.
static const int MAX_DEPTH
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
Represent a set of closed polygons.
KICURSOR
Definition: cursors.h:34
#define GAL_API
Definition: gal.h:28
The Cairo implementation of the graphics abstraction layer.
Definition: color4d.cpp:247
GRID_STYLE
Type definition of the grid style.
RENDER_TARGET
RENDER_TARGET: Possible rendering targets.
Definition: definitions.h:36
@ TARGET_CACHED
Main rendering target (cached)
Definition: definitions.h:37
GR_TEXT_H_ALIGN_T
This is API surface mapped to common.types.HorizontalAlignment.
GR_TEXT_V_ALIGN_T
This is API surface mapped to common.types.VertialAlignment.
VECTOR2< double > VECTOR2D
Definition: vector2d.h:694