Mondschein Engine  0.3.0
nurbscurve.h
Go to the documentation of this file.
1 #ifndef NURBSCURVE_H_INCLUDED
2 #define NURBSCURVE_H_INCLUDED
3 
4 /* Mondschein Engine is a fast, powerful, and easy-to-use 3D realtime rendering engine.
5  *
6  * Copyright (C) 2009-2013 by Andreas Amereller
7  * E-Mail: andreas.amereller.dev@googlemail.com
8  *
9  * This program is free software; you can redistribute it and/or modify it
10  * under the terms of the GNU General Public License as published by the Free
11  * Software Foundation; either version 3 of the License, or (at your option)
12  * any later version.
13  *
14  * This program is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
16  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
17  * more details.
18  *
19  * You should have received a copy of the GNU General Public License along
20  * with this program; if not, write to the Free Software Foundation, Inc.,
21  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22  */
24 
25 #include "types.h"
26 #include "eigen3.h"
27 
28 #include <cmath>
29 
30 namespace mondschein
31 {
32  namespace math
33  {
41  class NURBScurve
42  {
43  private:
44  uint32 degree;
45  std::vector<Eigen::Vector4d> points;
46  std::vector<float64> knots;
47  virtual void chord_knots();
48  virtual void uniform_knots();
49 
50  public:
51  explicit NURBScurve();
52  explicit NURBScurve(uint32 _d,const std::vector<Eigen::Vector4d> &_p);
53  explicit NURBScurve(NURBScurve_c _c);
54  virtual ~NURBScurve();
55  virtual NURBScurve &operator=(NURBScurve_c _c);
56 
71  virtual Eigen::Vector3d operator()(float64 _t) const;
72 
83  virtual void set_degree(uint32 _d);
84 
90  virtual uint32 get_degree() const;
91 
102  virtual void set_points(const std::vector<Eigen::Vector4d> &_p);
103 
109  virtual std::vector<Eigen::Vector4d> get_points() const;
110 
121  virtual void calc_knots(bool _cl);
122 
136  virtual Eigen::Vector3d get_point(float64 _t) const;
137  };
138  }
139 }
140 
141 #endif // NURBSCURVE_H_INCLUDED