| 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: curve.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.15 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.14 2004/11/05 13:58:09 basch 00033 // Class comment changed (Doxygen style) 00034 // 00035 // Revision 1.13 2004/03/12 16:28:38 baumann 00036 // macros VRS_NAMESPACE_BEGIN/_END expanded and removed 00037 // 00038 // Revision 1.12 2003/11/07 14:19:23 kirsch 00039 // removed leading underscore from include guards 00040 // 00041 // Revision 1.11 2003/07/23 17:04:49 baumann 00042 // code cleanup (especially untabified) 00043 // 00044 // Revision 1.10 2003/01/21 21:08:29 skirsch 00045 // moved length calculation to curve 00046 // 00047 // Revision 1.9 2002/07/02 06:12:34 baumann 00048 // VRS::Iterator<T> completely rewritten 00049 // 00050 // Revision 1.8 2002/03/04 11:08:34 kersting 00051 // directory structure changes 00052 // 00053 // Revision 1.7 2002/03/03 21:44:24 kosta 00054 // VRS_TYPEINFO-macro rewritten 00055 // 00056 // Revision 1.6 2002/02/19 10:34:07 kosta 00057 // undone all changes since 2002-02-15 00058 // 00059 // Revision 1.3 2002/01/15 16:25:53 kosta 00060 // macros rewritten for a better namespace support 00061 // 00062 // Revision 1.2 2001/11/13 16:36:30 kirsch 00063 // changed line feed to unix style (removed control-M) 00064 // 00065 // Revision 1.1.1.1 2001/06/08 08:09:20 kirsch 00066 // imported alpha-version by olli 00067 // 00068 00069 00070 #ifndef VRS_CURVE_H 00071 #define VRS_CURVE_H 00072 00073 #include <vrs/container/iterator.h> 00074 #include <vrs/container/array.h> 00075 #include <vrs/shape.h> 00076 00077 namespace VRS { 00078 00083 class VRS_CORE_API Curve : public Shape { 00084 00085 public: 00086 virtual Vector curvePoint(double t) const = 0; 00088 00089 virtual double t2length(double t) const; 00091 00094 virtual double length2t(double length) const; 00096 00101 virtual Vector derivative(int degree, double t) const = 0; 00103 00104 virtual Iterator<Vector>* newIterator(unsigned int resolution) const; 00110 virtual double getLength() const; 00112 00113 virtual void modified(); 00115 00116 VRS_TYPEINFO(Curve, Shape); 00117 00118 protected: 00119 Curve(); 00121 00122 private: 00123 void updateLengthMapping(); 00124 00125 // new method for length mapping 00126 enum {INITIAL_EVAL_POINTS = 11}; 00127 double getCurveLengthSlidingWindow(double min_t, double max_t, int n_eval_pts); 00128 double getSectionLength(double t0, double t1, double t2, const Vector& pt0, const Vector& pt1, const Vector& pt2); 00129 00130 SO<NonPersistentArray<double> > tMapping_; 00131 SO<NonPersistentArray<double> > lengthMapping_; 00132 bool updateLengthMapping_; 00133 }; 00134 00135 } // namespace VRS 00136 00137 #endif // VRS_CURVE_H