Find the closest points between two curves. Closest points mean closest pairs of points, each pair consisting of a point on this, say P1, and a point on other curve, say P2. P1 and P2 are closest locally. Each pairs of closest points will be represented by the corresponding parameter values with respect to the two curves and the 3d points. A closest pair is also known as a pair of critical points of the distance function between points of the two curves. If the input parameter returnAllCriticalPoints is set to false, then the function will return only pairs with minimum distance. 
   Namespace:   Autodesk.Revit.DB  
  Assembly:   RevitAPI  (in RevitAPI.dll) Version: 18.0.0.0 (18.2.0.0) 
  Since:  2018.1 
Syntax
| C# | 
|---|
|  | 
| Visual Basic | 
|---|
|  | 
| Visual C++ | 
|---|
|  | 
Parameters
- otherCurve
-  Type:  Autodesk.Revit.DB Curve  
 The specified curve used to compute closest points to this curve.
- withinThisCurveBounds
-  Type:  System Boolean  
 If this parameter is true only the solutions that are between this curve bounds will be returned. This curve must be bound if this parameter is true.
- withinOtherCurveBounds
-  Type:  System Boolean  
 If this parameter is true only the solutions that are between other curve bounds will be returned. The other curve must be bound if this parameter is true.
- returnAllCriticalPnts
-  Type:  System Boolean  
 The input parameter returnAllCriticalPnts is used to tell if all the critical points of the distance function are to be returned.
- resultList
-  Type:  System.Collections.Generic IList   ClosestPointsPairBetweenTwoCurves   %  
 Output parameter that will contain the results collection.
Remarks
 The output list of closest points contains one entry for each pair of closest points. The following is the meaning of every ClosestPointsPairBetweenTwoCurves's members: 
 - XYZPointOnFirstCurve is the closest point on the first curve;
- XYZPointOnSecondCurve is the closest point on the second curve;
- ParameterOnFirstCurve is the raw (not normalized) parameter on the first curve
- ParameterOnSecondCurve is the raw (not normalized) parameter on the second curve
- Distance is the distance from the closest point on the first curve to the closest point on the second curve.
Exceptions
| Exception | Condition | 
|---|---|
| Autodesk.Revit.Exceptions ArgumentNullException | Thrown when otherCurve argument is null. Thrown when resultArray is null. | 
| Autodesk.Revit.Exceptions ArgumentsInconsistentException | Thrown when withinThisCurveBounds is true and this curve is unbounded. Thrown when withinOtherCurveBounds is true and other curve is unbounded. | 
| Autodesk.Revit.Exceptions InvalidOperationException | Thrown when the method failed. For example the problem has infinitely many solutions such as two parallel lines or two concentric circles, or in other singular cases that the method currently cannot handle, such as evaluating the closest points between a spline and a line, and the spline contains a flat segment (all points on the segment have zero curvature), and the closest points lie within that flat segment. |