You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
koffice/kpresenter/KPrPolygonObject.h

88 lines
3.3 KiB

/* This file is part of the KDE project
Copyright (C) 2001 Toshitaka Fujioka <fujioka@kde.org>
Copyright (C) 2005 Thorsten Zachmann <zachmann@kde.org>
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 kppolygonobject_h
#define kppolygonobject_h
#include <tqpointarray.h>
#include "KoPointArray.h"
#include "KPrObject.h"
class KPrGradient;
class TQPainter;
class DCOPObject;
class KoPen;
class KPrPolygonObject : public KPr2DObject
{
public:
KPrPolygonObject();
KPrPolygonObject( const KoPointArray &_points, const KoSize &_size, const KoPen &_pen, const TQBrush &_brush,
FillType _fillType, const TQColor &_gColor1, const TQColor &_gColor2, BCType _gType,
bool _unbalanced, int _xfactor, int _yfactor,
bool _checkConcavePolygon, int _cornersValue, int _sharpnessValue );
virtual ~KPrPolygonObject() {}
virtual DCOPObject* dcopObject();
KPrPolygonObject &operator=( const KPrPolygonObject & );
virtual void setSize( double _width, double _height );
virtual void setSize( const KoSize & _size )
{ setSize( _size.width(), _size.height() ); }
virtual ObjType getType() const { return OT_POLYGON; }
virtual TQString getTypeString() const { return i18n( "Polygon" ); }
void setCheckConcavePolygon(bool _concavePolygon) { checkConcavePolygon = _concavePolygon; drawPolygon(); }
void setCornersValue(int _cornersValue) { cornersValue = _cornersValue; drawPolygon(); }
void setSharpnessValue(int _sharpnessValue) { sharpnessValue = _sharpnessValue; drawPolygon(); }
bool getCheckConcavePolygon() const { return checkConcavePolygon; }
int getCornersValue() const { return cornersValue; }
int getSharpnessValue() const { return sharpnessValue; }
virtual TQDomDocumentFragment save( TQDomDocument& doc, double offset );
virtual double load( const TQDomElement &element );
virtual void loadOasis( const TQDomElement &element, KoOasisContext & context, KPrLoadingInfo *info );
virtual void flip( bool horizontal );
virtual KoSize getRealSize() const;
virtual KoPoint getRealOrig() const;
protected:
virtual const char * getOasisElementName() const;
virtual bool saveOasisObjectAttributes( KPOasisSaveContext &sc ) const;
virtual void paint( TQPainter *_painter,KoTextZoomHandler*_zoomHandler,
int /* pageNum */, bool drawingShadow, bool drawContour );
void updatePoints( double _fx, double _fy );
void drawPolygon();
KoPointArray points;
bool checkConcavePolygon;
int cornersValue;
int sharpnessValue;
};
#endif