Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qpaintengine.h
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#ifndef QPAINTENGINE_H
5#define QPAINTENGINE_H
6
7#include <QtGui/qtguiglobal.h>
8#include <QtCore/qnamespace.h>
9#include <QtCore/qobjectdefs.h>
10#include <QtCore/qscopedpointer.h>
11#include <QtGui/qpainter.h>
12
13QT_BEGIN_NAMESPACE
14
15
16class QFontEngine;
17class QLineF;
18class QPaintDevice;
19class QPaintEnginePrivate;
20class QPainterPath;
21class QPointF;
22class QPolygonF;
23class QRectF;
24struct QGlyphLayout;
25class QTextItemInt;
26class QPaintEngineState;
27
28class Q_GUI_EXPORT QTextItem {
29public:
30 enum RenderFlag {
31 RightToLeft = 0x1,
32 Overline = 0x10,
33 Underline = 0x20,
34 StrikeOut = 0x40,
35
36 Dummy = 0xffffffff
37 };
38 Q_DECLARE_FLAGS(RenderFlags, RenderFlag)
39 qreal descent() const;
40 qreal ascent() const;
41 qreal width() const;
42
43 RenderFlags renderFlags() const;
44 QString text() const;
45 QFont font() const;
46};
47Q_DECLARE_TYPEINFO(QTextItem, Q_PRIMITIVE_TYPE);
48
49
50class Q_GUI_EXPORT QPaintEngine
51{
52 Q_DECLARE_PRIVATE(QPaintEngine)
53public:
54 enum PaintEngineFeature {
55 PrimitiveTransform = 0x00000001, // Can transform primitives brushes
56 PatternTransform = 0x00000002, // Can transform pattern brushes
57 PixmapTransform = 0x00000004, // Can transform pixmaps
58 PatternBrush = 0x00000008, // Can fill with pixmaps and standard patterns
59 LinearGradientFill = 0x00000010, // Can fill gradient areas
60 RadialGradientFill = 0x00000020, // Can render radial gradients
61 ConicalGradientFill = 0x00000040, // Can render conical gradients
62 AlphaBlend = 0x00000080, // Can do source over alpha blend
63 PorterDuff = 0x00000100, // Can do general porter duff compositions
64 PainterPaths = 0x00000200, // Can fill, outline and clip paths
65 Antialiasing = 0x00000400, // Can antialias lines
66 BrushStroke = 0x00000800, // Can render brush based pens
67 ConstantOpacity = 0x00001000, // Can render at constant opacity
68 MaskedBrush = 0x00002000, // Can fill with textures that has an alpha channel or mask
69 PerspectiveTransform = 0x00004000, // Can do perspective transformations
70 BlendModes = 0x00008000, // Can do extended Porter&Duff composition
71 ObjectBoundingModeGradients = 0x00010000, // Can do object bounding mode gradients
72 RasterOpModes = 0x00020000, // Can do logical raster operations
73 PaintOutsidePaintEvent = 0x20000000, // Engine is capable of painting outside paint events
74 /* 0x10000000, // Used for emulating
75 QGradient::StretchToDevice,
76 defined in qpainter.cpp
77
78 0x40000000, // Used internally for emulating opaque backgrounds
79 */
80
81 AllFeatures = 0xffffffff // For convenience
82 };
83 Q_DECLARE_FLAGS(PaintEngineFeatures, PaintEngineFeature)
84
85 enum DirtyFlag {
86 DirtyPen = 0x0001,
87 DirtyBrush = 0x0002,
89 DirtyFont = 0x0008,
94 DirtyClipPath = 0x0100,
95 DirtyHints = 0x0200,
98 DirtyOpacity = 0x1000,
99
100 AllDirty = 0xffff
101 };
102 Q_DECLARE_FLAGS(DirtyFlags, DirtyFlag)
103
110
111 explicit QPaintEngine(PaintEngineFeatures features=PaintEngineFeatures());
112 virtual ~QPaintEngine();
113
114 bool isActive() const { return active; }
115 void setActive(bool newState) { active = newState; }
116
117 virtual bool begin(QPaintDevice *pdev) = 0;
118 virtual bool end() = 0;
119
120 virtual void updateState(const QPaintEngineState &state) = 0;
121
122 virtual void drawRects(const QRect *rects, int rectCount);
123 virtual void drawRects(const QRectF *rects, int rectCount);
124
125 virtual void drawLines(const QLine *lines, int lineCount);
126 virtual void drawLines(const QLineF *lines, int lineCount);
127
128 virtual void drawEllipse(const QRectF &r);
129 virtual void drawEllipse(const QRect &r);
130
131 virtual void drawPath(const QPainterPath &path);
132
133 virtual void drawPoints(const QPointF *points, int pointCount);
134 virtual void drawPoints(const QPoint *points, int pointCount);
135
136 virtual void drawPolygon(const QPointF *points, int pointCount, PolygonDrawMode mode);
137 virtual void drawPolygon(const QPoint *points, int pointCount, PolygonDrawMode mode);
138
139 virtual void drawPixmap(const QRectF &r, const QPixmap &pm, const QRectF &sr) = 0;
140 virtual void drawTextItem(const QPointF &p, const QTextItem &textItem);
141 virtual void drawTiledPixmap(const QRectF &r, const QPixmap &pixmap, const QPointF &s);
142 virtual void drawImage(const QRectF &r, const QImage &pm, const QRectF &sr,
143 Qt::ImageConversionFlags flags = Qt::AutoColor);
144
145 void setPaintDevice(QPaintDevice *device);
146 QPaintDevice *paintDevice() const;
147
148 void setSystemClip(const QRegion &baseClip);
149 QRegion systemClip() const;
150
151 void setSystemRect(const QRect &rect);
152 QRect systemRect() const;
153
154
155 virtual QPoint coordinateOffset() const;
156
177 virtual Type type() const = 0;
178
179 inline void fix_neg_rect(int *x, int *y, int *w, int *h);
180
181 inline bool testDirty(DirtyFlags df);
182 inline void setDirty(DirtyFlags df);
183 inline void clearDirty(DirtyFlags df);
184
185 bool hasFeature(PaintEngineFeatures feature) const { return bool(gccaps & feature); }
186
187 QPainter *painter() const;
188
189 void syncState();
190 inline bool isExtended() const { return extended; }
191
192 virtual QPixmap createPixmap(QSize size);
193 virtual QPixmap createPixmapFromImage(QImage image, Qt::ImageConversionFlags flags = Qt::AutoColor);
194
195protected:
196 QPaintEngine(QPaintEnginePrivate &data, PaintEngineFeatures devcaps=PaintEngineFeatures());
197
198 QPaintEngineState *state;
200
204
206
207private:
208 void setAutoDestruct(bool autoDestr) { selfDestruct = autoDestr; }
209 bool autoDestruct() const { return selfDestruct; }
211
212 friend class QPainterReplayer;
213 friend class QFontEngineBox;
214 friend class QFontEngineMac;
215 friend class QFontEngineWin;
216 friend class QMacPrintEngine;
218 friend class QFontEngineQPF2;
219 friend class QPainter;
220 friend class QPainterPrivate;
221 friend class QWidget;
222 friend class QWidgetPrivate;
223 friend class QWin32PaintEngine;
225 friend class QMacCGContext;
228};
229
230
231class Q_GUI_EXPORT QPaintEngineState
232{
233public:
234 QPaintEngine::DirtyFlags state() const { return dirtyFlags; }
235
236 QPen pen() const;
237 QBrush brush() const;
238 QPointF brushOrigin() const;
239 QBrush backgroundBrush() const;
240 Qt::BGMode backgroundMode() const;
241 QFont font() const;
242 QTransform transform() const;
243
244 Qt::ClipOperation clipOperation() const;
245 QRegion clipRegion() const;
246 QPainterPath clipPath() const;
247 bool isClipEnabled() const;
248
249 QPainter::RenderHints renderHints() const;
250 QPainter::CompositionMode compositionMode() const;
251 qreal opacity() const;
252
253 QPainter *painter() const;
254
255 bool brushNeedsResolving() const;
256 bool penNeedsResolving() const;
257
258protected:
259 friend class QPaintEngine;
260 friend class QRasterPaintEngine;
261 friend class QWidget;
262 friend class QPainter;
263 friend class QPainterPrivate;
264 friend class QMacPrintEnginePrivate;
265
266 QPaintEngine::DirtyFlags dirtyFlags;
267};
268
269//
270// inline functions
271//
272
273inline void QPaintEngine::fix_neg_rect(int *x, int *y, int *w, int *h)
274{
275 if (*w < 0) {
276 *w = -*w;
277 *x -= *w - 1;
278 }
279 if (*h < 0) {
280 *h = -*h;
281 *y -= *h - 1;
282 }
283}
284
285inline bool QPaintEngine::testDirty(DirtyFlags df) {
286 Q_ASSERT(state);
287 return bool(state->dirtyFlags & df);
288}
289
290inline void QPaintEngine::setDirty(DirtyFlags df) {
291 Q_ASSERT(state);
292 state->dirtyFlags |= df;
293}
294
295inline void QPaintEngine::clearDirty(DirtyFlags df)
296{
297 Q_ASSERT(state);
298 state->dirtyFlags &= ~df;
299}
300
301Q_DECLARE_OPERATORS_FOR_FLAGS(QTextItem::RenderFlags)
302Q_DECLARE_OPERATORS_FOR_FLAGS(QPaintEngine::PaintEngineFeatures)
303Q_DECLARE_OPERATORS_FOR_FLAGS(QPaintEngine::DirtyFlags)
304
305QT_END_NAMESPACE
306
307#endif // QPAINTENGINE_H
QScopedPointer< QImageIOHandlerPrivate > d_ptr
The QPaintEngineState class provides information about the active paint engine's current state....
\inmodule QtGui
virtual QPixmap createPixmap(QSize size)
friend class QPainter
void setSystemRect(const QRect &rect)
void setActive(bool newState)
Sets the active state of the paint engine to state.
virtual void drawPolygon(const QPoint *points, int pointCount, PolygonDrawMode mode)
This is an overloaded member function, provided for convenience. It differs from the above function o...
virtual QPixmap createPixmapFromImage(QImage image, Qt::ImageConversionFlags flags=Qt::AutoColor)
friend class QWidgetPrivate
QRect systemRect() const
QPaintEngine(PaintEngineFeatures features=PaintEngineFeatures())
Creates a paint engine with the featureset specified by caps.
friend class QFontEngineQPF2
friend class QMacCGContext
virtual void drawTextItem(const QPointF &p, const QTextItem &textItem)
This function draws the text item textItem at position p.
virtual void drawLines(const QLineF *lines, int lineCount)
The default implementation splits the list of lines in lines into lineCount separate calls to drawPat...
PolygonDrawMode
\value OddEvenMode The polygon should be drawn using OddEven fill rule.
virtual void drawPoints(const QPointF *points, int pointCount)
Draws the first pointCount points in the buffer points.
virtual void drawRects(const QRectF *rects, int rectCount)
Draws the first rectCount rectangles in the buffer rects.
virtual void drawImage(const QRectF &r, const QImage &pm, const QRectF &sr, Qt::ImageConversionFlags flags=Qt::AutoColor)
Reimplement this function to draw the part of the image specified by the sr rectangle in the given re...
QPainter * painter() const
Returns the paint engine's painter.
void fix_neg_rect(int *x, int *y, int *w, int *h)
void setPaintDevice(QPaintDevice *device)
virtual QPoint coordinateOffset() const
virtual void drawPolygon(const QPointF *points, int pointCount, PolygonDrawMode mode)
Reimplement this virtual function to draw the polygon defined by the pointCount first points in point...
void setDirty(DirtyFlags df)
void setSystemClip(const QRegion &baseClip)
QPaintEngineState * state
friend class QPainterReplayer
friend class QX11GLPlatformPixmap
PaintEngineFeatures gccaps
void clearDirty(DirtyFlags df)
bool hasFeature(PaintEngineFeatures feature) const
Returns true if the paint engine supports the specified feature; otherwise returns false.
virtual void drawEllipse(const QRectF &r)
Reimplement this function to draw the largest ellipse that can be contained within rectangle rect.
QRegion systemClip() const
bool isExtended() const
QPaintDevice * paintDevice() const
Returns the device that this engine is painting on, if painting is active; otherwise returns \nullptr...
bool testDirty(DirtyFlags df)
virtual void updateState(const QPaintEngineState &state)=0
Reimplement this function to update the state of a paint engine.
DirtyFlag
\value DirtyPen The pen is dirty and needs to be updated.
Type
\value X11 \value Windows \value MacPrinter \value CoreGraphics \macos's Quartz2D (CoreGraphics) \val...
virtual Type type() const =0
Reimplement this function to return the paint engine \l{Type}.
void drawPath(const QPainterPath &path)
Draws the given painter path using the current pen for outline and the current brush for filling.
bool begin(QPaintDevice *)
Begins painting the paint device and returns true if successful; otherwise returns false.
void drawRects(const QRectF *rects, int rectCount)
Draws the first rectCount of the given rectangles using the current pen and brush.
void drawLines(const QLineF *lines, int lineCount)
Draws the first lineCount lines in the array lines using the current pen.
friend class QFontEngineMac
Definition qpainter.h:427
friend class QWin32PaintEngine
Definition qpainter.h:432
friend class QWin32PaintEnginePrivate
Definition qpainter.h:433
friend class QWidget
Definition qpainter.h:423
friend class QFontEngineWin
Definition qpainter.h:428
void drawEllipse(const QRectF &r)
Draws the ellipse defined by the given rectangle.
bool end()
Ends painting.
void drawPoints(const QPointF *points, int pointCount)
Draws the first pointCount points in the array points using the current pen's color.
bool isActive() const
Returns true if begin() has been called and end() has not yet been called; otherwise returns false.
\inmodule QtCore\reentrant
Definition qpoint.h:229
The QPolygonF class provides a list of points using floating point precision.
Definition qpolygon.h:96
Internal QTextItem.
\inmodule QtGui
uint is_closing
Definition qwidget.h:82
QPalette pal
Definition qwidget.h:91
uint focus_policy
Definition qwidget.h:80
uint in_show
Definition qwidget.h:83
uint unused
Definition qwidget.h:89
uint fstrut_dirty
Definition qwidget.h:85
QRect wrect
Definition qwidget.h:93
QRect crect
Definition qwidget.h:90
uint in_destructor
Definition qwidget.h:88
uint sizehint_forced
Definition qwidget.h:81
uint in_set_window_state
Definition qwidget.h:84
Qt::WindowFlags window_flags
Definition qwidget.h:78
QFont fnt
Definition qwidget.h:92
uint window_modality
Definition qwidget.h:87
uint window_state
Definition qwidget.h:79
WId winid
Definition qwidget.h:76
uint context_menu_policy
Definition qwidget.h:86
uint widget_attributes
Definition qwidget.h:77
The QWidget class is the base class of all user interface objects.
Definition qwidget.h:99
The QWindows11Style class provides a look and feel suitable for applications on Microsoft Windows 11.
void drawControl(ControlElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget) const override
void unpolish(QWidget *widget) override
void polish(QWidget *widget) override
void drawComplexControl(ComplexControl control, const QStyleOptionComplex *option, QPainter *painter, const QWidget *widget) const override
QSize sizeFromContents(ContentsType type, const QStyleOption *option, const QSize &size, const QWidget *widget) const override
QRect subControlRect(ComplexControl control, const QStyleOptionComplex *option, SubControl subControl, const QWidget *widget) const override
QWindows11Style(QWindows11StylePrivate &dd)
void polish(QPalette &pal) override
int pixelMetric(PixelMetric metric, const QStyleOption *option=nullptr, const QWidget *widget=nullptr) const override
int styleHint(StyleHint hint, const QStyleOption *opt=nullptr, const QWidget *widget=nullptr, QStyleHintReturn *returnData=nullptr) const override
void drawPrimitive(PrimitiveElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget) const override
QRect subElementRect(QStyle::SubElement element, const QStyleOption *option, const QWidget *widget=nullptr) const override
~QWindows11Style() override
Destructor.
HRGN mask(QWidget *widget)
QWindowsThemeData(const QWidget *w=nullptr, QPainter *p=nullptr, int themeIn=-1, int part=0, int state=0, const QRect &r=QRect())
QMarginsF margins(const QRect &rect, int propId=TMT_CONTENTMARGINS)
const QWidget * widget
static RECT toRECT(const QRect &qr)
QMarginsF margins(int propId=TMT_CONTENTMARGINS)
static QSizeF themeSize(const QWidget *w=nullptr, QPainter *p=nullptr, int themeIn=-1, int part=0, int state=0)
HBITMAP buffer(int w=0, int h=0)
static int fixedPixelMetric(QStyle::PixelMetric pm)
static HDC hdcForWidgetBackingStore(const QWidget *widget)
static QBackingStore * backingStoreForWidget(const QWidget *widget)
bool swapAlphaChannel(const QRect &rect, bool allPixels=false)
bool drawBackgroundThruNativeBuffer(QWindowsThemeData &QWindowsThemeData, qreal aditionalDevicePixelRatio, qreal correctionFactor)
static HWND winId(const QWidget *widget)
void init(bool force=false)
static bool isLineEditBaseColorSet(const QStyleOption *option, const QWidget *widget)
bool drawBackgroundDirectly(HDC dc, QWindowsThemeData &QWindowsThemeData, qreal aditionalDevicePixelRatio)
static bool isItemViewDelegateLineEdit(const QWidget *widget)
static bool useVista(bool update=false)
bool fixAlphaChannel(const QRect &rect)
void cleanup(bool force=false)
bool isTransparent(QWindowsThemeData &QWindowsThemeData)
bool hasAlphaChannel(const QRect &rect)
QRegion region(QWindowsThemeData &QWindowsThemeData)
bool drawBackground(QWindowsThemeData &QWindowsThemeData, qreal correctionFactor=1)
static HTHEME createTheme(int theme, const QWidget *widget)
static int pixelMetricFromSystemDp(QStyle::PixelMetric pm, const QStyleOption *option=nullptr, const QWidget *widget=nullptr)
static QString themeName(int theme)
The QWindowsVistaStyle class provides a look and feel suitable for applications on Microsoft Windows ...
QRect subElementRect(SubElement element, const QStyleOption *option, const QWidget *widget) const override
QRect subControlRect(ComplexControl cc, const QStyleOptionComplex *opt, SubControl sc, const QWidget *widget) const override
int styleHint(StyleHint hint, const QStyleOption *opt=nullptr, const QWidget *widget=nullptr, QStyleHintReturn *returnData=nullptr) const override
SubControl hitTestComplexControl(ComplexControl control, const QStyleOptionComplex *option, const QPoint &pos, const QWidget *widget=nullptr) const override
void drawControl(ControlElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget) const override
void polish(QWidget *widget) override
int pixelMetric(PixelMetric metric, const QStyleOption *option=nullptr, const QWidget *widget=nullptr) const override
QPixmap standardPixmap(StandardPixmap standardPixmap, const QStyleOption *opt, const QWidget *widget=nullptr) const override
QIcon standardIcon(StandardPixmap standardIcon, const QStyleOption *option=nullptr, const QWidget *widget=nullptr) const override
\reimp
~QWindowsVistaStyle() override
Destructor.
void polish(QPalette &pal) override
void drawPrimitive(PrimitiveElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget=nullptr) const override
QSize sizeFromContents(ContentsType type, const QStyleOption *option, const QSize &size, const QWidget *widget) const override
QWindowsVistaStyle(QWindowsVistaStylePrivate &dd)
void drawComplexControl(ComplexControl control, const QStyleOptionComplex *option, QPainter *painter, const QWidget *widget) const override
void unpolish(QWidget *widget) override
Combined button and popup list for selecting options.
Q_DECLARE_TYPEINFO(QByteArrayView, Q_PRIMITIVE_TYPE)
Q_CORE_EXPORT QDebug operator<<(QDebug debug, QDir::Filters filters)
Definition qdir.cpp:2462
bool operator==(const ThemeMapKey &k1, const ThemeMapKey &k2)
@ UnknownAlpha
size_t qHash(const ThemeMapKey &key)
AlphaChannelType alphaType
ThemeMapKey(const QWindowsThemeData &data)
ThemeMapKey()=default