Branch data Line data Source code
1 : : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : : /*************************************************************************
3 : : *
4 : : * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 : : *
6 : : * Copyright 2000, 2010 Oracle and/or its affiliates.
7 : : *
8 : : * OpenOffice.org - a multi-platform office productivity suite
9 : : *
10 : : * This file is part of OpenOffice.org.
11 : : *
12 : : * OpenOffice.org is free software: you can redistribute it and/or modify
13 : : * it under the terms of the GNU Lesser General Public License version 3
14 : : * only, as published by the Free Software Foundation.
15 : : *
16 : : * OpenOffice.org is distributed in the hope that it will be useful,
17 : : * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 : : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 : : * GNU Lesser General Public License version 3 for more details
20 : : * (a copy is included in the LICENSE file that accompanied this code).
21 : : *
22 : : * You should have received a copy of the GNU Lesser General Public License
23 : : * version 3 along with OpenOffice.org. If not, see
24 : : * <http://www.openoffice.org/license.html>
25 : : * for a copy of the LGPLv3 License.
26 : : *
27 : : ************************************************************************/
28 : :
29 : : #ifndef _XPOLYIMP_HXX
30 : : #define _XPOLYIMP_HXX
31 : :
32 : : #include <tools/gen.hxx>
33 : : #include <svx/xpoly.hxx>
34 : : #include <vector>
35 : :
36 : : class ImpXPolygon
37 : : {
38 : : public:
39 : : Point* pPointAry;
40 : : sal_uInt8* pFlagAry;
41 : : Point* pOldPointAry;
42 : : sal_Bool bDeleteOldPoints;
43 : : sal_uInt16 nSize;
44 : : sal_uInt16 nResize;
45 : : sal_uInt16 nPoints;
46 : : sal_uInt16 nRefCount;
47 : :
48 : : ImpXPolygon( sal_uInt16 nInitSize = 16, sal_uInt16 nResize=16 );
49 : : ImpXPolygon( const ImpXPolygon& rImpXPoly );
50 : : ~ImpXPolygon();
51 : :
52 : : bool operator==(const ImpXPolygon& rImpXPoly) const;
53 : 0 : bool operator!=(const ImpXPolygon& rImpXPoly) const { return !operator==(rImpXPoly); }
54 : :
55 : 4000 : void CheckPointDelete()
56 : : {
57 [ - + ]: 4000 : if ( bDeleteOldPoints )
58 : : {
59 [ # # ]: 0 : delete[] (char*)pOldPointAry;
60 : 0 : bDeleteOldPoints = sal_False;
61 : : }
62 : 4000 : }
63 : :
64 : : void Resize( sal_uInt16 nNewSize, sal_Bool bDeletePoints = sal_True );
65 : : void InsertSpace( sal_uInt16 nPos, sal_uInt16 nCount );
66 : : void Remove( sal_uInt16 nPos, sal_uInt16 nCount );
67 : : };
68 : :
69 : : typedef ::std::vector< XPolygon* > XPolygonList;
70 : :
71 : : class ImpXPolyPolygon
72 : : {
73 : : public:
74 : : XPolygonList aXPolyList;
75 : : sal_uInt16 nRefCount;
76 : :
77 : 144 : ImpXPolyPolygon() { nRefCount = 1; }
78 : : ImpXPolyPolygon( const ImpXPolyPolygon& rImpXPolyPoly );
79 : : ~ImpXPolyPolygon();
80 : :
81 : : bool operator==(const ImpXPolyPolygon& rImpXPolyPoly) const;
82 : 0 : bool operator!=(const ImpXPolyPolygon& rImpXPolyPoly) const { return !operator==(rImpXPolyPoly); }
83 : : };
84 : :
85 : :
86 : :
87 : : #endif // _XPOLYIMP_HXX
88 : :
89 : : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|