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

Контур на поверхности. Подробнее...

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

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

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

 MbContourOnSurface (const MbSurface &, const MbContour &, bool same)
 Конструктор по поверхности, контуру и флагу использования оригинала контура.
 MbContourOnSurface (const MbSurface &, int sense)
 Конструктор по поверхности и направлению обхода поверхности.
 VISITING_CLASS (MbContourOnSurface)
virtual MbeSpaceType IsA () const
 Получить тип объекта.
virtual MbeSpaceType Type () const
 Получить групповой тип объекта.
virtual MbSpaceItemDuplicate (MbRegDuplicate *=NULL) const
 Создать копию объекта.
virtual MbContourOnSurfaceCurvesDuplicate () 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 AddYourGabaritTo (MbCube &r) const
 Расширить присланный габаритный куб так, чтобы он включал в себя данный объект.
virtual void CalculateWire (const MbStepData &stepData, MbMesh &) const
 Создать полигональную копию.
virtual void Refresh ()
 Перевести все временные (mutable) данные объекта в неопределённое (исходное) состояние.
virtual void PrepareIntegralData (const bool forced) const
 Рассчитать временные (mutable) данные объекта.
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 GetTMax () const
 Вернуть максимальное значение параметра.
virtual double GetTMin () const
 Вернуть минимальное значение параметра.
virtual bool IsClosed () const
 Определить, является ли кривая замкнутой.
virtual void PointOn (double &t, MbCartPoint3D &) const
 Вычислить точку на кривой.
virtual void FirstDer (double &t, MbVector3D &) const
 Вычислить первую производную.
virtual void SecondDer (double &t, MbVector3D &) const
 Вычислить вторую производную.
virtual void ThirdDer (double &t, MbVector3D &) const
 Вычислить третью производную.
virtual void _PointOn (double t, MbCartPoint3D &) const
 Вычислить точку на кривой и её продолжении.
virtual void _FirstDer (double t, MbVector3D &) const
 Вычислить первую производную на кривой и её продолжении.
virtual void _SecondDer (double t, MbVector3D &) const
 Вычислить вторую производную на кривой и её продолжении.
virtual void _ThirdDer (double t, MbVector3D &) const
 Вычислить третью производную на кривой и её продолжении.
virtual void Explore (double &t, bool ext, MbCartPoint3D &pnt, MbVector3D &fir, MbVector3D *sec, MbVector3D *thir) const
 Вычислить значения точки и производных для заданного параметра.
virtual void Inverse (MbRegTransform *iReg=NULL)
 Изменить ориентацию контура относительно поверхности.
virtual MbNurbs3DNurbsCurve (const MbCurveIntoNurbsInfo &) const
 Построить NURBS копию кривой.
virtual MbCurve3DTrimmed (double t1, double t2, int sense) const
 Построить усеченную кривую.
virtual double Step (double t, double sag) const
 Вычислить шаг параметра.
virtual double DeviationStep (double t, double angle) const
 Вычислить шаг параметра.
virtual double GetMetricLength () const
 Вычислить метрическую длину кривой.
virtual double GetLengthEvaluation () const
 Вычислить метрическую длину кривой.
virtual double CalculateMetricLength () const
 Вычислить метрическую длину кривой.
virtual void CalculateGabarit (MbCube &) const
 Вычислить габарит кривой.
void SetDirtyGabarit () const
 Сбросить рассчитанный габарит.
const MbCubeGetGabarit () const
 Выдать габарит кривой.
virtual void CalculateUVLimits (MbRect &uvRect)
 Вычислить параметрический габарит контура.
virtual void ChangeCarrier (MbSpaceItem &item, MbSpaceItem &init)
 Изменить носитель. Для поверхностных кривых.
virtual bool ChangeCarrierBorne (MbSpaceItem &item, MbSpaceItem &init, const MbMatrix &matr)
 Изменить носитель.
virtual bool ChangeSurface (MbSurface &)
 Заменить поверхность контура.
void ChangeContour (MbContour &)
 Заменить двумерный контур.
virtual bool IsPlanar () const
 Является ли кривая плоской?
virtual bool IsSmoothConnected (double angleEps) const
 Являются ли стыки контура/кривой гладкими?
virtual bool GetPlaneCurve (MbCurve *&curve2d, MbPlacement3D &place3d, bool saveParams, VERSION version=Math::DefaultMathVersion()) const
 Дать плоскую кривую и плейсмент, если пространственная кривая плоская (после использования вызывать DeleteItem на двумерную кривую).
virtual bool GetSurfaceCurve (MbCurve *&curve2d, MbSurface *&surface, VERSION version=Math::DefaultMathVersion()) const
 Дать поверхностную кривую, если пространственная кривая поверхностная (после использования вызывать DeleteItem на аргументы).
virtual bool GetPlacement (MbPlacement3D &place, VERSION version=Math::DefaultMathVersion()) const
 Заполнить плейсемент, если кривая плоская.
virtual bool NearPointProjection (const MbCartPoint3D &, double &t, bool ext, MbRect1D *tRange=NULL) const
 Найти проекцию точки на кривую.
virtual bool IsStraight () const
 Является ли линия прямолинейной?
virtual MbCurveGetMap (const MbMatrix3D &, MbRect1D *pRgn=NULL, VERSION version=Math::DefaultMathVersion(), bool *coincParams=NULL) const
 Построить плоскую проекцию некоторой части пространственной кривой.
const MbSurfaceGetSurface () const
 Выдать базовую поверхность.
const MbContourGetContour () const
 Выдать двумерный контур.
const MbCurveGetSegment (size_t index) const
 Получить сегмент двумерного контура.
MbSurfaceSetSurface ()
 Выдать базовую поверхность для редактирования.
MbContourSetContour ()
 Выдать двумерный контур для редактирования.
MbCurveSetSegment (size_t index)
 Получить сегмент двумерного контура для редактирования.
size_t GetSegmentsCount () const
 Выдать количество сегментов контура.
MbContourContourDuplicate () const
 Выдать копию двумерного контура.
void SurfaceNormal (double t, MbVector3D &n) const
 Вычислить нормали к поверхности по параметру кривой.
ptrdiff_t FindSegment (double &t, double &tSeg) const
 Найти сегмент контура по параметру на контуре.
void FindCorner (ptrdiff_t index, MbCartPoint &) const
 Найти точку сегмента контура по индексу.
void FindCorner (ptrdiff_t index, MbCartPoint3D &) const
 Найти точку сегмента контура по индексу.
void AddSegment (MbCurve &newSegment)
 Добавить сегмент в контур.
void AddSegment (MbCurve &pBasis, double t1, double t2, int sense)
 Добавить сегмент в контур.
void AddSegment (MbSurfaceCurve &newSegment)
 Добавить сегмент в контур.
void AddSegment (MbSurfaceCurve &pBasis, double t1, double t2, int sense)
 Добавить сегмент в контур.
void GetSurfacePar (double &t, double &u, double &v) const
 Получить параметры поверхности по параметру на контуре.
void GetUPairs (double v, SArray< double > &u) const
 Вычислить U-пары от V.
void GetVPairs (double u, SArray< double > &v) const
 Вычислить V-пары от U.
double Area () const
 Вычислить площадь и ориентация контура относительно поверхности.
bool NormalizeOrientation ()
 Ориентировать контур против часовой стрелки.
MbeItemLocation PointClassification (const MbCartPoint &) const
 Классифицировать положение точки относительно контура.
double DistanceToBorder (const MbCartPoint &pnt, double &eps) const
 Вычислить параметрическое расстояние до ближайшей границы.
MbeItemLocation ContourClassification (const MbContourOnSurface &cntr, double precision=Math::metricPrecision) const
 Определить, находится ли контур cntr в области контура (известно, что контуры не пересекаются).
size_t SegmentIntersection (const MbCurve &pCurve, SArray< double > &tcontour, SArray< double > &tcurv) const
 Определить точки пересечения с двумерной кривой.
size_t SurfaceCurveIntersection (const MbSurfaceCurve &curv, SArray< double > &tcontour, SArray< double > &tcurv) const
 Определить точки пересечения с поверхностной кривой.
size_t ContourOnSurfaceIntersection (const MbContourOnSurface &cntr, SArray< double > &tcontour, SArray< double > &tcntr) const
 Определить точки пересечения с контуром на поверхности.
bool SetCurveEqual (const MbSpaceItem &)
 Сделать равным контур.
bool IsCurveEqual (const MbSpaceItem &) const
 Определить, являются ли объекты подобными.
bool CreateCubeTree (const size_t &indSegmMin, const size_t &indSegmMax) const
 Создать и инициализировать дерево габаритных кубов сегментов контура.

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

 MbContourOnSurface (const MbContourOnSurface &init, MbRegDuplicate *)
 Конструктор копирования.
 MbContourOnSurface (const MbContourOnSurface *)
 Конструктор копирования контура с той же поверхностью для CurvesDuplicate().
 MbContourOnSurface (const MbSurface &surf)
 Конструктор по поверхности.
void CalculateIncludePoints () const
 Посчитать параметрический габарит, сбросить временные данные, проверить замкнутость контура.
void DeleteCubeTree () const
void DeleteSearchTree () const

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

MbSurfacesurface
 Указатель на базовую поверхность (всегда не NULL).
MbContourcontour
 Указатель на 2D-контур в плоскости параметров поверхности (всегда не NULL).
double area
 Площадь 2D-контура со знаком.
MbCube cube
 Габаритный куб.
double metricLength
 Метрическая длина.
MbSegmentsSearchTree * searchTree
 Дерево габаритов для ускорения поиска сегментов.

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

Контур на поверхности представляет собой трёхмерную составную кривую, полученную движением вдоль двумерного контура MbContour, расположенного в пространстве параметров некоторой поверхности MbSurface.
Контур на поверхности используется: для описания области определения параметров поверхности.


Методы

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

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

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

Замещает MbCurve3D.

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

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

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

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

Замещает MbCurve3D.

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

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

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

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

Замещает MbCurve3D.

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

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

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

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

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

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

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

Замещает MbCurve3D.

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

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

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

Замещает MbCurve3D.

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

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

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

Замещает MbCurve3D.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Замещает MbCurve3D.

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

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

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

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

Замещает MbCurve3D.

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

virtual bool MbContourOnSurface::IsClosed ( ) const [virtual]

Определить, является ли кривая замкнутой.
Замкнутой считается кривая, если она циклична:

  • начальная и конечная точка кривой совпадают,
  • производные в начальной и конечной точке совпадают;
    если по своей природе кривая допускает изломы (контур, ломаная), то допускается не совпадение производных; у кривой Безье производные должны совпадать по направлению, но могут не совпадать по модулю.
Возвращает:
true, если кривая замкнута.

Замещает MbCurve3D.

virtual void MbContourOnSurface::PointOn ( double &  t,
MbCartPoint3D p 
) const [virtual]

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

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

Замещает MbCurve3D.

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

virtual void MbContourOnSurface::_PointOn ( double  t,
MbCartPoint3D p 
) const [virtual]

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

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

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

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

virtual void MbContourOnSurface::Explore ( double &  t,
bool  ext,
MbCartPoint3D pnt,
MbVector3D fir,
MbVector3D sec,
MbVector3D thir 
) const [virtual]

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

Аргументы:
[in]t- Параметр.
[in]ext- В пределах области определения (false), на расширенной кривой (true).
[out]pnt- Точка.
[out]fir- Производная.
[out]sec- Вторая производная по t, если не ноль.
[out]thir- Третья производная по t, если не ноль.

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

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

virtual MbNurbs3D* MbContourOnSurface::NurbsCurve ( const MbCurveIntoNurbsInfo nInfo) const [virtual]

Строит NURBS кривую, аппроксимирующую заданную в диапазоне параметров [t1, t2] с заданным направлением. По возможности, строит точную кривую, возможно с кратными узлами. Количеством узлов для NURBS определяется в зависимости от кривой.

Аргументы:
[in]t1- Параметр, соответствующий началу аппроксимируемой части кривой.
[in]t2- Параметр, соответствующий концу аппроксимируемой части кривой.
[in]sense- Совпадает ли направление возрастания параметра вдоль NURBS кривой с направлением на исходной кривой. sense > 0 - направление совпадает.
[in]nInfo- Параметры преобразования кривой в NURBS.
Возвращает:
Построенная NURBS кривая или NULL при неуспешном построении.

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

virtual MbCurve3D* MbContourOnSurface::Trimmed ( double  t1,
double  t2,
int  sense 
) const [virtual]

Строит усеченную кривую, начало которой соответствует точке с параметром t1 и конец - точке с параметром t2. Можно изменить направление полученной кривой относительно исходной с помощью параметра sense. Если кривая замкнута, можно получить усеченную кривую, проходящую через начало кривой.
В случае замкнутой или периодической кривой три параметра sense, t1 и t2 однозначно определяют результат. В случае разомкнутой кривой параметр sense и параметрами усечения должны соответствовать друг другу:
1) если sense == 1, то t1 < t2,
2) если sense == -1, то t1 > t2.
Если есть несоответствие между sense и параметрами усечения, то приоритетным параметром считается sense. Если параметры t1 и t2 равны и кривая замкнута, в результате должны получить замкнутую кривую.

Аргументы:
[in]t1- Параметр, соответствующий началу усеченной кривой.
[in]t2- Параметр, соответствующий концу усеченной кривой.
[in]sense- Направление усеченной кривой относительно исходной.
sense = 1 - направление кривой сохраняется. sense = -1 - направление кривой меняется на обратное.
Возвращает:
Построенная усеченная кривая.

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

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

virtual double MbContourOnSurface::Step ( double  t,
double  sag 
) const [virtual]

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

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

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

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

virtual double MbContourOnSurface::DeviationStep ( double  t,
double  ang 
) const [virtual]

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

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

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

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

virtual double MbContourOnSurface::GetLengthEvaluation ( ) const [virtual]

Длина кривой вычисляется неточно, на основе аппроксимации ломаной. Если нужна более точно вычисленная длина кривой, надо пользоваться функцией CalculateMetricLength().

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

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

virtual bool MbContourOnSurface::ChangeCarrierBorne ( MbSpaceItem item,
MbSpaceItem init,
const MbMatrix matr 
) [virtual]

Для поверхностных кривых. Заменяет текущий носитель item на новый, если возможно. Трансформирует носимый элемент по заданной матрице.

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

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

virtual bool MbContourOnSurface::NearPointProjection ( const MbCartPoint3D pnt,
double &  t,
bool  ext,
MbRect1D tRange = NULL 
) const [virtual]

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

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

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

virtual MbCurve* MbContourOnSurface::GetMap ( const MbMatrix3D into,
MbRect1D pRegion = NULL,
VERSION  version = Math::DefaultMathVersion(),
bool *  coincParams = NULL 
) const [virtual]

Построить плоскую проекцию некоторой части пространственной кривой.

Аргументы:
[in]into- Матрица преобразования из глобальной системы координат в видовую плоскость.
[in]pRegion- Отображаемая часть кривой (paramRegion.x = t1, paramRegion.y = t2), по умолчанию - вся кривая.
[in]version- Версия, по умолчанию - последняя.
[in,out]coincParams- Флаг совпадения параметризации исходной кривой и ее проекции
если coincParams != NULL, функция попытается сделать проекцию с совпадающей параметризацией
если в результате *coincParams = true, у проекции параметризация совпадает с параметрицацией исходной кривой.
Возвращает:
Двумерная проекция кривой.

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

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

size_t MbContourOnSurface::SegmentIntersection ( const MbCurve pCurve,
SArray< double > &  tcontour,
SArray< double > &  tcurv 
) const

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

Аргументы:
[in]pCurve- Кривая.
[out]tcontour- Массив параметров на контуре.
[out]tcurv- Массив параметров на кривой.
Возвращает:
Количество точек пересечения.
size_t MbContourOnSurface::SurfaceCurveIntersection ( const MbSurfaceCurve curv,
SArray< double > &  tcontour,
SArray< double > &  tcurv 
) const

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

Аргументы:
[in]curv- Кривая.
[out]tcontour- Массив параметров на контуре.
[out]tcurv- Массив параметров на кривой.
Возвращает:
Количество точек пересечения.
size_t MbContourOnSurface::ContourOnSurfaceIntersection ( const MbContourOnSurface cntr,
SArray< double > &  tcontour,
SArray< double > &  tcntr 
) const

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

Аргументы:
[in]cntr- Кривая.
[out]tcontour- Массив параметров на контуре.
[out]tcntr- Массив параметров на кривой.
Возвращает:
Количество точек пересечения.
bool MbContourOnSurface::CreateCubeTree ( const size_t &  indSegmMin,
const size_t &  indSegmMax 
) const

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

Аргументы:
[in]indSegmMin- Минимальный индекс сегмента в наборе для построения дерева габаритов.
[in]indSegmMax- Максимальный индекс сегмента в наборе для построения дерева габаритов.
Возвращает:
Результат создания и инициализации дерева.

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