summaryrefslogtreecommitdiffstats
path: root/karbon/core/vgradient.h
blob: 8341eeabc01dca4f5ec6759fad3c4da31fe1cbfd (plain)
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
/* This file is part of the KDE project
   Copyright (C) 2002 - 2005, The Karbon Developers

   This library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Library General Public
   License as published by the Free Software Foundation; either
   version 2 of the License, or (at your option) any later version.

   This library 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
   Library General Public License for more details.

   You should have received a copy of the GNU Library General Public License
   along with this library; see the file COPYING.LIB.  If not, write to
   the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301, USA.
*/

#ifndef __VGRADIENT_H__
#define __VGRADIENT_H__

#include <tqptrlist.h>
#include <tqptrvector.h>

#include <koffice_export.h>
#include <KoPoint.h>

#include "vcolor.h"

class TQDomElement;
class KoGenStyle;
class KoGenStyles;
class KoStyleStack;
class VObject;

class VColorStop
{
	public:
		VColorStop( double r, double m, VColor c )
			{ rampPoint = r; midPoint = m; color = c; };
		VColorStop( const VColorStop& colorStop )
			{ rampPoint = colorStop.rampPoint; midPoint = colorStop.midPoint; color = colorStop.color; };

		VColor color;

		// relative position of color point (0.0-1.0):
		float rampPoint;

		// relative position of midpoint (0.0-1.0)
		// between two ramp points. ignored for last VColorStop.
		float midPoint;

		friend inline bool operator== ( VColorStop& s1, VColorStop& s2 )
				{ return s1.rampPoint == s2.rampPoint; };
}; // VColorStop

class KARBONBASE_EXPORT VGradient
{
friend class VGradientWidget;

public:
	enum VGradientType
	{
		linear = 0,
		radial = 1,
		conic  = 2
	};

	enum VGradientRepeatMethod
	{
		none    = 0,
		reflect = 1,
		repeat  = 2
	};

	class VColorStopList : public TQPtrList<VColorStop>
	{
		protected:
			virtual int compareItems( TQPtrCollection::Item item1, TQPtrCollection::Item item2 );
	}; // VColorStopList

	VGradient( VGradientType type = linear );
	VGradient( const VGradient& gradient );

	VGradient& operator=(const VGradient& gradient);

	VGradientType type() const { return m_type; }
	void setType( VGradientType type ) { m_type = type; }

	VGradientRepeatMethod repeatMethod() const { return m_repeatMethod; }
	void setRepeatMethod( VGradientRepeatMethod repeatMethod ) { m_repeatMethod = repeatMethod; }

	const TQPtrVector<VColorStop> colorStops() const;
	void addStop( const VColorStop& colorStop );
	void addStop( const VColor &color, float rampPoint, float midPoint );
	void removeStop( const VColorStop& colorStop );
	void clearStops();

	KoPoint origin() const { return m_origin; }
	void setOrigin( const KoPoint &origin ) { m_origin = origin; }

	KoPoint focalPoint() const { return m_focalPoint; }
	void setFocalPoint( const KoPoint &focalPoint ) { m_focalPoint = focalPoint; }

	KoPoint vector() const { return m_vector; }
	void setVector( const KoPoint &vector ) { m_vector = vector; }

	void save( TQDomElement& element ) const;
	TQString saveOasis( KoGenStyles &mainStyles ) const;
	void load( const TQDomElement& element );
	void loadOasis( const TQDomElement &object, KoStyleStack &stack, VObject* tqparent = 0L );

	void transform( const TQWMatrix& m );

protected:
	VColorStopList        m_colorStops;
  
private:
	VGradientType         m_type		: 2;
	VGradientRepeatMethod m_repeatMethod	: 2;

	// coordinates:
	KoPoint m_origin;
	KoPoint m_focalPoint;
	KoPoint m_vector;
}; // VGradient

#endif /* __VGRADIENT_H__ */