1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
/* -*- Mode: C++ -*-
KDChart - a multi-platform charting engine
*/
/****************************************************************************
** Copyright (C) 2001-2003 Klarälvdalens Datakonsult AB. All rights reserved.
**
** This file is part of the KDChart library.
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** Licensees holding valid commercial KDChart licenses may use this file in
** accordance with the KDChart Commercial License Agreement provided with
** the Software.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** See http://www.klaralvdalens-datakonsult.se/?page=products for
** information about KDChart Commercial License Agreements.
**
** Contact info@klaralvdalens-datakonsult.se if any conditions of this
** licensing are not clear to you.
**
**********************************************************************/
#ifndef __KDCHARTTEXTPIECE_H__
#define __KDCHARTTEXTPIECE_H__
#include <qstring.h>
#include <qfont.h>
#include <qregion.h>
#include <qpalette.h>
#include <qobject.h>
#include <kdchart_export.h>
class QBrush;
class QPainter;
class QSimpleRichText;
class QFontMetrics;
class KDCHART_EXPORT KDChartTextPiece :public QObject
{
Q_OBJECT
public:
KDChartTextPiece();
KDChartTextPiece( const QString& text, const QFont& font );
KDChartTextPiece( QPainter* painter, const QString& text, const QFont& font );
virtual ~KDChartTextPiece();
/**
Copy the settings of text piece \c source into this box.
\note Use this method instead of using the assignment operator.
\sa clone
*/
void deepCopy( const KDChartTextPiece* source );
/**
Create a new text piece on the heap, copy the settings stored by
this text piece into the newly created text piece and return
the pointer to the new text piece.
\note Use this method instead of using the copy constructor.
\sa deepCopy
*/
const KDChartTextPiece* clone() const;
private:
KDChartTextPiece( const KDChartTextPiece& ) : QObject(0) {}
public slots:
virtual int width() const;
virtual int height() const;
virtual int fontLeading() const;
virtual QRect rect( QPainter *p, const QRect& clipRect) const;
virtual void draw( QPainter *p, int x, int y, const QRect& clipRect,
const QColor& color, const QBrush* paper = 0 ) const;
virtual void draw( QPainter *p, int x, int y, const QRegion& clipRegion,
const QColor& color, const QBrush* paper = 0 ) const;
QString text() const;
QFont font() const;
bool isRichText() const;
protected:
bool _isRichText;
QSimpleRichText* _richText; // used when _isRichText == true
QString _text; // used when _isRichText == false
QFont _font; // used when _isRichText == false
QFontMetrics* _metrics;
bool _dirtyMetrics;
};
#endif
|