#include <nurbsS_sp.h>
Inheritance diagram for PLib::NurbsSurfaceSP< T, N >:

Public Member Functions | |
| NurbsSurfaceSP (const NurbsSurface< T, N > &nS) | |
| NurbsSurfaceSP (const NurbsSurfaceSP< T, N > &nS) | |
| NurbsSurfaceSP (int DegU, int DegV, const Vector< T > &Uk, const Vector< T > &Vk, const Matrix< HPoint_nD< T, N > > &Cp) | |
| NurbsSurfaceSP (int DegU, int DegV, Vector< T > &Uk, Vector< T > &Vk, Matrix< Point_nD< T, N > > &Cp, Matrix< T > &W) | |
| virtual NurbsSurface< T, N > & | operator= (const NurbsSurface< T, N > &a) |
|
virtual NurbsSurfaceSP< T, N > & | operator= (const NurbsSurfaceSP< T, N > &a) |
| virtual void | resizeKeep (int Pu, int Pv, int DegU, int DegV) |
| virtual void | refineKnots (const Vector< T > &nU, const Vector< T > &nV) |
| virtual void | refineKnotU (const Vector< T > &X) |
| virtual void | refineKnotV (const Vector< T > &X) |
| virtual void | mergeKnots (const Vector< T > &nU, const Vector< T > &nV) |
| virtual void | mergeKnotU (const Vector< T > &X) |
| virtual void | mergeKnotV (const Vector< T > &X) |
| virtual int | read (ifstream &fin) |
| virtual void | degreeElevateU (int tU) |
| virtual void | degreeElevateV (int tV) |
| NurbsSurfaceSP< T, N > | generateParallel (T d) const |
| void | modSurfCPby (int i, int j, const HPoint_nD< T, N > &a) |
| void | modSurfCP (int i, int j, const HPoint_nD< T, N > &a) |
| void | modOnlySurfCPby (int i, int j, const HPoint_nD< T, N > &a) |
| void | modOnlySurfCP (int i, int j, const HPoint_nD< T, N > &a) |
| T | maxAtUV (int i, int j) const |
| T | maxAtU (int i) const |
| T | maxAtV (int i) const |
| HPoint_nD< T, N > | surfP (int i, int j) const |
| void | updateMaxUV () |
| void | updateMaxU () |
| void | updateMaxV () |
| int | okMax () |
Protected Attributes | |
| Vector< T > | maxU |
| Vector< T > | maxV |
| Vector< T > | maxAtU_ |
| Vector< T > | maxAtV_ |
A Nurbs surface with surface point manipulators. This allows someone to modify the point on a surface for which a control point has maximal influence over it. This might provide a more intuitive method to modify a surface.
|
||||||||||
|
Degree elevate the surface in the U direction.
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||
|
Degree elevate the surface in the V direction.
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||
|
Generate a parallel surface. Generates an offset surface from this surface. An offset surface is a surface wich has its surface parallel to an other one. There is a distance of d between the two parallel surfaces. The algorithm used is very naive. It generates a surface such that a point s_2(u,v) = s(u,v) + d n(u,v) where s_2(u,v,) is the point on the parallel surface at (u,v) , s(u,v) is the point on the original surface at (u,v), d is the offset between the two and n(u,v) is the normal on the surface at the point (u,v).
|
|
||||||||||
|
< Where is the maximal basis function in U for the control points in row i
|
|
||||||||||||||||
|
< The maximal basis function for the control point i,j
|
|
||||||||||
|
< Where is the maximal basis function in U for the control points in colum i
|
|
||||||||||||||||
|
merges a U and V knot vector with the surface knot vectors
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||
|
merges the U knot vector with another one
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||
|
merges the V knot vector with another one
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||||||||||||
|
|
|
||||||||||||||||||||
|
Move the surface point only. Moves only the specified surface point. The other surface points normally affected by moving this point are {not} moved. The point a is in the 4D homogenous space, but only the x,y,z value are used. The weight is not moved by this function.
|
|
||||||||||||||||||||
|
|
|
||||||||||||||||||||
|
|
|
||||||||||
|
NurbsSurface<T,N> assignment.
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||
|
Read a surface from an input stream.
Reimplemented from PLib::NurbsSurface< T, N >. Reimplemented in PLib::NurbsSurfaceGL. |
|
||||||||||||||||
|
Refine both knot vectors.
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||
|
Refines the U knot vector.
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||
|
Refines the V knot vector.
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||||||||||||||||
|
Resize the surface while keeping the old values.
Reimplemented from PLib::NurbsSurface< T, N >. |
|
||||||||||||||||
|
< the surface point for the control point at i,j
|
|
|||||||||
|
Updates the basis value for the U direction. Updates the basis value at which a control point has maximal influence. It also finds where the control point has maximal influence.
|
|
|||||||||
|
Updates the basis value for the V direction. Updates the basis value at which a control point has maximal influence. It also finds where the control point has maximal influence.
|
|
|||||
|
The vector identifiying where is the maximal basis function in U.
|
|
|||||
|
The vector identifiying where is the maximal basis function in V.
|
|
|||||
|
The vector of maximal basis function value in U.
|
|
|||||
|
The vector of maximal basis function value in V.
|
1.3.4