C3D Kernel  104598
Открытые члены | Защищенные члены
Класс MbCurveBoundedSurface

Ограниченная кривыми поверхность. Подробнее...

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

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

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

 MbCurveBoundedSurface (MbSurface &initSurface)
 Конструктор без установки пределов по u, v.
 MbCurveBoundedSurface (MbSurface &initSurface, double uin, double uax, double vin, double vax)
 Конструктор с установкой пределов по u, v.
 MbCurveBoundedSurface (MbSurface &initSurface, const MbRect &rect)
 Конструктор с установкой пределов по u, v.
 MbCurveBoundedSurface (MbSurface &initSurface, const MbRect2D &rect)
 Конструктор с установкой пределов по u, v.
 MbCurveBoundedSurface (MbSurface &initSurface, RPArray< MbContourOnSurface > &initCurves, bool sameContours)
 Конструктор с массивом контуров на поверхности.
 MbCurveBoundedSurface (MbSurface &initSurface, RPArray< MbContour > &initCurves, bool sameContours)
 Конструктор с массивом контуров на плоскости (двумерных контуров).
 MbCurveBoundedSurface (MbSurface &initSurface, std::vector< SPtr< MbContour > > &initCurves, bool sameContours)
 Конструктор с массивом контуров на плоскости (двумерных контуров).
 MbCurveBoundedSurface (MbSurface &initSurface, RPArray< MbContour > &initCurves, MbCube &gab)
 Конструктор для поверхности c габаритом при чтении грани.
 MbCurveBoundedSurface (MbContourOnSurface &init1, MbContourOnSurface *init2=NULL)
 Конструктор по контурам, берет за базовую поверхность поверхность первого контура.
 MbCurveBoundedSurface (const MbCurveBoundedSurface &init, MbSurface &newBaseSurface, bool calculateGabarit=true)
 Конструктор-копия на новую базовую поверхность.
 VISITING_CLASS (MbCurveBoundedSurface)
Общие функции геометрического объекта
virtual MbeSpaceType IsA () const
 Получить тип объекта.
virtual MbSpaceItemDuplicate (MbRegDuplicate *=NULL) const
 Создать копию объекта.
virtual bool IsSame (const MbSpaceItem &other, double accuracy=LENGTH_EPSILON) const
 Определить, являются ли объекты равными.
virtual bool SetEqual (const MbSpaceItem &)
 Сделать объекты равным, если они подобны.
virtual bool IsSimilar (const MbSpaceItem &) const
 Определить, являются ли объекты подобными.
virtual void Transform (const MbMatrix3D &, MbRegTransform *=NULL)
 Преобразовать объект согласно матрице.
virtual void Move (const MbVector3D &, MbRegTransform *=NULL)
 Сдвинуть объект вдоль вектора.
virtual void Rotate (const MbAxis3D &, double angle, MbRegTransform *=NULL)
 Повернуть объект вокруг оси на заданный угол.
virtual double DistanceToPoint (const MbCartPoint3D &) const
 Определить расстояние до точки.
virtual void Refresh ()
 Перевести все временные (mutable) данные объекта в неопределённое (исходное) состояние.
virtual void CalculateMesh (const MbStepData &stepData, const MbFormNote &note, MbMesh &mesh) const
 Построить полигональную копию mesh.
virtual void GetProperties (MbProperties &)
 Выдать свойства объекта.
virtual void SetProperties (const MbProperties &)
 Изменить свойства объекта.
virtual void GetBasisItems (RPArray< MbSpaceItem > &)
 Выдать базовые объекты в присланный контейнер.
virtual void GetBasisPoints (MbControlData3D &) const
 Выдать контрольные точки объекта.
virtual void SetBasisPoints (const MbControlData3D &)
 Изменить объект по контрольным точкам.
Функции описания области определения поверхности
virtual double GetUMin () const
 Вернуть минимальное значение параметра u.
virtual double GetVMin () const
 Вернуть минимальное значение параметра v.
virtual double GetUMax () const
 Вернуть максимальное значение параметра u.
virtual double GetVMax () const
 Вернуть максимальное значение параметра v.
virtual bool IsUClosed () const
 Определить, замкнута ли поверхность по параметру u.
virtual bool IsVClosed () const
 Определить, замкнута ли поверхность по параметру 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 bool GetPoleUMin () const
 Существует ли полюс на границе параметрической области.
virtual bool GetPoleUMax () const
 Существует ли полюс на границе параметрической области.
virtual bool GetPoleVMin () const
 Существует ли полюс на границе параметрической области.
virtual bool GetPoleVMax () const
 Существует ли полюс на границе параметрической области.
virtual bool IsPole (double u, double v) const
 Является ли точка полюсом.
Функции для работы в области определения поверхности

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

virtual void PointOn (double &u, double &v, MbCartPoint3D &) 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
 Вычислить производную нормали по U.
virtual void NormalV (double &u, double &v, MbVector3D &) const
 Вычислить производную нормали по V.
Функции для работы внутри и вне области определения поверхности

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

virtual void _PointOn (double u, double v, MbCartPoint3D &) 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 _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 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
 Вычислить шаг параметра.
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 num, MbCartPoint3D &) const
 Вычислить граничную точку.
virtual void GetLimitPoint (ptrdiff_t num, MbCartPoint &) const
 Вычислить двумерную граничную точку.
virtual double CurvatureU (double u, double v) const
 Вычислить кривизну линии вдоль u.
virtual double CurvatureV (double u, double v) const
 Вычислить кривизну линии вдоль v.
virtual bool IsSameBase (const MbSurface &) const
 Является ли базовая поверхность копией базовой поверхности данного объекта.
virtual bool IsPlanar () const
 Является ли поверхность плоской.
virtual double GetRadius () const
 Дать физический радиус объекта или ноль, если это невозможно.
virtual double GetFilletRadius (const MbCartPoint3D &) const
 Дать радиус скругления, если поверхность является поверхностью скругления.
virtual MbeParamDir GetFilletDirection () const
 Направление поверхности скругления.
virtual bool GetCylinderAxis (MbAxis3D &) const
 Дать ось вращения для поверхности.
virtual void ChangeCarrier (MbSpaceItem &item, MbSpaceItem &init)
 Изменение носителя.
virtual bool ChangeCarrierBorne (MbSurface &item, MbSurface &init, const MbMatrix &matr)
 Изменение носимых элементов.
virtual MbSplineSurfaceNurbsSurface (double u1, double u2, double v1, double v2, bool bmatch=false) const
 Построить NURBS копию усеченной поверхности.
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 &, bool bApprox=true) const
 Построить пространственную копию линии по параметрической линии.
virtual MbeItemLocation PointClassification (const MbCartPoint &, bool ignoreClosed=false) const
 Находятся ли точка в области, принадлежащей поверхности.
virtual double DistanceToBorder (const MbCartPoint &, double &eps) const
 Вычислить параметрическое расстояние до ближайшей границы.
virtual size_t CurveClassification (const MbCurve &curve, SArray< double > &tcurv, SArray< MbVector > &dir) const
 Определить точки пересечения кривoй с контурами поверхности.
size_t SegmentIntersection (const MbCurve &pCurve, SArray< double > &curveParams) const
 Определить точки пересечения с двумерной кривой.
virtual bool NearPointProjection (const MbCartPoint3D &p, double &u, double &v, bool ext, MbRect2D *uvRange=NULL) const
 Найти проекцию точки на поверхность.
virtual void DirectPointProjection (const MbCartPoint3D &p, const MbVector3D &vect, SArray< MbCartPoint > &uv, bool ext, MbRect2D *uvRange=NULL) const
 Найти все проекции точки на поверхность вдоль вектора в любом из двух направлений.
virtual void CurveIntersection (const MbCurve3D &curv, SArray< MbCartPoint > &uv, SArray< double > &tt, bool ext0, bool ext, bool touchInclude=false) 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, double precision=METRIC_PRECISION) const
 Определить, подобны ли поверхности для объединения.
virtual bool IsSpecialSimilarToSurface (const MbSurface &surf, VERSION version, double precision=METRIC_PRECISION) const
 Подобные ли поверхности для объединения (слива). Специальный случай. Для внутреннего использования.
virtual bool ProjectCurveOnSimilarSurface (const MbCurve3D &spaceCurve, const MbCurve &curve, const MbSurface &surfNew, MbCurve *&curveNew) const
 Построение проекции поверхностной кривой на совпадающую поверхность.
virtual bool GetMatrixToSurface (const MbSurface &surf, MbMatrix &matr, double precision=METRIC_PRECISION) const
 Дать двумерную матрицу преобразования из своей параметрической области в параметрическую область surf.
virtual ThreeStates Salient () const
 Определить, выпуклая ли поверхность.
virtual bool CreateNormalPlacements (const MbVector3D &axisZ, double angle, SArray< MbPlacement3D > &places) const
 Построить нормальные плейсменты конструктивных плоскостей.
virtual bool CreateTangentPlacements (const MbVector3D &axisZ, SArray< MbPlacement3D > &places) const
 Построить касательные плейсменты конструктивных плоскостей.
virtual void GetTesselation (const MbStepData &stepData, double u1, double u2, double v1, double v2, SArray< double > &uu, SArray< double > &vv) const
 Определить разбивку параметрической области поверхности вертикалями и горизонталями.
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.
virtual void CalculateGabarit (MbCube &) const
 Рассчитать габарит поверхности. Рекомендуется использовать GetGabarit.
virtual void CalculateLocalGabarit (const MbMatrix3D &, MbCube &) const
 Рассчитать габарит в локальной системе координат.
virtual void SetLimit (double u1, double v1, double u2, double v2)
 Установить пределы поверхности. Для внутреннего использования.
virtual void IncludePoint (double u, double 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, соответствующее единичной длине в пространстве.
virtual void CalculateSurfaceWire (const MbStepData &stepData, size_t beg, MbMesh &mesh, size_t uMeshCount=c3d::WIRE_MAX, size_t vMeshCount=c3d::WIRE_MAX) const
 Рассчитать сетку.
virtual size_t GetUMeshCount () const
 Выдать количество разбиений по u.
virtual size_t GetVMeshCount () const
 Выдать количество разбиений по v.
virtual bool IsLineU () const
 Проверить, что все производные поверхности по U выше первой равны нулю.
virtual bool IsLineV () const
 Проверить, что все производные поверхности по V выше первой равны нулю.
virtual MbContourMakeContour (bool sense) const
 Вернуть граничный двумерный контур.
virtual MbCurveMakeSegment (size_t i, bool sense) const
 Вернуть сегмент граничного двумерного контура.
virtual void CalculateSurfaceGrid (const MbStepData &stepData, bool sense, MbGrid &grid) const
 Аппроксимация поверхности треугольными пластинами.
Функции поверхности MbCurveBoundSurface
MbCurveMakeSegment (size_t number, size_t i, bool sense) const
 Дать граничную двумерную кривую.
const MbCurveGetSegment (size_t number, size_t i) const
 Дать граничную двумерную кривую.
MbCurveSetSegment (size_t number, size_t i)
 Дать граничную двумерную кривую.
size_t GetCurvesCount () const
 Выдать число контуров.
size_t GetSegmentsCount (size_t i) const
 Выдать число сегментов в контуре с номером i.
void AddOuterContour ()
 Добавить контур.
void DeleteContour (MbContourOnSurface *cntr)
 Удалить контур.
bool ChangeContour (size_t index, MbContourOnSurface *cntr)
 Заменить контур.
bool ChangeSurface (MbSurface &newsurf)
 Заменить базовую поверхность.
void NewBasisSurface ()
 Заменить базовую поверхность на ее копию.
void CalculateUVLimitsOnly ()
 Вычислить параметрические границы поверхности без сброса габарита.
void CalculateUVLimits ()
 Вычислить параметрические границы поверхности с пересчетом габарита.
void SetBasisSurfaceUVLimits ()
 Расширить параметрические границы базовой поверхности.
void CheckParam (double &u, double &v) const
 Проверить, входят ли параметры в параметрические границы поверхности.
double NormalizeCurvesOrientation ()
 Ориентировать ограничивающие контуры.
void DeleteCurves ()
 Удалить все контуры.
void AddCurve (MbContourOnSurface &contour)
 Добавить контур.
void AddCurve (MbContour &contour)
 Добавить контур.
void AddContour (MbContour &contour)
 Добавить контур.
const MbContourOnSurfaceGetCurve (size_t ind) const
 Дать контур, ограничивающий поверхность, по его индексу.
const MbContourOnSurface_GetCurve (size_t ind) const
 Дать контур, ограничивающий поверхность, по его индексу.
MbContourOnSurfaceSetCurve (size_t ind)
 Дать контур, ограничивающий поверхность, по его индексу.
MbContourOnSurface_SetCurve (size_t ind)
 Дать контур, ограничивающий поверхность, по его индексу.
void ReplaceOuterCurveBy (size_t ind)
 Переместить кривую с индексом ind в нулевую позицию массива.
bool ChangeCurve2D (MbCurve &oldCrv, MbCurve *newCrv)
 Найти двумерную кривую и заменить ее на другую.
void MergeSegments (double eps=Math::LengthEps)
 Слить двумерные сегменты в контурах.
MbCurveBoundedSurfaceCurvesDuplicate () const
 Копия объекта со старой базовой поверхностью.
bool CheckTouchByContour (bool byU) const
 Проверить на замкнутость по u или v по внешнему контуру.

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

 MbCurveBoundedSurface (const MbCurveBoundedSurface &init, MbRegDuplicate *)
 Конструктор копирования.
 MbCurveBoundedSurface (const MbCurveBoundedSurface *init)
 Конструктор копирования контуров с той же поверхностью (для CurvesDuplicate()).
bool CreateRectTree () const
 Создать и инициализировать дерево поиска.
void DeleteRectTree () const
 Удалить дерево поиска.
void DeleteSearchTree () const
 Удалить дерево поиска.

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

Поверхность, ограниченная замкнутыми контурами на поверхности MbContourOnSurface, представляет собой общий случай поверхности.
Областью определения параметров такой поверхности является связный кусок двумерной плоскости, который описывается одним внешним двумерным контуром и некоторым числом внутренних контуров.
Контур представляет собой составную замкнутую двумерную кривую. Каждый двумерный контур в совокупности с базовой поверхностью образует контур на поверхности MbContourOnSurface, который проходит по одному из краёв поверхности. Каждый контур описывает одну замкнутую границу поверхности.
Первый контур контейнера curves описывает внешнюю границу и содержит внутри все остальные контуры, которые описывают внутренние вырезы в поверхности.
Внутренние контуры не могут быть вложены друг в друга. Внутренние контуры лежат внутри внешнего контура.
В случае отсутствия вырезов внутри поверхности внутренние контуры отсутствуют. Контуры не пересекают друг друга и сами себя.
Контуры, описывающие область определения поверхности, могут выходить за область определения базовой поверхности basisSurface. При выходе за пределы области определения базовая поверхность basisSurface продолжается по своему закону изменения, как, например, элементарные поверхности, или - по касательной в общем случае.
Для правильной работы метода, определяющего положение параметров относительно границ поверхности, контуры должны быть ориентированы (метод NormalizeCurvesOrientation()). Если смотреть навстречу нормали поверхности с ориентированными контурами, то внешний контур на поверхности ориентирован против часовой стрелки, а внутренние контуры на поверхности ориентированы по часовой стрелке.
Ограниченная кривыми поверхность считается не замкнутой по обоим параметрам. Для периодической базовой поверхности область определения периодического параметра ограниченной кривыми поверхности может превышать период базовой поверхности. Базовой поверхностью для ограниченной кривыми поверхности не может служить другая ограниченная кривыми поверхность. В подобной ситуации выполняется переход к первичной базовой поверхности. Поверхность используется для построения граней тел в общем случае.


Методы

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

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

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

Замещает MbSurface.

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

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

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

Замещает MbSurface.

virtual bool MbCurveBoundedSurface::SetEqual ( const MbSpaceItem item) [virtual]

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

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

Замещает MbSurface.

virtual bool MbCurveBoundedSurface::IsSimilar ( const MbSpaceItem item) const [virtual]

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

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

Переопределяет метод предка MbSpaceItem.

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

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

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

Замещает MbSurface.

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

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

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

Замещает MbSurface.

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

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

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

Замещает MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::CalculateMesh ( const MbStepData stepData,
const MbFormNote note,
MbMesh mesh 
) const [virtual]

Построить полигональную копию данного объекта, представленную полигонами, или/и плоскими пластинами.

Аргументы:
[in]stepData- Данные для вычисления шага при построении полигонального.
[in]note- Способ построения полигонального объекта.
[in,out]mesh- Построенный полигональный объект.

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::GetProperties ( MbProperties properties) [virtual]

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

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

Замещает MbSurface.

virtual void MbCurveBoundedSurface::SetProperties ( const MbProperties properties) [virtual]

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

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

Замещает MbSurface.

virtual bool MbCurveBoundedSurface::IsUClosed ( ) const [virtual]

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

Замещает MbSurface.

virtual bool MbCurveBoundedSurface::IsVClosed ( ) const [virtual]

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

Замещает MbSurface.

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

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

Переопределяет метод предка MbSurface.

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

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

Переопределяет метод предка MbSurface.

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

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

Переопределяет метод предка MbSurface.

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

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

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::PointOn ( double &  u,
double &  v,
MbCartPoint3D p 
) const [virtual]

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

Аргументы:
[in]u- Первый параметр поверхности.
[in]v- Второй параметр поверхности.
[out]p- Вычисленная точка на поверхности.

Замещает MbSurface.

virtual void MbCurveBoundedSurface::_PointOn ( double  u,
double  v,
MbCartPoint3D p 
) const [virtual]

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

Аргументы:
[in]u- Первый параметр поверхности.
[in]v- Второй параметр поверхности.
[out]p- Вычисленная точка на поверхности.

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::Explore ( double &  u,
double &  v,
bool  ext,
MbCartPoint3D pnt,
MbVector3D uDer,
MbVector3D vDer,
MbVector3D uuDer,
MbVector3D vvDer,
MbVector3D uvDer,
MbVector3D nor 
) const [virtual]

Значения точки и производных вычисляются в пределах области определения и на расширенной поверхности.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
[in]ext- В пределах области определения (false), на расширенной поверхности (true).
[out]pnt- Точка.
[out]uDer- Производная по u.
[out]vDer- Производная по v.
[out]uuDer- Вторая производная по u, если не ноль.
[out]vvDer- Вторая производная по v, если не ноль.
[out]uvDer- Вторая производная по u и по v, если не ноль.

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::_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]

Значения точки и производных вычисляются на расширенной поверхности.

Аргументы:
[in]u- Параметр.
[in]v- Параметр.
[out]pnt- Точка.
[out]deru- Производная по u.
[out]derv- Производная по v.
[out]norm- Нормаль.
[out]noru- Производная нормали по u.
[out]norv- Производная нормали по v.
[out]deruu- Вторая производная по u.
[out]dervv- Вторая производная по v.
[out]deruv- Вторая производная по u и по v.

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::StepU ( double  u,
double  v,
double  sag 
) const [virtual]

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

Аргументы:
[in]u- Параметр, определяющий точку на поверхности.
[in]v- Параметр, определяющий точку на поверхности.
[in]sag- Максимально допустимая величина прогиба.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::StepV ( double  u,
double  v,
double  sag 
) const [virtual]

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

Аргументы:
[in]u- Параметр, определяющий точку на поверхности.
[in]v- Параметр, определяющий точку на поверхности.
[in]sag- Максимально допустимая величина прогиба.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::DeviationStepU ( double  u,
double  v,
double  angle 
) const [virtual]

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

Аргументы:
[in]u- Параметр, определяющий точку на поверхности.
[in]v- Параметр, определяющий точку на поверхности.
[in]ang- Максимально допустимый угол отклонения касательной.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::DeviationStepV ( double  u,
double  v,
double  angle 
) const [virtual]

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

Аргументы:
[in]u- Параметр, определяющий точку на поверхности.
[in]v- Параметр, определяющий точку на поверхности.
[in]ang- Максимально допустимый угол отклонения касательной.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::MetricStepU ( double  u,
double  v,
double  length 
) const [virtual]

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

Аргументы:
[in]u- Параметр, определяющий точку на поверхности.
[in]v- Параметр, определяющий точку на поверхности.
[in]len- Заданная метрическая длина.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::MetricStepV ( double  u,
double  v,
double  length 
) const [virtual]

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

Аргументы:
[in]u- Параметр, определяющий точку на поверхности.
[in]v- Параметр, определяющий точку на поверхности.
[in]len- Заданная метрическая длина.
Возвращает:
Величина шага по параметру в заданной точке.

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::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- Вычисленная точка.

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::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- Вычисленная точка.

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::CurvatureU ( double  u,
double  v 
) const [virtual]

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

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

Переопределяет метод предка MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

virtual double MbCurveBoundedSurface::GetRadius ( ) const [virtual]

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

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::ChangeCarrier ( MbSpaceItem item,
MbSpaceItem init 
) [virtual]

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

Переопределяет метод предка MbSurface.

virtual bool MbCurveBoundedSurface::ChangeCarrierBorne ( MbSurface item,
MbSurface init,
const MbMatrix matr 
) [virtual]

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

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

Переопределяет метод предка MbSurface.

virtual MbSplineSurface* MbCurveBoundedSurface::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, если при преобразовании нужно сохранить однозначное сответствие параметрических областей

Переопределяет метод предка MbSurface.

virtual MbSurface* MbCurveBoundedSurface::NurbsSurface ( const MbNurbsParameters uParam,
const MbNurbsParameters vParam 
) const [virtual]

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

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

Переопределяет метод предка MbSurface.

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

Переопределяет метод предка MbSurface.

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

Переопределяет метод предка MbSurface.

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

Переопределяет метод предка MbSurface.

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

Переопределяет метод предка MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

size_t MbCurveBoundedSurface::SegmentIntersection ( const MbCurve pCurve,
SArray< double > &  curveParams 
) const

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

Аргументы:
[in]pCurve- Кривая.
[out]curveParams- Массив параметров на кривой.
Возвращает:
Количество точек пересечения.
virtual bool MbCurveBoundedSurface::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 - если найдена проекция, удовлетворяющая всем входным условиям.

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::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- Диапазон изменения параметров, в котором надо найти решение.

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::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, то считать.

Переопределяет метод предка MbSurface.

virtual bool MbCurveBoundedSurface::IsSimilarToSurface ( const MbSurface surf,
double  precision = METRIC_PRECISION 
) const [virtual]

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

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

Переопределяет метод предка MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

virtual bool MbCurveBoundedSurface::GetMatrixToSurface ( const MbSurface surf,
MbMatrix matr,
double  precision = METRIC_PRECISION 
) const [virtual]

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

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

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::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.

Переопределяет метод предка MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

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

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

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

Переопределяет метод предка MbSurface.

virtual void MbCurveBoundedSurface::CalculateSurfaceWire ( const MbStepData stepData,
size_t  beg,
MbMesh mesh,
size_t  uMeshCount = c3d::WIRE_MAX,
size_t  vMeshCount = c3d::WIRE_MAX 
) const [virtual]

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

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

Переопределяет метод предка MbSurface.

virtual MbContour& MbCurveBoundedSurface::MakeContour ( bool  sense) const [virtual]

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

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

Переопределяет метод предка MbSurface.

virtual MbCurve& MbCurveBoundedSurface::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- Совпадает ли направление контура с направлением обхода против часовой стрелки.
Возвращает:
Граничная кривая.

Переопределяет метод предка MbSurface.

MbCurve& MbCurveBoundedSurface::MakeSegment ( size_t  number,
size_t  i,
bool  sense 
) const

Делает копию кривой.

Аргументы:
[in]number- Номер кривой
[in]i- Индекс сегмента
[in]sense- Признак совпадения направления кривой
const MbCurve* MbCurveBoundedSurface::GetSegment ( size_t  number,
size_t  i 
) const

Дать граничную двумерную кривую.

Аргументы:
[in]number- Номер кривой
[in]i- Индекс сегмента
MbCurve* MbCurveBoundedSurface::SetSegment ( size_t  number,
size_t  i 
)

Дать граничную двумерную кривую.

Аргументы:
[in]number- Номер кривой
[in]i- Индекс сегмента
void MbCurveBoundedSurface::AddOuterContour ( )

Создает контур, ограничивающий поверхность, если число контуров = 0

void MbCurveBoundedSurface::DeleteContour ( MbContourOnSurface cntr)

Удаляет указанный контур.

Аргументы:
[in]cntr- Удаляемый контур
bool MbCurveBoundedSurface::ChangeContour ( size_t  index,
MbContourOnSurface cntr 
)

Заменить контур.

Аргументы:
[in]index- Индекс изменяемого контура
[in]cntr- Новый контур
void MbCurveBoundedSurface::SetBasisSurfaceUVLimits ( )

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

void MbCurveBoundedSurface::CheckParam ( double &  u,
double &  v 
) const [inline]

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

double MbCurveBoundedSurface::NormalizeCurvesOrientation ( )

Ориентирует внешний контур против часовой стрелки, внутренние контуры - по часовой стрелки.

Возвращает:
Возвращает площадь параметрической области поверхности.
Предупреждения:
В конструкторах не вызывается, так как предполагается, что на вход поступает правильный набор контуров,
а сама функция ориентирования требует много времени на ее выполнение.
void MbCurveBoundedSurface::AddCurve ( MbContourOnSurface contour)

Добавить контур. После добавления нужно вызвать CalculateUVLimits().

void MbCurveBoundedSurface::AddCurve ( MbContour contour)

Добавить контур. После добавления нужно вызвать CalculateUVLimits().

void MbCurveBoundedSurface::AddContour ( MbContour contour) [inline]

Добавить контур. После добавления не нужно вызвать CalculateUVLimits().

const MbContourOnSurface* MbCurveBoundedSurface::GetCurve ( size_t  ind) const [inline]

Дать контур, ограничивающий поверхность, по его индексу. С проверкой индекса.

const MbContourOnSurface* MbCurveBoundedSurface::_GetCurve ( size_t  ind) const [inline]

Дать контур, ограничивающий поверхность, по его индексу. Без проверки индекса. Рекомендуется использовать функцию GetCurve с проверкой индекса.

MbContourOnSurface* MbCurveBoundedSurface::SetCurve ( size_t  ind) [inline]

Дать контур, ограничивающий поверхность, по его индексу. С проверкой индекса.

MbContourOnSurface* MbCurveBoundedSurface::_SetCurve ( size_t  ind) [inline]

Дать контур, ограничивающий поверхность, по его индексу. Без проверки индекса. Рекомендуется использовать функцию SetCurve с проверкой индекса.


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