zjf
2023-03-06 392b76515f40376b6d36f40a114850ef63650384
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/////////////////////////////////////////////////////////////////////////////// 
// Copyright (C) 2002-2016, Open Design Alliance (the "Alliance"). 
// All rights reserved. 
// 
// This software and its documentation and related materials are owned by 
// the Alliance. The software may only be incorporated into application 
// programs owned by members of the Alliance, subject to a signed 
// Membership Agreement and Supplemental Software License Agreement with the
// Alliance. The structure and organization of this software are the valuable  
// trade secrets of the Alliance and its suppliers. The software is also 
// protected by copyright law and international treaty provisions. Application  
// programs incorporating this software must include the following statement 
// with their copyright notices:
//   
//   This application incorporates Teigha(R) software pursuant to a license 
//   agreement with Open Design Alliance.
//   Teigha(R) Copyright (C) 2002-2016 by Open Design Alliance. 
//   All rights reserved.
//
// By use of this software, its documentation or related materials, you 
// acknowledge and accept the above terms.
///////////////////////////////////////////////////////////////////////////////
 
#ifndef OD_GECOMP3D_H
#define OD_GECOMP3D_H /*!DOM*/
 
#include "Ge/GeCurve3d.h"
#include "Ge/GeIntervalArray.h"
#include "Ge/GeCurve3dPtrArray.h"
#include "Ge/GeIntArray.h"
#include "OdPlatform.h"
 
#include "TD_PackPush.h"
 
/** \details
    This class represents composite curves in 3D space.
 
    \remarks
    Composite curves consists of pointers to any number of subcurves that
    are joined end to end. Each subcurve must be bounded.
 
    The parameter at the start of the composite curve is 0.0. The parameter at any
    point along the composite curve is the approximate length of the
    composite curve up to that point.
 
    Library: TD_Ge
 
    <group OdGe_Classes>
 
    \sa
    <link ge_OdGeCompositeCurve3d.html, Working with Composite Curves>
*/
class GE_TOOLKIT_EXPORT OdGeCompositeCurve3d : public OdGeCurve3d
{
public:
 
 
  /** \param curvelist [in]  Array of pointers to subcurves comprising the composite curve.
    \param subCurves [in]  Array of the subcurves comprising the composite curve 
    \param numSubCurves [in]  Number of subcurves.
    \param source [in]  Object to be cloned.
 
    \remarks
    The default constructor creates a composite curve that consists 
    of a single subcurve: a line segment from (0,0,0) to (1,0,0). 
  */
  OdGeCompositeCurve3d();
  OdGeCompositeCurve3d(const OdGeCompositeCurve3d& source);
  OdGeCompositeCurve3d(const OdGeCurve3dPtrArray& curveList);
 
  // TD Special :
  OdGeCompositeCurve3d(const OdGeCurve3d* subCurves, 
                       OdUInt32 numSubCurves);
 
  /** \details
  Returns an array of pointers to subcurves comprising the composite curve.
 
  \param curvelist [out]  Receives an array of pointers to subcurves comprising the composite curve.
  */
   void getCurveList(OdGeCurve3dPtrArray& curveList) const;
 
  /** \details
  Sets the curve list of the composite curve.
 
  \param curveList [in]  Array of pointers to subcurves comprising the composite curve.
  \param subCurves [in]  Array of the subcurves comprising the composite curve. 
  \param numSubCurves [in]  Number of subcurves.
  */
   OdGeCompositeCurve3d& setCurveList(const OdGeCurve3dPtrArray& curveList);
 
  // TD Special :
   OdGeCompositeCurve3d& setCurveList(const OdGeCurve3d* subCurves, 
                                             OdUInt32 number);
 
  /** \details
    Returns the parameter on a subcurve, and the index of that subcurve,
    corresponding to the specified parameter on the composite curve.
 
    \param param [in]  Parameter value on composite curve.
    \param crvNum [out]  Receives the curve number of the subcurve.
  */
   double globalToLocalParam(double param, int& crvNum) const; 
 
  /** \details
    Returns the parameter on the composite curve, corresponding
    to the specified parameter on the specifed subcurve.
 
    \param param [in]  Parameter value on the subcurve.
    \param crvNum [in]  Curve number of the subcurve.
  */
   double localToGlobalParam(double param, int crvNum) const; 
 
  /** \remarks
    All of the subcurves of the input curve are copied.         
  */
  OdGeCompositeCurve3d& operator =(const OdGeCompositeCurve3d& compCurve);
};
 
#include "TD_PackPop.h"
 
#endif