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
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#ifndef _SV_REGION_H
#define _SV_REGION_H
#include <vcl/regband.hxx>
#include <tools/poly.hxx>
#include <vcl/region.hxx>
// -----------------
// - Hilfsmethoden -
// -----------------
#ifdef DBG_UTIL
const char* ImplDbgTestRegion( const void* pObj );
#endif
// --------------------
// - ImplRegionHandle -
// --------------------
struct ImplRegionHandle
{
Region* mpRegion;
ImplRegionBand* mpCurrRectBand;
ImplRegionBandSep* mpCurrRectBandSep;
sal_Bool mbFirst;
};
// ------------------
// - ImplRegionInfo -
// ------------------
struct ImplRegionInfo
{
void* mpVoidCurrRectBand;
void* mpVoidCurrRectBandSep;
};
// --------------
// - ImplRegion -
// --------------
struct ImplRegionBase
{
public:
ImplRegionBase( int nCount = 1 ); // TODO: replace manual refcounting
virtual ~ImplRegionBase();
public:
sal_uIntPtr mnRefCount;
sal_uIntPtr mnRectCount;
PolyPolygon* mpPolyPoly;
basegfx::B2DPolyPolygon* mpB2DPolyPoly;
};
class ImplRegion : public ImplRegionBase
{
friend class Region;
private:
ImplRegionBand* mpFirstBand; // root of the list with y-bands
ImplRegionBand* mpLastCheckedBand;
public:
ImplRegion();
ImplRegion( const PolyPolygon& rPolyPoly );
ImplRegion( const basegfx::B2DPolyPolygon& );
ImplRegion( const ImplRegion& rImplRegion );
~ImplRegion();
ImplRegionBand* ImplGetFirstRegionBand() const { return mpFirstBand; }
PolyPolygon* ImplGetPolyPoly() const { return mpPolyPoly; }
void CreateBandRange( long nYTop, long nYBottom );
void InsertBands( long nYTop, long nYBottom );
sal_Bool InsertSingleBand( ImplRegionBand* mpImplRegionBand,
long nYBandPosition );
sal_Bool InsertLine( const Point & rFirstPoint,
const Point & rSecondPoint,
long nLineID );
sal_Bool InsertPoint( const Point &rPoint,
long nLineID,
sal_Bool bEndPoint, LineType eLineType );
/** Insert one band either after another band or as the first or only
band. Both the forward as well as the backward links are updated.
@param pPreviousBand
When <NULL/> then pBandToInsert is inserted as first band or as
only band when there are no other bands.
When not <NULL/> then pBandToInsert is inserted directly after
pPreviousBand.
@param pBandToInsert
The band to insert.
*/
void InsertBand (ImplRegionBand* pPreviousBand,
ImplRegionBand* pBandToInsert);
void Union( long nLeft, long nTop, long nRight, long nBottom );
void Exclude( long nLeft, long nTop, long nRight, long nBottom );
void XOr( long nLeft, long nTop, long nRight, long nBottom );
// remove emtpy rects
sal_Bool OptimizeBandList();
friend SvStream& operator>>( SvStream& rIStm, Region& rRegion );
friend SvStream& operator<<( SvStream& rOStm, const Region& rRegion );
};
#endif // _SV_REGION_H
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|