| VRS - The Virtual Rendering System |
| version 3.3 |
00001 /********************************************************************** 00002 VRS - The Virtual Rendering System 00003 Copyright (C) 2001 Computer Graphics Systems Group at the 00004 Hasso-Plattner-Institute, Potsdam, Germany. 00005 This library is free software; you can redistribute it and/or 00006 modify it under the terms of the GNU Lesser General Public 00007 License as published by the Free Software Foundation; either 00008 version 2.1 of the License, or (at your option) any later version. 00009 This library is distributed in the hope that it will be useful, but 00010 WITHOUT ANY WARRANTY; without even the implied warranty of 00011 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 00012 See the GNU Lesser General Public License for more details. 00013 You should have received a copy of the GNU Lesser+ General Public 00014 License along with this library; if not, write to the FreeSoftware 00015 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA, 02111-1307, USA. 00016 **********************************************************************/ 00017 // $Id: bspline.h 4633 2005-01-03 01:43:11Z klimetschek $ 00018 // $Date: 2005-01-03 02:43:11 +0100 (Mon, 03 Jan 2005) $ 00019 // $Revision: 4633 $ 00020 // $State$ 00021 // $Author: klimetschek $ 00022 // 00023 // $Log$ 00024 // Revision 1.19 2005/01/03 01:43:07 klimetschek 00025 // - modified win32 project layout, splitted vrs.vcproj into vrs_container, vrs_core, vrs_sg, vrs_image, vrs_opengl and vrs_io 00026 // - removed vrs.vcproj 00027 // minor things: 00028 // - added all glutexamples to vrs4glut.sln 00029 // - fixed some problems in glutexamples 00030 // - removed all project references from all VS projects (using solution wide project dependencies instead) 00031 // 00032 // Revision 1.18 2004/11/05 13:58:09 basch 00033 // Class comment changed (Doxygen style) 00034 // 00035 // Revision 1.17 2004/03/12 16:28:38 baumann 00036 // macros VRS_NAMESPACE_BEGIN/_END expanded and removed 00037 // 00038 // Revision 1.16 2004/01/29 13:42:24 wendland 00039 // set default value for curveDegree to 1 00040 // 00041 // Revision 1.15 2004/01/19 11:43:56 baumann 00042 // serialization mechanism improved 00043 // 00044 // Revision 1.14 2004/01/19 07:28:03 baumann 00045 // serialization mechanism improved 00046 // 00047 // Revision 1.13 2003/11/07 14:19:23 kirsch 00048 // removed leading underscore from include guards 00049 // 00050 // Revision 1.12 2003/01/16 22:21:58 skirsch 00051 // comment improvements 00052 // 00053 // Revision 1.11 2002/10/29 10:32:51 baumann 00054 // macros VRS_CLASSNAME_* and VRS_IMPL_TYPEINFO_* removed 00055 // 00056 // Revision 1.10 2002/03/04 11:08:34 kersting 00057 // directory structure changes 00058 // 00059 // Revision 1.9 2002/03/03 21:44:24 kosta 00060 // VRS_TYPEINFO-macro rewritten 00061 // 00062 // Revision 1.8 2002/02/19 10:34:07 kosta 00063 // undone all changes since 2002-02-15 00064 // 00065 // Revision 1.5 2002/02/05 07:48:24 kosta 00066 // new persistency macros: 00067 // VRS_SERIALIZABLE(CLASS_NAME); 00068 // VRS_SERIALIZABLE_ABSTRACT_CLASS(CLASS_NAME); 00069 // VRS_SERIALIZABLE_NO_SO_CLASS(CLASS_NAME) 00070 // 00071 // Revision 1.4 2002/02/04 13:07:19 kosta 00072 // VRS_SERIALIZABLE macros completely rewritten 00073 // 00074 // Revision 1.3 2002/01/15 16:25:53 kosta 00075 // macros rewritten for a better namespace support 00076 // 00077 // Revision 1.2 2001/11/13 16:36:30 kirsch 00078 // changed line feed to unix style (removed control-M) 00079 // 00080 // Revision 1.1.1.1 2001/06/08 08:09:20 kirsch 00081 // imported alpha-version by olli 00082 // 00083 00084 #ifndef VRS_BSPLINE_H 00085 #define VRS_BSPLINE_H 00086 00087 #include <vrs/container/array.h> 00088 #include <vrs/curve.h> 00089 00090 namespace VRS { 00091 00103 class VRS_CORE_API BSpline : public Curve { 00104 00105 public: 00106 BSpline(int curveDegree = 1, bool openCurve = true, Array<Vector>* controlPoints = 0, 00107 Array<int>* knotArray = 0); 00109 00110 void setControlPoint(int i, const Vector & p); 00112 Vector getControlPoint(int i) const; 00114 int controlPoints() const; 00116 Iterator<Vector>* newControlPointIterator() const; 00118 00119 void setKnot(int i, int value); 00121 int getKnot(int i) const; 00123 int knots() const; 00125 Iterator < int > * newKnotIterator() const; 00127 00128 void insertKnots(int noNewKnots, int knotValue); 00130 bool knotsConsistent() const; 00132 00141 void setOpenCurve(); 00143 void setClosedCurve(); 00145 bool isOpen() const; 00147 00148 void setCachingOn(int tessellation); 00150 00155 void setCachingOff(); 00157 bool isCached() const; 00159 00160 void reconfigure(int newDegree, int newNoOfPoints); 00166 virtual Vector curvePoint(double u) const; 00168 00172 virtual Vector derivative(int n, double u) const; 00174 00175 virtual Bounds boundingBox() const; 00177 00178 virtual void modified(); 00179 00180 VRS_TYPEINFO(BSpline, Curve); 00181 VRS_SERIALIZABLE(BSpline); 00182 00183 private: 00184 SO < Array < Vector > > pts_; 00185 SO < Array < int > > knots_; 00186 int noOfPts_; 00187 int noOfKnots_; 00188 int degree_; 00189 bool open_; 00190 00191 std::vector<Vector> cachedValues_; 00192 int cacheSteps_; 00193 bool caching_; 00194 00195 void cacheValues(); 00196 Vector computeValue(double position) const; 00197 00198 bool modified_; 00199 }; 00200 00201 } // namespace VRS 00202 00203 #endif // VRS_BSPLINE_H