C3D Kernel  104065
Открытые члены | Защищенные члены | Защищенные данные
Класс MbSurface

Поверхность в трехмерном пространстве. Подробнее...

Граф наследования:MbSurface:
Inheritance graph
[см. легенду]
Граф связей класса MbSurface:
Collaboration graph
[см. легенду]

Полный список членов класса

Открытые члены

virtual ~MbSurface ()
 Деструктор.
 VISITING_CLASS (MbSurface)
 Реализация функции, инициирующей посещение объекта.
virtual MbeSpaceType IsA () const =0
 Получить тип объекта.
virtual MbeSpaceType Type () const
 Получить групповой тип объекта.
virtual MbeSpaceType Family () const
 Получить семейство объекта.
virtual MbSpaceItemDuplicate (MbRegDuplicate *=NULL) const =0
 Создать копию объекта.
virtual bool IsSame (const MbSpaceItem &other, double accuracy=LENGTH_EPSILON) const =0
 Определить, являются ли объекты равными.
virtual bool SetEqual (const MbSpaceItem &)=0
 Сделать объекты равным, если они подобны.
virtual void Transform (const MbMatrix3D &, MbRegTransform *=NULL)=0
 Преобразовать объект согласно матрице.
virtual void Move (const MbVector3D &, MbRegTransform *=NULL)=0
 Сдвинуть объект вдоль вектора.
virtual void Rotate (const MbAxis3D &, double angle, MbRegTransform *=NULL)=0
 Повернуть объект вокруг оси на заданный угол.
virtual double DistanceToPoint (const MbCartPoint3D &) const
 Определить расстояние до точки.
virtual void AddYourGabaritTo (MbCube &c) const
 Расширить присланный габаритный куб так, чтобы он включал в себя данный объект.
virtual void Refresh ()
 Перевести все временные (mutable) данные объекта в неопределённое (исходное) состояние.
virtual void PrepareIntegralData (const bool forced) const
 Рассчитать временные (mutable) данные объекта.
virtual void CalculateWire (const MbStepData &stepData, MbMesh &mesh) const
 Создать полигональную копию.
virtual MbPropertyCreateProperty (MbePrompt name) const
 Создать собственное свойство с заданием его имени.
virtual void GetProperties (MbProperties &properties)=0
 Выдать свойства объекта.
virtual void SetProperties (const MbProperties &properties)=0
 Изменить свойства объекта.
virtual void GetBasisPoints (MbControlData3D &) const
 Выдать контрольные точки объекта.
virtual void SetBasisPoints (const MbControlData3D &)
 Изменить объект по контрольным точкам.
Функции описания области определения поверхности.
virtual double GetUMin () const =0
 Вернуть минимальное значение параметра u.
virtual double GetVMin () const =0
 Вернуть минимальное значение параметра v.
virtual double GetUMax () const =0
 Вернуть максимальное значение параметра u.
virtual double GetVMax () const =0
 Вернуть максимальное значение параметра v.
virtual bool IsUClosed () const =0
 Определить, замкнута ли поверхность по параметру u.
virtual bool IsVClosed () const =0
 Определить, замкнута ли поверхность по параметру v.
virtual bool IsUTouch () const
virtual bool IsVTouch () const
virtual bool IsUPeriodic () const
 Определить, замкнута ли поверхность по параметру u.
virtual bool IsVPeriodic () const
 Определить, замкнута ли поверхность по параметру v.
virtual double GetUPeriod () const
 Вернуть период для гладко замкнутой поверхности или 0.
virtual double GetVPeriod () const
 Вернуть период для гладко замкнутой поверхности или 0.
virtual double GetPeriod (ptrdiff_t i) const
 Вернуть период.
virtual size_t Periodicity () const
 Определить периодичность.
virtual bool GetPoleUMin () const
 Существует ли полюс на границе параметрической области.
virtual bool GetPoleUMax () const
 Существует ли полюс на границе параметрической области.
virtual bool GetPoleVMin () const
 Существует ли полюс на границе параметрической области.
virtual bool GetPoleVMax () const
 Существует ли полюс на границе параметрической области.
virtual bool IsPole (double u, double v) const
 Является ли точка полюсом.
bool IsPole (const MbCartPoint &uv) const
 Является ли точка полюсом.
Функции для работы в области определения поверхности

Функции PointOn, Derive... поверхностей корректируют параметры при выходе их за пределы прямоугольной области определения параметров.
Исключения составляют:
1. MbPlane (плоскость)
Функции PointOn, Derive... плоскости не корректируют параметры при выходе их за пределы прямоугольной области определения параметров.
2. MbSmoothSurface и её наследники (поверхности скругления или фаски)
Функции PointOn и Derive... поверхностей сопряжения не корректируют первый параметр при его выходе за пределы определения параметров.

virtual void PointOn (double &u, double &v, MbCartPoint3D &p) const =0
 Вычислить точку на поверхности.
virtual void DeriveU (double &u, double &v, MbVector3D &) const =0
 Вычислить первую производную по u.
virtual void DeriveV (double &u, double &v, MbVector3D &) const =0
 Вычислить первую производную по v.
virtual void DeriveUU (double &u, double &v, MbVector3D &) const =0
 Вычислить вторую производную по u.
virtual void DeriveVV (double &u, double &v, MbVector3D &) const =0
 Вычислить вторую производную по v.
virtual void DeriveUV (double &u, double &v, MbVector3D &) const =0
 Вычислить вторую производную.
virtual void DeriveUUU (double &u, double &v, MbVector3D &) const =0
 Вычислить третью производную.
virtual void DeriveUUV (double &u, double &v, MbVector3D &) const =0
 Вычислить третью производную.
virtual void DeriveUVV (double &u, double &v, MbVector3D &) const =0
 Вычислить третью производную.
virtual void DeriveVVV (double &u, double &v, MbVector3D &) const =0
 Вычислить третью производную.
virtual void TangentU (double &u, double &v, MbVector3D &) const
 Вычислить касательный вектор по u.
virtual void TangentV (double &u, double &v, MbVector3D &) const
 Вычислить касательный вектор по v.
virtual void Normal (double &u, double &v, MbVector3D &) const
 Вычислить нормаль.
virtual void NormalU (double &u, double &v, MbVector3D &) const
 Вычислить производную нормали по U.
virtual void NormalV (double &u, double &v, MbVector3D &) const
 Вычислить производную нормали по V.
Функции для работы внутри и вне области определения поверхности

функции _PointOn, _Derive... поверхностей не корректируют параметры при выходе их за пределы прямоугольной области определения параметров.

virtual void _PointOn (double u, double v, MbCartPoint3D &p) const
 Вычислить точку на поверхности.
virtual void _DeriveU (double u, double v, MbVector3D &) const
 Вычислить первую производную по u на расширенной поверхности.
virtual void _DeriveV (double u, double v, MbVector3D &) const
 Вычислить первую производную по v на расширенной поверхности.
virtual void _DeriveUU (double u, double v, MbVector3D &) const
 Вычислить вторую производную по u на расширенной поверхности.
virtual void _DeriveVV (double u, double v, MbVector3D &) const
 Вычислить вторую производную по v на расширенной поверхности.
virtual void _DeriveUV (double u, double v, MbVector3D &) const
 Вычислить вторую производную на расширенной поверхности.
virtual void _DeriveUUU (double u, double v, MbVector3D &) const
 Вычислить третью производную на расширенной поверхности.
virtual void _DeriveUUV (double u, double v, MbVector3D &) const
 Вычислить третью производную на расширенной поверхности.
virtual void _DeriveUVV (double u, double v, MbVector3D &) const
 Вычислить третью производную на расширенной поверхности.
virtual void _DeriveVVV (double u, double v, MbVector3D &) const
 Вычислить третью производную на расширенной поверхности.
virtual void _TangentU (double u, double v, MbVector3D &) const
 Вычислить касательный вектор по u на расширенной поверхности.
virtual void _TangentV (double u, double v, MbVector3D &) const
 Вычислить касательный вектор по v на расширенной поверхности.
virtual void _Normal (double u, double v, MbVector3D &) const
 Вычислить нормаль на расширенной поверхности.
virtual void _NormalU (double u, double v, MbVector3D &) const
 Вычислить производную нормали на расширенной поверхности.
virtual void _NormalV (double u, double v, MbVector3D &) const
 Вычислить производную нормали на расширенной поверхности.
virtual void _NormalUU (double u, double v, MbVector3D &) const
 Вычислить вторую производную нормали на расширенной поверхности.
virtual void _NormalUV (double u, double v, MbVector3D &) const
 Вычислить вторую производную нормали на расширенной поверхности.
virtual void _NormalVV (double u, double v, MbVector3D &) const
 Вычислить вторую производную нормали на расширенной поверхности.
virtual void _NormalD (double u, double v, double du, double dv, MbVector3D &der) const
 Вычислить производную нормали в точке с параметрами u v вдоль линии du dv.
virtual void Explore (double &u, double &v, bool ext, MbCartPoint3D &pnt, MbVector3D &uDer, MbVector3D &vDer, MbVector3D *uuDer, MbVector3D *vvDer, MbVector3D *uvDer, MbVector3D *nor) const
 Вычислить значения точки и производных для заданных параметров.
virtual void _PointNormal (double u, double v, MbCartPoint3D &pnt, MbVector3D &deru, MbVector3D &derv, MbVector3D &norm, MbVector3D &noru, MbVector3D &norv, MbVector3D &deruu, MbVector3D &dervv, MbVector3D &deruv) const
 Вычислить значения всех производных в точке.
Функции движения по поверхности
virtual double StepU (double u, double v, double sag) const
 Вычислить шаг параметра.
virtual double StepV (double u, double v, double sag) const
 Вычислить шаг параметра.
virtual double DeviationStepU (double u, double v, double angle) const
 Вычислить шаг параметра.
virtual double DeviationStepV (double u, double v, double angle) const
 Вычислить шаг параметра.
virtual double MetricStepU (double u, double v, double length) const
 Вычислить шаг параметра.
virtual double MetricStepV (double u, double v, double length) const
 Вычислить шаг параметра.
double SurfaceStep (const double &u, const double &v, bool alongU, const MbStepData &stepData) const
 Вычислить шаг параметра.
virtual size_t GetUCount () const
 Количество разбиений по параметру u для проверки событий.
virtual size_t GetVCount () const
 Количество разбиений по параметру v для проверки событий.
Общие функции поверхности
virtual const MbSurfaceGetSurface () const
 Дать себя (перегружена только у CurveBoundedSurface).
virtual const MbSurfaceGetBasisSurface () const
 Дать базовую поверхность, если есть, или себя.
virtual MbSurfaceSetSurface ()
 Дать себя (перегружена только у CurveBoundedSurface).
virtual MbSurfaceSetBasisSurface ()
 Дать базовую поверхность, если есть, или себя.
virtual void GetLimitPoint (ptrdiff_t number, MbCartPoint3D &pnt) const
 Вычислить граничную точку.
virtual void GetLimitPoint (ptrdiff_t number, MbCartPoint &pnt) const
 Вычислить двумерную граничную точку.
MbCartPoint3D GetLimitPoint (ptrdiff_t number) const
 Вычислить граничную точку.
virtual double CurvatureU (double u, double v) const
 Вычислить кривизну линии вдоль u.
virtual double CurvatureV (double u, double v) const
 Вычислить кривизну линии вдоль v.
double NormalCurvatureU (double u, double v) const
 Вычислить нормальную кривизну линии вдоль u.
double NormalCurvatureV (double u, double v) const
 Вычислить нормальную кривизну линии вдоль v.
double NormalCurvature (double u, double v, double du, double dv) const
 Вычислить нормальную кривизну поверхности.
bool MeanGaussCurvature (double u, double v, double &mean, double &gauss) const
 Вычислить Среднюю и Гауссову кривизну.
virtual bool IsSameBase (const MbSurface &) const
 Является ли базовая поверхность копией базовой поверхности данного объекта.
virtual bool IsPlanar () const
 Является ли поверхность плоской.
virtual double GetRadius () const
 Дать физический радиус объекта или ноль, если это невозможно.
virtual double GetFilletRadius (const MbCartPoint3D &p) const
 Дать радиус скругления, если поверхность является поверхностью скругления.
virtual MbeParamDir GetFilletDirection () const
 Направление поверхности скругления.
virtual bool GetCylinderAxis (MbAxis3D &) const
 Дать ось вращения для поверхности.
virtual bool GetCentre (MbCartPoint3D &c) const
 Выдать центр сферической поверхности.
virtual void ChangeCarrier (MbSpaceItem &item, MbSpaceItem &init)
 Изменение носителя.
virtual bool ChangeCarrierBorne (MbSurface &item, MbSurface &init, const MbMatrix &matr)
 Изменение носимых элементов.
virtual bool IsSpinePeriodic () const
 Периодичность направляющей.
MbSplineSurfaceNurbsSurface (bool bmatch=false) const
 Построить NURBS копию поверхности.
virtual MbSplineSurfaceNurbsSurface (double u1, double u2, double v1, double v2, bool bmatch=false) const
 Построить NURBS копию усеченной поверхности.
bool NurbsParam (const MbNurbsParameters &tParam, bool uParam, double op1, double op2, bool &isClosedNurbs, double &epsilon, SArray< double > &params) const
 Подготовить параметры для преобразования в NURBS поверхность.
void CheckApproxPointParamsOpen (bool isU, double par, size_t degree, size_t pCount, SArray< double > &tList, SArray< double > &aKnots) const
 Выбрать точки для аппроксимации вдоль параметра.
void CheckApproxPointParamsClosed (bool isU, double par, size_t degree, size_t pCount, SArray< double > &tList, SArray< double > &aKnots) const
 Выбрать точки для аппроксимации вдоль параметра.
virtual MbSurfaceNurbsSurface (const MbNurbsParameters &uParam, const MbNurbsParameters &vParam) const
 Построить NURBS копию поверхности.
virtual MbSurfaceOffset (double d, bool same) const
 Построить эквидистантую поверхность.
virtual MbCurve3DCurveU (double v, MbRect1D *pRgn, bool bApprox=true) const
 Построить пространственную копию линии v = const.
virtual MbCurve3DCurveV (double u, MbRect1D *pRgn, bool bApprox=true) const
 Построить пространственную копию линии u = const.
virtual MbCurve3DCurveUV (const MbLineSegment &segm, bool bApprox=true) const
 Построить пространственную копию линии по параметрической линии.
virtual MbeItemLocation PointRelative (const MbCartPoint3D &pnt, double eps=ANGLE_REGION) const
 Определить, с какой стороны от поверхности находится точка.
virtual MbeItemLocation PointClassification (const MbCartPoint &pnt, bool ignoreClosed=false) const
 Находятся ли точка в области, принадлежащей поверхности.
virtual double DistanceToBorder (const MbCartPoint &point, double &epsilon) const
 Вычислить параметрическое расстояние до ближайшей границы.
virtual size_t CurveClassification (const MbCurve &curve, SArray< double > &tcurv, SArray< MbVector > &dir) const
 Определить точки пересечения кривoй с контурами поверхности.
size_t SurfaceBorderIntersection (const MbCurve &curve, SArray< double > &tcurv, SArray< MbVector > &dir) const
 Определить точки пересечения кривoй с контурами поверхности.
virtual MbeNewtonResult PointProjectionNewton (const MbCartPoint3D &p, size_t iterLimit, double &u, double &v, bool ext) const
 Нахождение проекции точки на поверхность. Для внутреннего использования.
virtual bool NearPointProjection (const MbCartPoint3D &pnt, double &u, double &v, bool ext, MbRect2D *uvRange=NULL) const
 Найти проекцию точки на поверхность.
virtual MbeNewtonResult DirectPointProjectionNewton (const MbCartPoint3D &p, const MbVector3D &vect, size_t iterLimit, double &u, double &v, double &w, bool ext) const
 Нахождение проекции точки на поверхность в направлении вектора. Для внутреннего использования.
virtual void DirectPointProjection (const MbCartPoint3D &pnt, const MbVector3D &vect, SArray< MbCartPoint > &uv, bool ext, MbRect2D *uvRange=NULL) const
 Найти все проекции точки на поверхность вдоль вектора в любом из двух направлений.
virtual bool NearDirectPointProjection (const MbCartPoint3D &pnt, const MbVector3D &vect, double &u, double &v, bool ext, MbRect2D *uvRange=NULL, bool onlyPositiveDirection=false) const
 Найти ближайшую проекцию точки на поверхность в направлении вектора.
virtual MbeNewtonResult CurveIntersectNewton (const MbCurve3D &curv1, double funcEpsilon, size_t iterLimit, double &u0, double &v0, double &t1, bool ext0, bool ext1) const
 Решение системы уравнений для определения пересечения поверхности и кривой. Для внутреннего использования.
virtual MbeNewtonResult CurveTangentNewton (const MbCurve3D &curv1, double funcEpsilon, size_t iterLimit, double &u0, double &v0, double &t1, bool ext0, bool ext1) const
 Решение системы уравнений для определения касания поверхности и кривой. Для внутреннего использования.
virtual void CurveIntersection (const MbCurve3D &curv, SArray< MbCartPoint > &uv, SArray< double > &tt, bool ext0, bool ext, bool touchInclude=false) const
 Определить точки пересечения поверхности и кривой.
virtual MbeNewtonResult SurfaceIntersectNewton (const MbSurface &surf1, MbeParamDir switchPar, double funcEpsilon, size_t iterLimit, double &u0, double &v0, double &u1, double &v1, bool ext0, bool ext1) const
 Решение системы уравнений для определения пересечения поверхностей. Для внутреннего использования.
virtual MbeNewtonResult SurfaceTangentNewton (const MbSurface &surf1, MbeParamDir switchPar, double funcEpsilon, size_t iterLimit, double &u0, double &v0, double &u1, double &v1, bool ext0, bool ext1) const
 Решение системы уравнений для определения касания поверхностей. Для внутреннего использования.
virtual MbeNewtonResult SilhouetteNewton (const MbVector3D &eye, bool perspective, const MbAxis3D *axis, MbeParamDir switchPar, double funcEpsilon, size_t iterLimit, double &u, double &v, bool ext) const
 Решение системы уравнений для определение точек очерка поверхности. Для внутреннего использования.
virtual bool IsSimilarToSurface (const MbSurface &surf) const
 Определить, подобны ли поверхности для объединения.
virtual bool IsSpecialSimilarToSurface (const MbSurface &surf, VERSION version=Math::DefaultMathVersion()) const
 Подобные ли поверхности для объединения (слива). Специальный случай. Для внутреннего использования.
virtual bool ProjectCurveOnSimilarSurface (const MbCurve3D &spaceCurve, const MbCurve &curve, const MbSurface &surfNew, MbCurve *&curveNew) const
 Построение проекции поверхностной кривой на совпадающую поверхность.
virtual bool GetMatrixToSurface (const MbSurface &surf, MbMatrix &matr) const
 Дать двумерную матрицу преобразования из своей параметрической области в параметрическую область surf.
virtual ThreeStates Salient () const
 Определить, выпуклая ли поверхность.
virtual double DistanceToCurve (const MbCurve3D &curve, double &u, double &v, double &t, bool tCalc=false) const
 Вычислить ближайшее расстояние до кривой.
virtual double DistanceToSurface (const MbSurface &surf1, double &u0, double &v0, double &u1, double &v1) const
 Вычислить ближайшее расстояние до поверхности.
virtual bool CreateNormalPlacements (const MbVector3D &axisZ, double angle, SArray< MbPlacement3D > &places) const
 Построить нормальные плейсменты конструктивных плоскостей.
virtual bool CreateTangentPlacements (const MbVector3D &axisZ, SArray< MbPlacement3D > &places) const
 Построить касательные плейсменты конструктивных плоскостей.
MbeNewtonResult PlacementNewton (const MbVector3D &vec, double angle, MbeParamDir switchPar, size_t iterLimit, double &u, double &v) const
 Построить касательные плейсменты конструктивных плоскостей. Для внутреннего использования.
bool CreateVconstPlacements (const MbVector3D &axisZ, double angle, bool normalPlace, SArray< MbPlacement3D > &places) const
 Построить нормальные или касательные плейсменты на v-линиях.
bool CreateUconstPlacements (const MbVector3D &axisZ, double angle, bool normalPlace, SArray< MbPlacement3D > &places) const
 Построить нормальные или касательные плейсменты на u-линиях.
virtual double ParamArea () const
 Вычислить площадь области определения параметров.
virtual size_t GetUPairs (double v, SArray< double > &u) const
 Вычислить U-пары от V.
virtual size_t GetVPairs (double u, SArray< double > &v) const
 Вычислить V-пары от U.
MbeNewtonResult IsoclinalNewton (const MbVector3D &dir, size_t iterLimit, double &u, double &v) const
 Определение параметров точки изоклины поверхности. Для внутреннего использования.
virtual void GetIsoclinal (const MbVector3D &nor, SArray< MbCartPoint > &uv) const
 Найти все изоклины поверхности.
virtual void CalculateGabarit (MbCube &cube) const
 Рассчитать габарит поверхности. Рекомендуется использовать GetGabarit.
virtual void CalculateLocalGabarit (const MbMatrix3D &into, MbCube &cube) const
 Рассчитать габарит в локальной системе координат.
const MbCubeGetGabarit () const
 Рассчитать габаритный куб поверхности.
const MbCubeCube () const
 Вернуть сохраненный габаритный куб. Он должен быть пустой. Рекомендуется использовать GetGabarit.
void SetDirtyGabarit () const
 Сделать габарит пустым. Для внутреннего использования.
void CopyGabarit (const MbSurface &s)
 Скопировать габаритный куб из копии.
double GetGabDiagonal () const
 Вычислить диагональ габаритного куба.
void CalculateRect (const MbPlacement3D &place, MbRect &rect) const
 Вычислить прямоугольный габарит поверхности в заданной плоскости.
virtual MbContourMakeContour (bool sense) const
 Вернуть граничный двумерный контур.
virtual MbCurveMakeSegment (size_t i, bool sense) const
 Вернуть сегмент граничного двумерного контура.
MbCurveMakeCurve (size_t number1, size_t number2) const
 Вернуть сегмент граничного двумерного контура.
virtual void SetLimit (double u1, double v1, double u2, double v2)
 Установить пределы поверхности. Для внутреннего использования.
void SetLimit (const MbRect &)
 Установить пределы поверхности. Для внутреннего использования.
virtual void SetExtendedParamRegion (double u1, double v1, double u2, double v2)
 Установить расширенные пределы поверхности. Для внутреннеого использования.
virtual void IncludePoint (double u, double v)
 Включить точку в область определения. Для внутреннеого использования.
double GetMaxParamDeltaU () const
 Дать максимальное приращение параметра U.
double GetMaxParamDeltaV () const
 Дать максимальное приращение параметра V.
virtual double GetParamDelta () const
 Дать максимальное приращение параметра.
virtual double GetParamPrice () const
 Дать мимнимально различимую величину параметра.
virtual double GetUParamToUnit () const
 Дать приращение параметра u, осреднённо соответствующее единичной длине в пространстве.
virtual double GetVParamToUnit () const
 Дать приращение параметра v, осреднённо соответствующее единичной длине в пространстве.
virtual double GetUParamToUnit (double u, double v) const
 Дать приращение параметра u, соответствующее единичной длине в пространстве.
virtual double GetVParamToUnit (double u, double v) const
 Дать приращение параметра v, соответствующее единичной длине в пространстве.
virtual void GetParamsToUnit (double u, double v, double &uParam, double &vParam) const
 Дать приращение параметра u и параметра v, соответствующее единичной длине в пространстве.
double GetUEpsilon () const
 Дать минимально различимую величину параметра U. Соответствует длине в пространстве = Math::metricEpsilon.
double GetVEpsilon () const
 Дать минимально различимую величину параметра V. Соответствует длине в пространстве = Math::metricEpsilon.
double GetUEpsilon (double u, double v) const
 Дать минимально различимую величину параметра U. Соответствует длине в пространстве = Math::metricEpsilon.
double GetVEpsilon (double u, double v) const
 Дать минимально различимую величину параметра V. Соответствует длине в пространстве = Math::metricEpsilon.
double GetURegion () const
 Дать минимально различимую величину параметра U. Соответствует длине в пространстве = Math::metricRegion.
double GetVRegion () const
 Дать минимально различимую величину параметра V. Соответствует длине в пространстве = Math::metricRegion.
double GetURegion (double u, double v) const
 Дать минимально различимую величину параметра U. Соответствует длине в пространстве = Math::metricRegion.
double GetVRegion (double u, double v) const
 Дать минимально различимую величину параметра V. Соответствует длине в пространстве = Math::metricRegion.
virtual size_t GetUMeshCount () const
 Выдать количество разбиений по u.
virtual size_t GetVMeshCount () const
 Выдать количество разбиений по v.
void CalculatePolygon (double minPar, double maxPar, double constPar, MbeParamDir dir, const MbStepData &stepData, MbPolygon3D &polygon) const
 Рассчитать полигон по параметру U или V.
virtual void CalculateSurfaceWire (const MbStepData &stepData, size_t beg, MbMesh &mesh, size_t uMeshCount=WIRE_MAX, size_t vMeshCount=WIRE_MAX) const
 Рассчитать сетку.
virtual void GetTesselation (const MbStepData &stepData, double u1, double u2, double v1, double v2, SArray< double > &uu, SArray< double > &vv) const
 Определить разбивку параметрической области поверхности вертикалями и горизонталями.
void AddTesselation (const MbStepData &stepData, MbeParamDir dir, double u1, double u2, double v1, double v2, SArray< double > &uu, SArray< double > &vv) const
 Определить разбивку параметрической области поверхности с учетом направления.
virtual void CalculateSurfaceGrid (const MbStepData &stepData, bool sense, MbGrid &grid) const
 Аппроксимировать поверхность треугольными пластинами.
void CalculateMesh (const MbStepData &stepData, const MbFormNote &note, MbMesh &mesh) const
 Аппроксимировать поверхность треугольными пластинами.
virtual bool IsRectangular () const
 Определить, ортогональны ли производные по u и v.
virtual bool IsLineU () const
 Проверить, что все производные поверхности по U выше первой равны нулю.
virtual bool IsLineV () const
 Проверить, что все производные поверхности по V выше первой равны нулю.
virtual bool IsShift (const MbSpaceItem &obj, MbVector3D &dir, bool &isSame, double accuracy=LENGTH_EPSILON) const
 Определить, является ли объект смещением.
virtual void CheckSurfParams (double &u, double &v) const
 Проверить параметры. Аналог глобальной функции _CheckParams, оптимизированный под использование кэшей.
bool GetPlacement (MbPlacement3D *place, bool exact=false) const
 Дать плоскость (или только возможность ее выдачи).
bool GetPlanePlacement (MbPlacement3D &place) const
 Дать плоскость.
bool GetControlPlacement (MbPlacement3D &place, bool sameSense=true) const
 Дать плейсмент поверхности в средней точке.
bool OrientPlacement (MbPlacement3D &place, bool normalSense=true) const
 Сориентировать ось Х плейсмента вдоль линии его пересечения с поверхностью.
bool IsPointOn (const MbCartPoint3D &, double eps=METRIC_PRECISION) const
 Определить, лежит ли точка на плоскости.
void PointOn (MbCartPoint &uv, MbCartPoint3D &p) const
 Вычислить точку на поверхности в области определения поверхности.
void _PointOn (const MbCartPoint &uv, MbCartPoint3D &p) const
 Вычислить точку на продолженной поверхности.
void Normal (MbCartPoint &uv, MbVector3D &v) const
 Вычислить нормаль к поверхности в области определения поверхности.
bool GetMatrix (double xMin, double xMax, double yMin, double yMax, MbMatrix &matr) const
 Найти матрицу преобразования для кривых на поверхности при изменении параметризации.
double GetUMid () const
 Среднее значение параметра u.
double GetVMid () const
 Среднее значение параметра v.
double GetURange () const
 Параметрическая длина по u.
double GetVRange () const
 Параметрическая длина по v.
void GetRect (MbRect &r) const
 Получить параметрические границы поверхности.
void GetRect (MbRect2D &r) const
 Получить параметрические границы поверхности.

Защищенные члены

 MbSurface ()
 Конструктор.
 MbSurface (const MbSurface &)
 Конструктор копирования.
void MoveGabarit (const MbVector3D &v)
 Сдвинуть габарит.
void NormalCalculation (const MbVector3D &uDer, const MbVector3D &vDer, double u, double v, bool ext, MbVector3D &nor) const
 Вычислить нормаль по известным производным uDer и vDer в точке с параметрами u, v.
double StepAlong (double u, double v, double sag, bool alongU, double stepMinCoeff, const MbVector3D &der, const MbVector3D &sec) const
 Вычислить шаг по параметру для заданного прогиба.
double DeviationStepAlong (double u, double v, double angle, bool alongU, const MbVector3D &der, const MbVector3D &sec) const
 Вычислить шаг по параметру для заданного углового отклонения нормали.

Защищенные данные

MbCube cube
 Габаритный куб поверхности.

Подробное описание

Родительский класс всех поверхностей в трехмерном пространстве. Поверхность представляет собой векторную функцию двух скалярных параметров, принимающих значения на двумерной связной области. Поверхность представляет собой непрерывное отображение двумерной связной области в трёхмерное пространство.
Для всех поверхностей, кроме MbCurveBoundedSurface, областью определения является прямоугольник в двумерном пространстве параметров.
Поверхность используется:
для пространственного моделирования,
для построения граней тел в частных случаях.


Методы

virtual MbSpaceItem& MbSurface::Duplicate ( MbRegDuplicate iReg = NULL) const [pure virtual]

Создать копию объекта с использованием регистратора. Регистратор используется для предотвращения многократного копирования объекта. Если объект содержит ссылки на другие объекты, то вложенные объекты так же копируются. Допустимо не передавать регистратор в функцию. Тогда будет создана новая копия объекта. При копировании одиночного объекта или набора не связанных между собой объектов допустимо не использовать регистратор. Регистратор необходимо использовать, если надо последовательно копировать несколько взаимосвязанных объектов. Возможно, что связь объектов обусловлена наличием в них ссылок на общие объекты. Тогда, при копировании без использования регистратора, можно получить набор копий, содержащих ссылки на разные копии одного и того же вложенного объекта, что ведет к потере связи между копиями.

Аргументы:
[in]iReg- Регистратор.
Возвращает:
Копия объекта.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbChannelSurface, MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface, MbSweptSurface и MbTorusSurface.

virtual bool MbSurface::IsSame ( const MbSpaceItem other,
double  accuracy = LENGTH_EPSILON 
) const [pure virtual]

Равными считаются однотипные объекты, все данные которых одинаковы (равны).

Аргументы:
[in]item- Объект для сравнения.
[in]accuracy- Точность сравнения.
Возвращает:
Равны ли объекты.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbChannelSurface, MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface, MbSweptSurface и MbTorusSurface.

virtual bool MbSurface::SetEqual ( const MbSpaceItem item) [pure virtual]

Равными можно сделать только подобные объекты. Подобный объект приравнивается присланному путем изменения численных данных.

Аргументы:
[in]item- Объект для инициализации.
Возвращает:
Сделан ли объект равным присланному.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbChannelSurface, MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface, MbSweptSurface и MbTorusSurface.

virtual void MbSurface::Transform ( const MbMatrix3D matr,
MbRegTransform iReg = NULL 
) [pure virtual]

Преобразовать исходный объект согласно матрице c использованием регистратора. Если объект содержит ссылки на другие геометрические объекты, то вложенные объекты так же преобразуются согласно матрице. Регистратор служит для предотвращения многократного преобразования объекта. Допустимо использовать функцию без регистратора, если надо преобразовать одиночный объект. Если надо преобразовать набор взаимосвязанных объектов, необходимо использовать регистратор для предотвращения повторного преобразования вложенных объектов, поскольку не исключена ситуация, когда несколько объектов из набора содержат ссылки на один или несколько общих объектов, подлежащих трансформации.

Аргументы:
[in]matr- Матрица преобразования.
[in]iReg- Регистратор.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSphereSurface, MbSpiralSurface, MbSweptSurface и MbTorusSurface.

virtual void MbSurface::Move ( const MbVector3D to,
MbRegTransform iReg = NULL 
) [pure virtual]

Сдвинуть геометрический объект вдоль вектора с использованием регистратора. Если объект содержит ссылки на другие геометрические объекты, то к вложенным объектам так же применяется операция сдвига. Регистратор служит для предотвращения многократного преобразования объекта. Допустимо использовать функцию без регистратора, если надо преобразовать одиночный объект. Если надо преобразовать набор взаимосвязанных объектов, необходимо использовать регистратор для предотвращения повторного преобразования вложенных объектов, поскольку не исключена ситуация, когда несколько объектов из набора содержат ссылки на один или несколько общих объектов, подлежащих сдвигу.

Аргументы:
[in]to- Вектор сдвига.
[in]iReg- Регистратор.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSpiralSurface и MbSweptSurface.

virtual void MbSurface::Rotate ( const MbAxis3D axis,
double  angle,
MbRegTransform iReg = NULL 
) [pure virtual]

Повернуть объект вокруг оси на заданный угол с использованием регистратора. Если объект содержит ссылки на другие геометрические объекты, то к вложенным объектам так же применяется операция поворота. Регистратор служит для предотвращения многократного преобразования объекта. Допустимо использовать функцию без регистратора, если надо преобразовать одиночный объект. Если надо преобразовать набор взаимосвязанных объектов, необходимо использовать регистратор для предотвращения повторного преобразования вложенных объектов, поскольку не исключена ситуация, когда несколько объектов из набора содержат ссылки на один или несколько общих объектов, подлежащих повороту.

Аргументы:
[in]axis- Ось поворота.
[in]angle- Угол поворота.
[in]iReg- Регистратор.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSpiralSurface и MbSweptSurface.

virtual double MbSurface::DistanceToPoint ( const MbCartPoint3D point) const [virtual]

Определить расстояние до точки.

Аргументы:
[in]point- Точка.
Возвращает:
Расстояние от объекта до точки.

Замещает MbSpaceItem.

Переопределяется в MbCurveBoundedSurface, MbElementarySurface и MbPlane.

virtual void MbSurface::AddYourGabaritTo ( MbCube cube) const [virtual]

Расширить присланный габаритный куб так, чтобы он включал в себя данный объект.

Аргументы:
[in,out]cube- Принимающий габаритный куб с информацией по габаритам.

Замещает MbSpaceItem.

virtual void MbSurface::PrepareIntegralData ( const bool  forced) const [virtual]

Рассчитать временные данные объекта в зависимости от параметра forced. Если параметр forced равен false, рассчитываются только ещё не насчитанные данные. Если параметр forced равен true, перерасчитываются все временные данные объекта. Принудительный перерасчёт.

virtual void MbSurface::CalculateWire ( const MbStepData stepData,
MbMesh mesh 
) const [virtual]

Создать полигональную копию данного объекта, представленную полигонами. Полигональный объект будет содержать только полигоны MbPolygon3D.

Аргументы:
[in]sag- Максимальное отклонение полигонального объекта от оригинала по прогибу.
[in,out]mesh- Принимающий полигональный объект.

Замещает MbSpaceItem.

Переопределяется в MbCurveBoundedSurface и MbGridSurface.

virtual void MbSurface::GetProperties ( MbProperties properties) [pure virtual]

Выдать внутренние данные (свойства) объекта для их просмотра и модификации.

Аргументы:
[in]properties- Контейнер для внутренних данных объекта.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbChannelSurface, MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface, MbSweptSurface и MbTorusSurface.

virtual void MbSurface::SetProperties ( const MbProperties properties) [pure virtual]

Изменение внутренних данных (свойств) объекта выполняется копированием соответствующих значений из присланного объекта.

Аргументы:
[in]properties- Контейнер для внутренних данных объекта.

Замещает MbSpaceItem.

Замещается в MbChamferSurface, MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface, MbSweptSurface и MbTorusSurface.

virtual bool MbSurface::IsUClosed ( ) const [pure virtual]

Определить, замкнута ли гладко поверхность по u-параметру без учета граничного контура. Всегда false для MbCurveBoundSurface. Рекомендуется использовать IsUPeriodic.

Замещается в MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbSmoothSurface, MbSphereSurface, MbSplineSurface, MbSweptSurface и MbTorusSurface.

virtual bool MbSurface::IsVClosed ( ) const [pure virtual]

Определить, замкнута ли гладко поверхность по v-параметру без учета граничного контура. Всегда false для MbCurveBoundSurface. Рекомендуется использовать IsVPeriodic.

Замещается в MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElementarySurface, MbGregorySurface, MbGridSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbPolySurface, MbSmoothSurface, MbSphereSurface, MbSplineSurface, MbSweptSurface и MbTorusSurface.

virtual bool MbSurface::IsUTouch ( ) const [virtual]

Определить, замкнута ли фактически поверхность по u-параметру независимо от гладкости замыкания.

Переопределяется в MbCurveBoundedSurface, MbGregorySurface, MbMeshSurface и MbSplineSurface.

virtual bool MbSurface::IsVTouch ( ) const [virtual]

Определить, замкнута ли фактически поверхность по v-параметру независимо от гладкости замыкания.

Переопределяется в MbCurveBoundedSurface, MbGregorySurface, MbMeshSurface и MbSplineSurface.

virtual bool MbSurface::IsUPeriodic ( ) const [virtual]

Определить, замкнута ли гладко поверхность по u-параметру без учета граничного контура.

Переопределяется в MbCurveBoundedSurface, MbGregorySurface, MbMeshSurface и MbSplineSurface.

virtual bool MbSurface::IsVPeriodic ( ) const [virtual]

Определить, замкнута ли гладко поверхность по v-параметру без учета граничного контура.

Переопределяется в MbCurveBoundedSurface, MbGregorySurface, MbMeshSurface и MbSplineSurface.

virtual double MbSurface::GetPeriod ( ptrdiff_t  i) const [virtual]

Период вычисляется для гладко замкнутой поверхности по одному из параметров. Если поверхность не замкнута по этому параметру, возвращается 0.

Аргументы:
[in]i- Показывает направление: 0 - период по u, 1 - период по v.
virtual size_t MbSurface::Periodicity ( ) const [virtual]

Является ли поверхность периодической.

Возвращает:
0 если не периодическая
1 если периодическая по U
2 если периодическая по V
3 если периодическая по U и V
virtual void MbSurface::GetLimitPoint ( ptrdiff_t  number,
MbCartPoint3D pnt 
) const [virtual]

Вычислить одну из точек, параметры которых принимают наибольшие или наименьшие значения.

Аргументы:
[in]number- Номер граничной точки.
1 соответствует точке (umin, vmin)
2 - точке (umax, vmin)
3 - точке (umax, vmax)
4 - точке (umin, vmax)
[in,out]pnt- Вычисленная точка.

Переопределяется в MbCurveBoundedSurface и MbPlane.

virtual void MbSurface::GetLimitPoint ( ptrdiff_t  number,
MbCartPoint pnt 
) const [virtual]

Вычислить одну из точек, параметры которых принимают наибольшие или наименьшие значения.

Аргументы:
[in]number- Номер граничной точки.
1 соответствует точке (umin, vmin)
2 - точке (umax, vmin)
3 - точке (umax, vmax)
4 - точке (umin, vmax)
[in,out]pnt- Вычисленная точка.

Переопределяется в MbCurveBoundedSurface и MbPlane.

MbCartPoint3D MbSurface::GetLimitPoint ( ptrdiff_t  number) const

Вычислить одну из точек, параметры которых принимают наибольшие или наименьшие значения.

Аргументы:
[in]number- Номер граничной точки.
1 соответствует точке (umin, vmin)
2 - точке (umax, vmin)
3 - точке (umax, vmax)
4 - точке (umin, vmax)
Возвращает:
Вычисленная точка. Выдать граничную трехмерную точку.
virtual double MbSurface::CurvatureU ( double  u,
double  v 
) const [virtual]

Вычисляется кривизна линии вдоль u при v = const.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
Возвращает:
Кривизна.

Переопределяется в MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbEvolutionSurface, MbExpansionSurface, MbExtrusionSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSphereSurface, MbSpiralSurface и MbTorusSurface.

virtual double MbSurface::CurvatureV ( double  u,
double  v 
) const [virtual]

Вычисляется кривизна линии вдоль v при u = const.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
Возвращает:
Кривизна.

Переопределяется в MbChamferSurface, MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbExpansionSurface, MbExtrusionSurface, MbFilletSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSphereSurface и MbTorusSurface.

double MbSurface::NormalCurvatureU ( double  u,
double  v 
) const

Вычисляется нормальная кривизна координатной линии вдоль u.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
Возвращает:
Кривизна.
double MbSurface::NormalCurvatureV ( double  u,
double  v 
) const

Вычисляется нормальная кривизна координатной линии вдоль v.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
Возвращает:
Кривизна.
double MbSurface::NormalCurvature ( double  u,
double  v,
double  du,
double  dv 
) const

Вычисляется нормальная кривизна поверхности вдоль линии du dv.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
[in]du- Задает направление линии, вдоль которой вычисляется нормальная кривизна.
[in]dv- Задает направление линии, вдоль которой вычисляется нормальная кривизна.
Возвращает:
Кривизна.
bool MbSurface::MeanGaussCurvature ( double  u,
double  v,
double &  mean,
double &  gauss 
) const

Средняя и Гауссова кривизна.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
[out]mean- Средняя кривизна.
[out]gauss- Гауссова кривизна.
Возвращает:
true в случае успеха операции
false в противном случае
virtual double MbSurface::GetRadius ( ) const [virtual]

Метод выдает максимальный физический радиус по одному из изопараметрических направлений, если соответствующая изопараметрическая кривая является дугой окружности, в противном случае метод выдает ноль.

Переопределяется в MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbFilletSurface, MbSphereSurface, MbSplineSurface и MbTorusSurface.

virtual void MbSurface::ChangeCarrier ( MbSpaceItem item,
MbSpaceItem init 
) [virtual]
virtual bool MbSurface::ChangeCarrierBorne ( MbSurface item,
MbSurface init,
const MbMatrix matr 
) [virtual]

Используется для объединения компланарных граней. Поверхности item и init должны быть подобны.

Аргументы:
[in]item- Изменяемая поверхность
[in]init- Новая поверхность
[in]matr- Матрица перехода из item в init
Возвращает:
true в случае успеха операции
false в противном случае

Переопределяется в MbChamferSurface, MbCurveBoundedSurface, MbFilletSurface и MbOffsetSurface.

virtual bool MbSurface::IsSpinePeriodic ( ) const [virtual]
Возвращает:
true если у поверхности есть направляющая и она периодичная

Переопределяется в MbEvolutionSurface.

MbSplineSurface* MbSurface::NurbsSurface ( bool  bmatch = false) const

Полученная поверхность всегда не замкнута как по u, так и по v. Исключением является сама поверхность NURBS. Если поверхность не требует пересчета, то выдается ее копия.

Аргументы:
[in]bmatch- true, если при преобразовании нужно сохранить однозначное сответствие параметрических областей
virtual MbSplineSurface* MbSurface::NurbsSurface ( double  u1,
double  u2,
double  v1,
double  v2,
bool  bmatch = false 
) const [virtual]

Полученная поверхность всегда не замкнута как по u, так и по v. Исключением является сама поверхность NURBS. Если поверхность не требует пересчета, то выдается ее копия Параметры u1, u2, v1, v2 - границы усечения поверхности.

Аргументы:
[in]u1- Минимальный параметр по U
[in]u2- Максимальный параметр по U
[in]v1- Минимальный параметр по V
[in]v2- Максимальный параметр по V
[in]bmatch- true, если при преобразовании нужно сохранить однозначное сответствие параметрических областей

Переопределяется в MbChamferSurface, MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbJoinSurface, MbLoftedSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface и MbTorusSurface.

bool MbSurface::NurbsParam ( const MbNurbsParameters tParam,
bool  uParam,
double  op1,
double  op2,
bool &  isClosedNurbs,
double &  epsilon,
SArray< double > &  params 
) const

Подготовить параметры для преобразования в NURBS поверхность. Число точек вдоль выбранного направления определяется в переменной tParam.

Аргументы:
[in]tParam- Параметры преобразования поверхности в NURBS по одному из параметров.
[in]uParam- Какой параметр поверхности рассматривается:
true - готовит аппроксимацию по u false - готовит аппроксимацию по v.
[in]op1- Минимальное значение второго параметра.
[in]op2- Максимальное значение второго параметра.
[out]isClosedNurbs- true - если аппроксимирующая поверхность замкнута по выбранному направлению.
[out]epsilon- На выходе - параметрическая точность по выбранному направлению.
[out]params- Заполненный массив параметров разбиения вдоль выбранного направления.
Возвращает:
true, если операция прошла успешно.
void MbSurface::CheckApproxPointParamsOpen ( bool  isU,
double  par,
size_t  degree,
size_t  pCount,
SArray< double > &  tList,
SArray< double > &  aKnots 
) const

Выбрать точки на поверхности для аппроксимации nurbs вдоль параметра в случае незамкнутой по выбранному направлению поверхности. Если поверхность аппроксимируется с заданным узловым вектором, то проверяются параметры разбиения для того, чтобы между элементами узлового вектора содержалась бы хотя бы одна точка разбиения. При необходимости список точек разбиения дополняется. Если узловой вектор не задан (пустой), то вычисляется узловой вектор в соответствии с порядком, количеством узлов и предложенным разбиением.

Аргументы:
[in]isU- Какой параметр поверхности рассматривается:
true - готовит аппроксимацию по u. false - готовит аппроксимацию по v.
[in]par- Значение второго параметра.
[in]degree- Порядок NURBS-поверхности по выбранному направлению.
[in]pCount- Количество узлов NURBS-поверхности по выбранному направлению.
[in,out]tList- Параметры разбиения поверхности по выбранному направлению. Вычисляются в функции NurbsParam.
[in,out]aKnots- Узловой вектор NURBS-поверхности.
void MbSurface::CheckApproxPointParamsClosed ( bool  isU,
double  par,
size_t  degree,
size_t  pCount,
SArray< double > &  tList,
SArray< double > &  aKnots 
) const

Выбрать точки на поверхности для аппроксимации nurbs вдоль параметра в случае замкнутой по выбранному направлению поверхности. Если поверхность аппроксимируется с заданным узловым вектором, то проверяются параметры разбиения для того, чтобы между элементами узлового вектора содержалась бы хотя бы одна точка разбиения. При необходимости список точек разбиения дополняется. Если узловой вектор не задан (пустой), то вычисляется узловой вектор в соответствии с порядком, количеством узлов и предложенным разбиением.

Аргументы:
[in]isU- Какой параметр поверхности рассматривается:
true - готовит аппроксимацию по u false - готовит аппроксимацию по v.
[in]par- Значение второго параметра.
[in]degree- Порядок NURBS-поверхности по выбранному направлению.
[in]pCount- Количество узлов NURBS-поверхности по выбранному направлению.
[in,out]tList- Параметры разбиения поверхности по выбранному направлению. Вычисляются в функции NurbsParam.
[in,out]aKnots- Узловой вектор NURBS-поверхности.
virtual MbSurface* MbSurface::NurbsSurface ( const MbNurbsParameters uParam,
const MbNurbsParameters vParam 
) const [virtual]

Строит NURBS поверхность, аппроксимирующую исходную с заданными параметрами по каждому направлению. В параметрах можно задать степень и количество узлов сплайна, диапазон изменения параметра кривой. Если в параметрах не задан флаг точной аппроксимации, то строит NURBS без кратных узлов.

Аргументы:
[in]uParam- Параметры построения по направлению u.
[in]vParam- Параметры построения по направлению v.
Возвращает:
Построенная NURBS поверхность или NULL при неуспешном построении.

Переопределяется в MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbExpansionSurface, MbExtrusionSurface, MbFilletSurface, MbJoinSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSmoothSurface, MbSphereSurface, MbSplineSurface и MbTorusSurface.

virtual MbSurface* MbSurface::Offset ( double  d,
bool  same 
) const [virtual]
Аргументы:
[in]d- Расстояние по нормали от базовой до эквидистантной поверхности.
[in]same- Флаг, показывающий, использовать ли в эквидистантной поверхности текущую поверхность или ее копию.

Переопределяется в MbChamferSurface, MbChannelSurface, MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbJoinSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSphereSurface, MbSpiralSurface и MbTorusSurface.

virtual MbCurve3D* MbSurface::CurveU ( double  v,
MbRect1D pRgn,
bool  bApprox = true 
) const [virtual]
Аргументы:
[in]v- Параметр по направлению V.
[in]pRgn- Диапазон параметров по U.
[in]bApprox- Если false, то вернет не ноль только в случае, если получится создать точную кривую.
Если true, то вернет не ноль, если кривая не вырождена.
Возвращает:
Построенная кривая.

Переопределяется в MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbLoftedSurface, MbMeshSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface и MbTorusSurface.

virtual MbCurve3D* MbSurface::CurveV ( double  u,
MbRect1D pRgn,
bool  bApprox = true 
) const [virtual]
Аргументы:
[in]u- Параметр по направлению U.
[in]pRgn- Диапазон параметров по V.
[in]bApprox- Если false, то вернет не ноль только в случае, если получится создать точную кривую.
Если true, то вернет не ноль, если кривая не вырождена.
Возвращает:
Построенная кривая.

Переопределяется в MbChamferSurface, MbConeSurface, MbCoonsPatchSurface, MbCornerSurface, MbCoverSurface, MbCurveBoundedSurface, MbCylinderSurface, MbElevationSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbLoftedSurface, MbMeshSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface и MbTorusSurface.

virtual MbCurve3D* MbSurface::CurveUV ( const MbLineSegment segm,
bool  bApprox = true 
) const [virtual]
Аргументы:
[in]segm- Отрезок в параметрической плоскости поверхности, пространственную копию которого надо построить.
[in]bApprox- Если false, то вернет не ноль только в случае, если получится создать точную кривую.
Если true, то вернет не ноль, если кривая не вырождена.

Переопределяется в MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbPlane и MbRuledSurface.

virtual MbeItemLocation MbSurface::PointRelative ( const MbCartPoint3D pnt,
double  eps = ANGLE_REGION 
) const [virtual]
Аргументы:
[in]pnt- Исследуемая точка.
[in]eps- Точность определения попадания точки на поверхность.
Возвращает:
iloc_InItem = 1 - точка над поверхностью (со стороны нормали).
iloc_OnItem = 0 - точка на поверхности.
iloc_OutOfItem = -1 - точка под поверхностью.

Переопределяется в MbPlane.

virtual MbeItemLocation MbSurface::PointClassification ( const MbCartPoint pnt,
bool  ignoreClosed = false 
) const [virtual]

Исследуется двумерная точка в параметрической плоскости поверхности.

Аргументы:
[in]pnt- Исследуемая точка.
[in]ignoreClosed- Учитывать ли замкнутость поверхности. Если true, то замкнутость не учитывается.
Возвращает:
iloc_InItem - точка в области поверхности.
iloc_OnItem - точка на границе поверхности.
iloc_OutOfItem - точка вне области поверхности.

Переопределяется в MbCurveBoundedSurface.

virtual double MbSurface::DistanceToBorder ( const MbCartPoint point,
double &  epsilon 
) const [virtual]

Найденное расстояние до ближайшей границы имеет положительное значение, если точка находится внутри, и отрицательное - если снаружи.

Аргументы:
[in]point- Исследуемая точка.
[in]epsilon- Точность определения попадания точки на поверхность.
Возвращает:
Возвращает расстояние до границы.

Переопределяется в MbCurveBoundedSurface.

virtual size_t MbSurface::CurveClassification ( const MbCurve curve,
SArray< double > &  tcurv,
SArray< MbVector > &  dir 
) const [virtual]

Определить точки пересечения кривoй с границами поверхности для нахождение частей кривой в пределах поверхности и векторов для их сдвига в пределы поверхности. Вектор сдвига определен для каждой точки пересечения. Если вектор сдвига найти нельзя, то в массив сохраняется вектор нулевой длины. Он может быть ненулевым, если поверхность замкнута хотя бы по одному из направлений. Тогда вектор сдвига позволяет сдвинуть часть кривой на некоторое количество периодов так, чтобы найденная точка пересечения кривой с границей находилась бы в пределах поверхности и производная к кривой в этой точке была бы направлена внутрь поверхности. С помощью вектора сдвига кривую можно сдвинуть на некоторое количество периодов. То есть метрически кривая не изменится.

Аргументы:
[in]curve- Заданная кривая.
[in,out]tcurv- Множество параметров кривой, соответствующих точкам пересечения.
[in,out]dir- Множество векторов сдвига.
Возвращает:
Количество пересечений.

Переопределяется в MbCurveBoundedSurface.

size_t MbSurface::SurfaceBorderIntersection ( const MbCurve curve,
SArray< double > &  tcurv,
SArray< MbVector > &  dir 
) const

Определить точки пересечения кривoй с границами поверхности для нахождение частей кривой в пределах поверхности и векторов для их сдвига в пределы поверхности. Вектор сдвига определен для каждой точки пересечения. Если вектор сдвига найти нельзя, то в массив сохраняется вектор нулевой длины. Он может быть ненулевым, если поверхность замкнута хотя бы по одному из направлений. Тогда вектор сдвига позволяет сдвинуть часть кривой на некоторое количество периодов так, чтобы найденная точка пересечения кривой с границей находилась бы в пределах поверхности и производная к кривой в этой точке была бы направлена внутрь поверхности. С помощью вектора сдвига кривую можно сдвинуть на некоторое количество периодов. То есть метрически кривая не изменится.

Аргументы:
[in]curve- Заданная кривая.
[in,out]tcurv- Множество параметров кривой, соответствующих точкам пересечения.
[in,out]dir- Множество векторов сдвига.
Возвращает:
Количество пересечений.
virtual bool MbSurface::NearPointProjection ( const MbCartPoint3D pnt,
double &  u,
double &  v,
bool  ext,
MbRect2D uvRange = NULL 
) const [virtual]

Найти ближайшую проекцию точки на поверхность или ее продолжение по заданному начальному приближению. Если задан диапазон изменения параметров uvRange, то надо найти проекцию в заданном диапазоне. Диапазон параметров может выходить за область определения параметров поверхности. Используется метод Ньютона.

Аргументы:
[in]pnt- Заданная точка.
[in,out]u- На входе - начальное приближение, на выходе - параметр, соответствующий ближайшей проекции.
[in,out]v- На входе - начальное приближение, на выходе - параметр, соответствующий ближайшей проекции.
[in]ext- Флаг, определяющий, искать ли проекцию на продолжении поверхности (если true, то искать).
[in]uvRange- Диапазон изменения параметров, в котором надо найти решение.
Возвращает:
true - если найдена проекция, удовлетворяющая всем входным условиям.

Переопределяется в MbCurveBoundedSurface, MbElementarySurface, MbExtrusionSurface, MbFilletSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbRevolutionSurface, MbRuledSurface, MbSpiralSurface и MbSplineSurface.

virtual void MbSurface::DirectPointProjection ( const MbCartPoint3D pnt,
const MbVector3D vect,
SArray< MbCartPoint > &  uv,
bool  ext,
MbRect2D uvRange = NULL 
) const [virtual]

Вычислить все точки пересечения поверхности с лучом, выходящим из заданной точки p по направлению vect. Если задан диапазон изменения параметров uvRange, то надо найти проекцию в заданном диапазоне. Диапазон параметров может выходить за область определения параметров поверхности.

Аргументы:
[in]pnt- Заданная точка.
[in]vect- Вектор направления.
[in,out]uv- Множество точек проекции.
[in]ext- Флаг, определяющий, искать ли проекцию на продолжении кривой (если true, то искать).
[in]uvRange- Диапазон изменения параметров, в котором надо найти решение.

Переопределяется в MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbLoftedSurface, MbMeshSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbSphereSurface, MbSplineSurface и MbTorusSurface.

virtual bool MbSurface::NearDirectPointProjection ( const MbCartPoint3D pnt,
const MbVector3D vect,
double &  u,
double &  v,
bool  ext,
MbRect2D uvRange = NULL,
bool  onlyPositiveDirection = false 
) const [virtual]

Вычислить ближайшую точку пересечения поверхности с лучом, выходящим из заданной точки p по направлению vect. Если задан диапазон изменения параметров uvRange - то надо найти проекцию в заданном диапазоне. Диапазон параметров может выходить за область определения параметров поверхности.

Аргументы:
[in]pnt- Заданная точка.
[in]vect- Вектор направления.
[in,out]u- На входе - начальное приближение, на выходе - параметр, соответствующий ближайшей проекции.
[in,out]v- На входе - начальное приближение, на выходе - параметр, соответствующий ближайшей проекции.
[in]ext- Флаг, определяющий, искать ли проекцию на продолжении кривой (если true, то искать).
[in]uvRange- Диапазон изменения параметров, в котором надо найти решение.
Возвращает:
true - если найдена проекция, удовлетворяющая всем входным условиям.

Переопределяется в MbPlane.

virtual void MbSurface::CurveIntersection ( const MbCurve3D curv,
SArray< MbCartPoint > &  uv,
SArray< double > &  tt,
bool  ext0,
bool  ext,
bool  touchInclude = false 
) const [virtual]

Определить точки пересечения поверхности и кривой.

Аргументы:
[in]curv- Заданная кривая.
[in]uv- Множество точек пересечения на поверхности.
[in,out]tt- Множество точек пересечения на кривой.
[in]ext0- Флаг, определяющий, искать ли пересечения на расширенной поверхности (если true, то искать).
[in]ext- Флаг, определяющий, искать ли пересечения на продолжении кривой (если true, то искать).
[in]touchInclude- Считать ли касание пересечением. Если true, то считать.

Переопределяется в MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbExtrusionSurface, MbPlane, MbRuledSurface, MbSphereSurface и MbTorusSurface.

virtual bool MbSurface::IsSimilarToSurface ( const MbSurface surf) const [virtual]

Поверхности подобны для объединения, если геометрически они совпадают или переходят одна в другую.

Аргументы:
[in]surf- Заданная поверхность.
Возвращает:
true - если поверхности подобны.

Переопределяется в MbChamferSurface, MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExtrusionSurface, MbFilletSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSphereSurface, MbSpiralSurface и MbTorusSurface.

virtual bool MbSurface::ProjectCurveOnSimilarSurface ( const MbCurve3D spaceCurve,
const MbCurve curve,
const MbSurface surfNew,
MbCurve *&  curveNew 
) const [virtual]

Строится проекция кривой пересечения поверхностей на некоторую заданную поверхность. В функции подразумевается, что заданная поверхность подобна одной из несущих поверхностей кривой пересечения, но этот факт не проверяется.

Аргументы:
[in]spaceCurve- Заданная кривая пересечения.
[in]curve- Двумерная кривая на поверхности.
[in]surfNew- Новая поверхность.
[out]curveNew- Полученная двумерная кривая на новой поверхности.
Возвращает:
true - если операция прошла успешно.

Переопределяется в MbCurveBoundedSurface и MbSphereSurface.

virtual bool MbSurface::GetMatrixToSurface ( const MbSurface surf,
MbMatrix matr 
) const [virtual]

Вычисление матрицы преобразования из одной параметрической области в другую осуществляется для поверхностей, подобных для объединения.

Аргументы:
[in]surf- Заданная поверхность.
[out]matr- Матрица преобразования.
Возвращает:
true - матрица вычислена.

Переопределяется в MbChamferSurface, MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbEvolutionSurface, MbExactionSurface, MbExpansionSurface, MbExtrusionSurface, MbFilletSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSphereSurface, MbSpiralSurface и MbTorusSurface.

virtual double MbSurface::DistanceToCurve ( const MbCurve3D curve,
double &  u,
double &  v,
double &  t,
bool  tCalc = false 
) const [virtual]

Вычисляется минимальное расстояние между кривой и поверхностью. Определяются точки на поверхности и кривой, между которыми расстояние минимально.

Аргументы:
[in]curve- Заданная кривая.
[out]u- Координата вычисленной точки на поверхности.
[out]v- Координата вычисленной точки на поверхности.
[in,out]t- На входе - начальное приближение к искомой точке на кривой. На выходе - параметр вычисленной точки на кривой.
[in]tCalc- Флаг, показывающий, использовать ли t в качестве начального приближения.
Возвращает:
Минимальное расстояние между кривой и поверхностью.
virtual double MbSurface::DistanceToSurface ( const MbSurface surf1,
double &  u0,
double &  v0,
double &  u1,
double &  v1 
) const [virtual]

Вычисляется минимальное расстояние между двумя поверхностями. Определяются точки на поверхностях, между которыми расстояние минимально.

Аргументы:
[in]surf1- Заданная поверхность.
[out]u0- Координата вычисленной точки на текущей поверхности.
[out]v0- Координата вычисленной точки на текущей поверхности.
[out]u1- Координата вычисленной точки на заданной поверхности.
[out]v1- Координата вычисленной точки на заданной поверхности.
Возвращает:
Минимальное расстояние между поверхностями.
virtual size_t MbSurface::GetUPairs ( double  v,
SArray< double > &  u 
) const [virtual]

Вычислить значимые параметры u поверхности при заданном параметре v. В случае поверхности общего вида - минимальное и максимальное значения параметра u.

Аргументы:
[in]v- Заданный параметр.
[out]u- Множество значений u.
Возвращает:
Количество вычисленных значений u.

Переопределяется в MbCurveBoundedSurface и MbGridSurface.

virtual size_t MbSurface::GetVPairs ( double  u,
SArray< double > &  v 
) const [virtual]

Вычислить значимые параметры v поверхности при заданном параметре u. В случае поверхности общего вида - минимальное и максимальное значения параметра v.

Аргументы:
[in]u- Заданный параметр.
[out]v- Множество значений v.
Возвращает:
Количество вычисленных значений v.

Переопределяется в MbCurveBoundedSurface и MbGridSurface.

virtual void MbSurface::GetIsoclinal ( const MbVector3D nor,
SArray< MbCartPoint > &  uv 
) const [virtual]

Найти точки на поверхности, в которых касательная плоскость параллельна некоторой плоскости, имеющей нормаль nor.

Аргументы:
[in]nor- Вектор, задающий плоскость.
[out]uv- Множество параметров точек с искомой касательной.
void MbSurface::CopyGabarit ( const MbSurface s) [inline]

Скопировать из копии готовые метрические оценки, которые в оригинале не были расчитаны.

Предупреждения:
Для скорости проверка идентичности оригинала и копии не выполняется!
Аргументы:
[in]s- Поверхность-копия.
void MbSurface::CalculateRect ( const MbPlacement3D place,
MbRect rect 
) const

Выдать прямоугольный габарит поверхности в плоскости XOY плейсмента.

Аргументы:
[in]place- Заданный плейсмент.
[out]rect- Вычисленный прямоугольник.
virtual MbContour& MbSurface::MakeContour ( bool  sense) const [virtual]

Функция создает новый двумерный граничный контур. После использования объект надо удалить.

Аргументы:
[in]sense- Совпадает ли направление контура с направлением обхода против часовой стрелки.
Возвращает:
Граничный контур.

Переопределяется в MbCurveBoundedSurface и MbGridSurface.

virtual MbCurve& MbSurface::MakeSegment ( size_t  i,
bool  sense 
) const [virtual]

Функция создает сегмент граничного контура в соответствии с параметром i.
i = 0 - Отрезок границы при v = vmin
i = 1 - Отрезок границы при u = umax
i = 2 - Отрезок границы при v = vmax
i = 3 - Отрезок границы при u = umin
После использования объект надо удалить.

Аргументы:
[in]i- Номер сегмента.
[in]sense- Совпадает ли направление контура с направлением обхода против часовой стрелки.
Возвращает:
Граничная кривая.

Переопределяется в MbCurveBoundedSurface и MbGridSurface.

MbCurve& MbSurface::MakeCurve ( size_t  number1,
size_t  number2 
) const

Функция находит крайние точки поверхности с помощью функции GetLimitPoint и строит отрезок от точки с номером number1 до точки с номером number2. После использования объект надо удалить.

Аргументы:
[in]number1- Номер граничной точки поверхности.
[in]number2- Номер граничной точки поверхности.
Возвращает:
Граничная кривая.
void MbSurface::CalculatePolygon ( double  minPar,
double  maxPar,
double  constPar,
MbeParamDir  dir,
const MbStepData stepData,
MbPolygon3D polygon 
) const

В функции строится поверхностная кривая - отрезок вдоль выбранного направления и считается полигон, аппроксимирующий эту кривую.

Аргументы:
[in]minPar- Минимальное значение параметра по выбранному направлению.
[in]maxPar- Максимальное значение параметра по выбранному направлению.
[in]constPar- Значение второго параметра.
[in]dir- Выбранное направление.
dir == pd_DirU - расчет производится по параметру u, v = const.
dir == pd_DirV - расчет производится по параметру v, u = const.
[in]sag- Величина прогиба, определяющая точность аппроксимации.
[out]polygon- Насчитанный полигон.
virtual void MbSurface::CalculateSurfaceWire ( const MbStepData stepData,
size_t  beg,
MbMesh mesh,
size_t  uMeshCount = WIRE_MAX,
size_t  vMeshCount = WIRE_MAX 
) const [virtual]

В функции производится рассчет сетки для отрисовки поверхности.

Аргументы:
[in]sag- Величина прогиба, определяющая точность.
[in]beg- Номер первого узла, который попадет в сетку, по каждому из направлений. Для построения сетки для всей поверхности beg == 0.
[out]mesh- Насчитанный Фасетный объект.
[in]uMeshCount- Количество u-линий отрисовочной сетки.
[in]vMeshCount- Количество v-линий отрисовочной сетки.

Переопределяется в MbCornerSurface, MbCurveBoundedSurface и MbGridSurface.

virtual void MbSurface::GetTesselation ( const MbStepData stepData,
double  u1,
double  u2,
double  v1,
double  v2,
SArray< double > &  uu,
SArray< double > &  vv 
) const [virtual]

Определить разбивку параметрической области поверхности вертикалями и горизонталями при триангуляции.

Аргументы:
[in]stepData- Данные для вычисления шага при триангуляции.
[in]u1- Минимальное значение параметра u в области разбиения поверхности.
[in]u2- Максимальное значение параметра u в области разбиения поверхности.
[in]v1- Минимальное значение параметра v в области разбиения поверхности.
[in]v2- Максимальное значение параметра v в области разбиения поверхности.
[out]uu- Множество параметров разбиения по u.
[out]vv- Множество параметров разбиения по v.

Переопределяется в MbConeSurface, MbCurveBoundedSurface, MbCylinderSurface, MbEvolutionSurface, MbExpansionSurface, MbExplorationSurface, MbExtrusionSurface, MbFilletSurface, MbLoftedSurface, MbOffsetSurface, MbPlane, MbRevolutionSurface, MbRuledSurface, MbSectorSurface, MbSphereSurface, MbSpiralSurface, MbSplineSurface и MbTorusSurface.

void MbSurface::AddTesselation ( const MbStepData stepData,
MbeParamDir  dir,
double  u1,
double  u2,
double  v1,
double  v2,
SArray< double > &  uu,
SArray< double > &  vv 
) const

Определить разбивку параметрической области поверхности вертикалями и горизонталями. Добавить параметры в массив в направлении dir. Если массивы uu или vv не пустые, то элементы из них не удаляются, то есть происходит уточнение сетки в выбранном направлении.

Аргументы:
[in]stepData- Данные для вычисления шага при триангуляции.
[in]dir- Выбранное направление.
dir == pd_DirU - расчет производится по параметру u, v = const.
dir == pd_DirV - расчет производится по параметру v, u = const.
[in]u1- Минимальное значение параметра u в области разбиения поверхности.
[in]u2- Максимальное значение параметра u в области разбиения поверхности.
[in]v1- Минимальное значение параметра v в области разбиения поверхности.
[in]v2- Максимальное значение параметра v в области разбиения поверхности.
[out]uu- Множество параметров разбиения по u.
[out]vv- Множество параметров разбиения по v.
virtual void MbSurface::CalculateSurfaceGrid ( const MbStepData stepData,
bool  sense,
MbGrid grid 
) const [virtual]

Аппроксимировать поверхность треугольными пластинами.

Аргументы:
[in]stepData- Данные для вычисления шага при триангуляции.
[in]sense- Определяет совпадение нормалей поверхности и треугольников.
[out]grid- Результат разбиения.

Переопределяется в MbCurveBoundedSurface и MbGridSurface.

void MbSurface::CalculateMesh ( const MbStepData stepData,
const MbFormNote note,
MbMesh mesh 
) const

Аппроксимировать поверхность треугольными пластинами. Аппроксимируется лицевая сторона поверхности.

Аргументы:
[in]stepData- Данные для вычисления шага при триангуляции.
[in]note- Способ построения полигонального объекта.
[out]mesh- Результат разбиения.
virtual bool MbSurface::IsShift ( const MbSpaceItem obj,
MbVector3D dir,
bool &  isSame,
double  accuracy = LENGTH_EPSILON 
) const [virtual]

Определить, является ли объект смещением заданного объекта.

Аргументы:
[in]obj- Объект - образец.
[out]dir- Вектор смещения, если объект является смещением.
[out]isSame- На выходе true, если текущая поверхность и объект-образец идентичны.
Возвращает:
true - если поверхность является смещением.

Переопределяется в MbConeSurface, MbCylinderSurface, MbPlane, MbSphereSurface и MbTorusSurface.

virtual void MbSurface::CheckSurfParams ( double &  u,
double &  v 
) const [virtual]

Проверить параметры и загнать в область определения, если параметр вышел за полюс.

Аргументы:
[in]surface- Поверхность.
[in]u- Первый параметр.
[in]v- Второй параметр.

Переопределяется в MbLoftedSurface, MbMeshSurface, MbOffsetSurface и MbSplineSurface.

bool MbSurface::GetMatrix ( double  xMin,
double  xMax,
double  yMin,
double  yMax,
MbMatrix matr 
) const

Для поверхности устанавливается новый диапазон параметров. Геометрически поверхность не изменяется. Функция ищет матрицу преобразования для двумерных кривых на поверхности для перехода от старой параметризации к новой.

Аргументы:
[in]xMin- Новое минимальное значение параметра u.
[in]xMax- Новое максимальное значение параметра u.
[in]yMin- Новое минимальное значение параметра v.
[in]yMax- Новое максимальное значение параметра v.
[in]matr- Матрица преобразования.

Данные класса

MbCube MbSurface::cube [mutable, protected]

Габаритный куб поверхности рассчитывается только при запросе габарита объекта. Габаритный куб в конструкторе объекта и после модификации объекта принимает неопределенное значение.


Объявления и описания членов класса находятся в файле:
 Указатель Классы Пространства имен Файлы Функции Переменные Определения типов Перечисления Элементы перечислений Друзья Макросы