23 #if !defined(OPENNURBS_NURBSCURVE_INC_) 24 #define OPENNURBS_NURBSCURVE_INC_ 36 #if defined(ON_HAS_RVALUEREF) 94 unsigned int SizeOf()
const override;
97 ON__UINT32
DataCRC(ON__UINT32 current_remainder)
const override;
113 bool bIgnoreParameterization,
114 double tolerance = ON_ZERO_TOLERANCE
119 void Initialize(
void);
146 bool CreateClampedUniformNurbs(
151 double knot_delta = 1.0
165 bool CreatePeriodicUniformNurbs(
170 double knot_delta = 1.0
224 bool GetBBox(
double* boxmin,
double* boxmax,
bool bGrowBox =
false )
const override;
325 int Degree()
const override;
338 double tolerance = ON_ZERO_TOLERANCE
367 double tolerance = ON_ZERO_TOLERANCE
374 double tolerance = ON_ZERO_TOLERANCE
381 double tolerance = ON_ZERO_TOLERANCE
444 double cos_angle_tolerance=ON_DEFAULT_ANGLE_TOLERANCE_COSINE,
445 double curvature_tolerance=ON_SQRT_EPSILON
485 double point_tolerance=ON_ZERO_TOLERANCE,
486 double d1_tolerance=ON_ZERO_TOLERANCE,
487 double d2_tolerance=ON_ZERO_TOLERANCE,
488 double cos_angle_tolerance=ON_DEFAULT_ANGLE_TOLERANCE_COSINE,
489 double curvature_tolerance=ON_SQRT_EPSILON
606 double knot_tolerance=0.0,
663 double tolerance = 0.0,
769 ON::point_style CVStyle()
const;
861 int KnotMultiplicity(
872 const double* Knot()
const;
886 bool MakeClampedUniformKnotVector(
902 bool MakePeriodicUniformKnotVector(
910 double SuperfluousKnot(
914 double GrevilleAbcissa(
918 bool GetGrevilleAbcissae(
945 int knot_multiplicity
950 bool MakeNonRational();
957 int desired_dimension
964 bool ReserveCVCapacity(
967 bool ReserveKnotCapacity(
973 double ControlPolygonLength()
const;
980 bool ConvertSpanToBezier(
1009 bool IsSingular()
const;
1039 int RemoveSingularSpans();
1044 bool HasBezierSpans()
const;
1057 bool MakePiecewiseBezier(
1058 bool bSetEndWeightsToOne =
false 1079 bool ChangeEndWeights(
double w0,
double w1 );
1101 bool Reparameterize(
double c );
1132 int m_knot_capacity;
virtual bool IsClosed() const
Test a curve to see if it is closed.
virtual int SpanCount() const =0
Get number of nonempty smooth (c-infinity) spans in curve
virtual bool IsContinuous(ON::continuity c, double t, int *hint=nullptr, double point_tolerance=ON_ZERO_TOLERANCE, double d1_tolerance=ON_ZERO_TOLERANCE, double d2_tolerance=ON_ZERO_TOLERANCE, double cos_angle_tolerance=ON_DEFAULT_ANGLE_TOLERANCE_COSINE, double curvature_tolerance=ON_SQRT_EPSILON) const
Test continuity at a curve parameter value.
virtual bool GetNextDiscontinuity(ON::continuity c, double t0, double t1, double *t, int *hint=nullptr, int *dtype=nullptr, double cos_angle_tolerance=ON_DEFAULT_ANGLE_TOLERANCE_COSINE, double curvature_tolerance=ON_SQRT_EPSILON) const
Search for a derivatitive, tangent, or curvature discontinuity.
virtual int Dimension() const
Dimension of the object.
An ON_Arc is a subcurve of 3d circle.
Definition: opennurbs_arc.h:33
virtual bool GetBBox(double *boxmin, double *boxmax, bool bGrowBox=false) const
This is the virtual function that actually calculates axis aligned bounding boxes.
virtual bool IsArc(const ON_Plane *plane=nullptr, ON_Arc *arc=nullptr, double tolerance=ON_ZERO_TOLERANCE) const
Test a curve to see if the locus if its points is an arc or circle.
virtual bool SetStartPoint(ON_3dPoint start_point)
Force the curve to start at a specified point.
virtual int HasNurbForm() const
Does a NURBS curve representation of this curve.
virtual bool GetSpanVector(double *knots) const =0
Get number of parameters of "knots".
virtual bool MakeDeformable()
If possible, converts the object into a form that can be accuratly modified with "squishy" transforma...
virtual bool Reverse()=0
Reverse the direction of the curve.
virtual bool GetParameterTolerance(double t, double *tminus, double *tplus) const
Returns maximum algebraic degree of any span or a good estimate if curve spans are not algebraic...
virtual bool Extend(const ON_Interval &domain)
Pure virtual function. Default returns false. Where possible, analytically extends curve to include d...
ON_Curve is a pure virtual class for curve objects
Definition: opennurbs_curve.h:93
virtual int GetNurbForm(ON_NurbsCurve &nurbs_curve, double tolerance=0.0, const ON_Interval *subdomain=nullptr) const
Get a NURBS curve representation of this curve.
virtual int Degree() const =0
Returns maximum algebraic degree of any span or a good estimate if curve spans are not algebraic...
virtual bool IsPlanar(ON_Plane *plane=nullptr, double tolerance=ON_ZERO_TOLERANCE) const
Test a curve to see if it is planar.
virtual bool SwapCoordinates(int i, int j)
Swaps object coordinate values with indices i and j.
virtual bool GetNurbFormParameterFromCurveParameter(double curve_t, double *nurbs_t) const
Convert a curve parameter to a NURBS curve parameter.
virtual bool ChangeDimension(int desired_dimension)
Change the dimension of a curve.
virtual bool IsInPlane(const ON_Plane &test_plane, double tolerance=ON_ZERO_TOLERANCE) const =0
Test a curve to see if it lies in a specific plane.
bool Transform(const ON_Xform &xform) override
overrides virtual ON_Geometry::Transform(). ON_Curve::Transform() calls ON_Geometry::Transform(xform)...
virtual int IsPolyline(ON_SimpleArray< ON_3dPoint > *pline_points=nullptr, ON_SimpleArray< double > *pline_t=nullptr) const
Several types of ON_Curve can have the form of a polyline including a degree 1 ON_NurbsCurve, an ON_PolylineCurve, and an ON_PolyCurve all of whose segments are some form of polyline. IsPolyline tests a curve to see if it can be represented as a polyline.
virtual bool ChangeClosedCurveSeam(double t)
If this curve is closed, then modify it so that the start/end point is at curve parameter t...
Definition: opennurbs_point.h:648
virtual void Dump(ON_TextLog &) const
Creates a text dump of the object.
void EmergencyDestroy()
Sets m_user_data_list = 0.
virtual bool IsDeformable() const
ON_Curve & operator=(const ON_Curve &)
virtual bool IsPeriodic() const
Test a curve to see if it is periodic.
Definition: opennurbs_line.h:20
bool SetDomain(ON_Interval domain)
Set the domain of the curve.
virtual bool GetCurveParameterFromNurbFormParameter(double nurbs_t, double *curve_t) const
Convert a NURBS curve parameter to a curve parameter
virtual bool Trim(const ON_Interval &domain)
Removes portions of the curve outside the specified interval.
virtual bool SetEndPoint(ON_3dPoint end_point)
Force the curve to end at a specified point.
virtual bool Evaluate(double t, int der_count, int v_stride, double *v, int side=0, int *hint=0) const =0
This evaluator actually does all the work. The other ON_Curve evaluation tools call this virtual func...
Definition: opennurbs_bezier.h:150
Definition: opennurbs_nurbscurve.h:26
Definition: opennurbs_textlog.h:20
Definition: opennurbs_archive.h:1783
virtual bool Read(ON_BinaryArchive &binary_archive)
Low level archive writing tool used by ON_BinaryArchive::ReadObject().
Definition: opennurbs_point.h:460
bool IsValid(class ON_TextLog *text_log=nullptr) const override
Tests an object to see if its data members are correctly initialized.
virtual bool Write(ON_BinaryArchive &binary_archive) const
Low level archive writing tool used by ON_BinaryArchive::WriteObject().
virtual ON__UINT32 DataCRC(ON__UINT32 current_remainder) const
Returns a CRC calculated from the information that defines the object. This CRC can be used as a quic...
Definition: opennurbs_plane.h:20
unsigned int SizeOf() const override
virtual ON_Object::SizeOf override
virtual bool IsLinear(double tolerance=ON_ZERO_TOLERANCE) const
Test a curve to see if the locus if its points is a line segment.
Definition: opennurbs_point.h:46
virtual ON_Interval Domain() const =0
virtual bool Split(double t, ON_Curve *&left_side, ON_Curve *&right_side) const
Splits (divides) the curve at the specified parameter. The parameter must be in the interior of the c...