// Copyright (C) 2009 Petr Gajdos and // Maurizio Paolini // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License // as published by the Free Software Foundation; either version 2 // of the License, or (at your option) any later version. // This program 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 General Public License for more details. // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA // 02110-1301, USA. #ifndef KIG_OBJECTS_BEZIER_IMP_H #define KIG_OBJECTS_BEZIER_IMP_H #include "curve_imp.h" #include "object_imp.h" #include "../misc/coordinate.h" #include /** * An ObjectImp representing polynomial Bézier Curve. */ class BezierImp : public CurveImp { uint mnpoints; std::vector mpoints; Coordinate mcenterofmass; Coordinate deCasteljau( unsigned int m, unsigned int k, double p ) const; public: typedef CurveImp Parent; /** * Returns the ObjectImpType representing the BezierImp type. */ static const ObjectImpType* stype(); static const ObjectImpType* stype2(); static const ObjectImpType* stype3(); /** * Constructs a Bézier curve. */ BezierImp( const std::vector& points ); ~BezierImp(); BezierImp* copy() const; Coordinate attachPoint() const; ObjectImp* transform( const Transformation& ) const; void draw( KigPainter& p ) const; bool contains( const Coordinate& p, int width, const KigWidget& ) const; bool inRect( const Rect& r, int width, const KigWidget& ) const; bool valid() const; Rect surroundingRect() const; const Coordinate getPoint( double param, const KigDocument& ) const; bool containsPoint( const Coordinate& p, const KigDocument& doc ) const; bool internalContainsPoint( const Coordinate& p, double threshold, const KigDocument& doc ) const; int numberOfProperties() const; const QByteArrayList properties() const; const QByteArrayList propertiesInternalNames() const; ObjectImp* property( int which, const KigDocument& w ) const; const char* iconForProperty( int which ) const; const ObjectImpType* impRequirementForProperty( int which ) const; bool isPropertyDefinedOnOrThroughThisImp( int which ) const; const ObjectImpType* type() const; void visit( ObjectImpVisitor* vtor ) const; /** * Returns the vector with control points. */ const std::vector points() const; /** * Returns the center of mass of the control polygon. */ const Coordinate centerOfMass() const; /** * Returns the number of control points. */ uint npoints() const; bool equals( const ObjectImp& rhs ) const; }; /** * An ObjectImp representing a rational Bézier curve. */ class RationalBezierImp : public CurveImp { uint mnpoints; std::vector mpoints; std::vector mweights; Coordinate mcenterofmass; Coordinate deCasteljauPoints( unsigned int m, unsigned int k, double p ) const; double deCasteljauWeights( unsigned int m, unsigned int k, double p ) const; public: typedef CurveImp Parent; /** * Returns the ObjectImpType representing the RationalBezierImp type. */ static const ObjectImpType* stype(); static const ObjectImpType* stype2(); static const ObjectImpType* stype3(); /** * Constructs a rational Bézier curve. */ RationalBezierImp( const std::vector& points, const std::vector& weights ); ~RationalBezierImp(); RationalBezierImp* copy() const; Coordinate attachPoint() const; ObjectImp* transform( const Transformation& ) const; void draw( KigPainter& p ) const; bool contains( const Coordinate& p, int width, const KigWidget& ) const; bool inRect( const Rect& r, int width, const KigWidget& ) const; bool valid() const; Rect surroundingRect() const; const Coordinate getPoint( double param, const KigDocument& ) const; bool containsPoint( const Coordinate& p, const KigDocument& doc ) const; bool internalContainsPoint( const Coordinate& p, double threshold, const KigDocument& doc ) const; int numberOfProperties() const; const QByteArrayList properties() const; const QByteArrayList propertiesInternalNames() const; ObjectImp* property( int which, const KigDocument& w ) const; const char* iconForProperty( int which ) const; const ObjectImpType* impRequirementForProperty( int which ) const; bool isPropertyDefinedOnOrThroughThisImp( int which ) const; const ObjectImpType* type() const; void visit( ObjectImpVisitor* vtor ) const; /** * Returns the vector with control points. */ const std::vector points() const; /** * Returns the center of mass of the control polygon. */ const Coordinate centerOfMass() const; /** * Returns the number of control points. */ uint npoints() const; bool equals( const ObjectImp& rhs ) const; }; #endif