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
|
/*
* Kivio - Visual Modelling and Flowcharting
* Copyright (C) 2000-2001 theKompany.com & Dave Marotti
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifndef KIVIO_GRADIENT_H
#define KIVIO_GRADIENT_H
#include <tqptrlist.h>
#include <tqcolor.h>
#include <tqdom.h>
class KivioPoint;
class KivioGradient
{
public:
// Gradient type enumerations
typedef enum {
kgtNone=0,
kgtLinear,
kgtBiLinear,
kgtRadial,
kgtSquare,
kgtConicalSymmetric,
kgtConicalAsymmetric,
kgtLast
} KivioGradientType;
protected:
TQPtrList <TQColor> *m_pColors; // A list of the colors in the gradient
TQPtrList <KivioPoint> *m_pPoints; // A list of the points for each color
KivioGradientType m_gradientType; // The type of gradient
public:
KivioGradient();
KivioGradient( const KivioGradient & );
virtual ~KivioGradient();
void copyInto( KivioGradient *pTarget ) const;
bool loadXML( const TQDomElement & );
TQDomElement saveXML( TQDomDocument & );
TQPtrList<TQColor> *colors() const { return m_pColors; }
TQPtrList<KivioPoint> *points() const { return m_pPoints; }
KivioGradientType gradientType() const { return m_gradientType; }
void setGradientType( KivioGradientType t ) { m_gradientType=t; }
};
#endif
|