2003-03-27 10:05:12 -06:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2005-09-09 07:49:39 -05:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
2005-09-09 07:49:39 -05:00
|
|
|
* $RCSfile: poly.h,v $
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
2007-06-27 16:08:40 -05:00
|
|
|
* $Revision: 1.5 $
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
2007-06-27 16:08:40 -05:00
|
|
|
* last change: $Author: hr $ $Date: 2007-06-27 22:08:40 $
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
2005-09-09 07:49:39 -05:00
|
|
|
* The Contents of this file are made available subject to
|
|
|
|
* the terms of GNU Lesser General Public License Version 2.1.
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
|
|
|
*
|
2005-09-09 07:49:39 -05:00
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2005 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
2005-09-09 07:49:39 -05:00
|
|
|
* 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.
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
2005-09-09 07:49:39 -05:00
|
|
|
* 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.
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
2005-09-09 07:49:39 -05:00
|
|
|
* 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
|
2003-03-27 10:05:12 -06:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _POLY_H
|
|
|
|
#define _POLY_H
|
|
|
|
|
|
|
|
#ifndef _GEN_HXX
|
2007-06-27 16:08:40 -05:00
|
|
|
#include <tools/gen.hxx>
|
2003-03-27 10:05:12 -06:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define MAX_64KPOINTS ((((USHORT)0xFFFF)-32)/sizeof(Point))
|
|
|
|
|
|
|
|
// -------------------
|
|
|
|
// - ImplPolygonData -
|
|
|
|
// -------------------
|
|
|
|
|
|
|
|
class ImplPolygonData
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
#ifdef WIN
|
|
|
|
Point huge* mpPointAry;
|
|
|
|
BYTE* mpFlagAry;
|
|
|
|
GLOBALHANDLE mhPoints;
|
|
|
|
#else
|
|
|
|
Point* mpPointAry;
|
|
|
|
BYTE* mpFlagAry;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
USHORT mnPoints;
|
2006-07-13 03:58:14 -05:00
|
|
|
ULONG mnRefCount;
|
2003-03-27 10:05:12 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
// ---------------
|
|
|
|
// - ImplPolygon -
|
|
|
|
// ---------------
|
|
|
|
|
|
|
|
class ImplPolygon : public ImplPolygonData
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ImplPolygon( USHORT nInitSize, BOOL bFlags = FALSE );
|
|
|
|
ImplPolygon( USHORT nPoints, const Point* pPtAry, const BYTE* pInitFlags = NULL );
|
|
|
|
ImplPolygon( const ImplPolygon& rImplPoly );
|
|
|
|
~ImplPolygon();
|
|
|
|
|
|
|
|
void ImplSetSize( USHORT nSize, BOOL bResize = TRUE );
|
|
|
|
void ImplCreateFlagArray();
|
|
|
|
void ImplSplit( USHORT nPos, USHORT nSpace, ImplPolygon* pInitPoly = NULL );
|
|
|
|
void ImplRemove( USHORT nPos, USHORT nCount );
|
|
|
|
};
|
|
|
|
|
|
|
|
// -------------------
|
|
|
|
// - ImplPolyPolygon -
|
|
|
|
// -------------------
|
|
|
|
|
|
|
|
#define MAX_POLYGONS ((USHORT)0x3FF0)
|
|
|
|
|
|
|
|
class Polygon;
|
|
|
|
typedef Polygon* SVPPOLYGON;
|
|
|
|
|
|
|
|
class ImplPolyPolygon
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
SVPPOLYGON* mpPolyAry;
|
2006-07-13 03:58:14 -05:00
|
|
|
ULONG mnRefCount;
|
2003-03-27 10:05:12 -06:00
|
|
|
USHORT mnCount;
|
|
|
|
USHORT mnSize;
|
|
|
|
USHORT mnResize;
|
|
|
|
|
|
|
|
ImplPolyPolygon( USHORT nInitSize, USHORT nResize )
|
|
|
|
{ mpPolyAry = NULL; mnCount = 0; mnRefCount = 1;
|
|
|
|
mnSize = nInitSize; mnResize = nResize; }
|
|
|
|
ImplPolyPolygon( USHORT nInitSize );
|
|
|
|
ImplPolyPolygon( const ImplPolyPolygon& rImplPolyPoly );
|
|
|
|
~ImplPolyPolygon();
|
|
|
|
};
|
|
|
|
|
|
|
|
inline long MinMax( long nVal, long nMin, long nMax )
|
|
|
|
{
|
|
|
|
return( nVal >= nMin ? ( nVal <= nMax ? nVal : nMax ) : nMin );
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------
|
|
|
|
|
|
|
|
inline long FRound( double fVal )
|
|
|
|
{
|
|
|
|
return( fVal > 0.0 ? (long) ( fVal + 0.5 ) : -(long) ( -fVal + 0.5 ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _SV_POLY_H
|