/**************************************************************************** Copyright (C) 2010-2012 the Office National des Forêts (ONF), France and the Association de Recherche Technologie et Sciences (ARTS), Ecole Nationale Suprieure d'Arts et Métiers (ENSAM), Cluny, France. All rights reserved. Contact : alexandre.piboule@onf.fr Developers : Michal KREBS (ARTS/ENSAM) This file is part of PluginShared library 2.0. PluginShared is free library: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. PluginShared 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 Lesser General Public License along with PluginShared. If not, see . *****************************************************************************/ #ifndef CT_PLANARBSPLINE_H #define CT_PLANARBSPLINE_H #include "ct_itemdrawable/abstract/ct_abstractshape.h" #include "ct_itemdrawable/tools/drawmanager/ct_standardplanarbsplinedrawmanager.h" #include "ct_shapedata/ct_planarbsplinedata.h" /*! * \class CT_PlanarBSpline * \ingroup PluginShared_Items * \brief ItemDrawable managing a CT_PlanarBSplineData * * It represents a planar B-Spline in 3D. * */ class PLUGINSHAREDSHARED_EXPORT CT_PlanarBSpline : public CT_AbstractShape { Q_OBJECT CT_TYPE_IMPL_MACRO(CT_PlanarBSpline, CT_AbstractShape, Planar B-spline) public: CT_PlanarBSpline(); /** * \brief Contructeur avec une instance des donnes (CT_PlanarBSplineData*), ne peut tre NULL ! (Supprime dans le destructeur de la classe). */ CT_PlanarBSpline(const CT_OutAbstractSingularItemModel *model, const CT_AbstractResult *result, CT_PlanarBSplineData *data); CT_PlanarBSpline(const QString &modelName, const CT_AbstractResult *result, CT_PlanarBSplineData *data); int getDegree() const; int getNCP() const; void setPolyline(const QList &list); const QList &getPolyline() const; virtual CT_AbstractItemDrawable* copy(const CT_OutAbstractItemModel *model, const CT_AbstractResult *result, CT_ResultCopyModeList copyModeList); private: QList _polyline; CT_DEFAULT_IA_BEGIN(CT_PlanarBSpline) CT_DEFAULT_IA_V3(CT_PlanarBSpline, CT_AbstractCategory::staticInitDataNumber(), &CT_PlanarBSpline::getDegree, QObject::tr("Degré de polynome"), "dp") CT_DEFAULT_IA_V3(CT_PlanarBSpline, CT_AbstractCategory::staticInitDataNumber(), &CT_PlanarBSpline::getNCP, QObject::tr("Nombre de points de contrôle"), "npc") CT_DEFAULT_IA_END(CT_PlanarBSpline) const static CT_StandardPlanarBSplineDrawManager PLANARBSPLINE_DRAW_MANAGER; }; #endif // CT_PLANARBSPLINE_H