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
130
131
132
133
134
135
136
137
138
|
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: regband.hxx,v $
*
* $Revision: 1.2 $
*
* last change: $Author: vg $ $Date: 2007-04-11 18:04:26 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
#ifndef _SV_REGBAND_HXX
#define _SV_REGBAND_HXX
#ifndef _SV_SV_H
#include <vcl/sv.h>
#endif
#ifndef _TL_POLY_HXX
#include <tools/poly.hxx>
#endif
/* =======================================================================
class ImplRegionBand
This class handles one y-band of the region. In this band may contain one
or more seprarations in x-direction. The y-Band do not contain any
separation after creation.
The separations are modified with basic clipping functions like Union and
Intersection - the Class will process the clipping for the actual band.
The actual separations may be checked by functions like IsInside or
IsOver.
======================================================================= */
// ------------------------
// - ImplRegionBand-Types -
// ------------------------
// element for the list with x-separations
struct ImplRegionBandSep
{
ImplRegionBandSep* mpNextSep;
long mnXLeft;
long mnXRight;
BOOL mbRemoved;
};
enum LineType { LINE_ASCENDING, LINE_DESCENDING, LINE_HORIZONTAL };
// element for the list with x-separations
struct ImplRegionBandPoint
{
ImplRegionBandPoint* mpNextBandPoint;
long mnX;
long mnLineId;
BOOL mbEndPoint;
LineType meLineType;
};
// ------------------
// - ImplRegionBand -
// ------------------
class ImplRegionBand
{
public:
ImplRegionBand* mpNextBand; // pointer to the next element of the list
ImplRegionBand* mpPrevBand; // pointer to the previous element of the list (only used temporaery)
ImplRegionBandSep* mpFirstSep; // root of the list with x-separations
ImplRegionBandPoint* mpFirstBandPoint; // root of the list with lines
long mnYTop; // actual boundary of the band
long mnYBottom;
BOOL mbTouched;
// create y-band with boundaries
ImplRegionBand( long nYTop, long nYBottom );
// copy y-band with with all data
ImplRegionBand( const ImplRegionBand & theSourceBand );
~ImplRegionBand();
long GetXLeftBoundary() const;
long GetXRightBoundary() const;
// combine overlapping bands
BOOL OptimizeBand();
// generate separations from lines and process
// union with existing separations
void ProcessPoints();
// insert point in the list for later processing
BOOL InsertPoint( long nX, long nLineID,
BOOL bEndPoint, LineType eLineType );
void Union( long nXLeft, long nXRight );
void Intersect( long nXLeft, long nXRight );
void Exclude( long nXLeft, long nXRight );
void XOr( long nXLeft, long nXRight );
void MoveX( long nHorzMove );
void ScaleX( double fHorzScale );
BOOL IsInside( long nX );
BOOL IsInside( long nLeft, long nRight );
BOOL IsOver( long nLeft, long nRight );
BOOL IsEmpty() const { return ((!mpFirstSep) && (!mpFirstBandPoint)); }
BOOL operator==( const ImplRegionBand& rRegionBand ) const;
};
#endif // _SV_REGBAND_HXX
|