Returns a point collection containing all points of intersection, in order along the ray.
[Visual Basic .NET] Public Sub Intersect ( _ ByVal targetGeometry As IGeometry, _ ByVal intersectionPoints As IPointCollection _ )
[C#] public void Intersect ( IGeometry targetGeometry, IPointCollection intersectionPoints );
[C++]
HRESULT Intersect(
IGeometry* targetGeometry,
IPointCollection* intersectionPoints
);
[C++]Parameters
targetGeometrytargetGeometry is a parameter of type IGeometry
intersectionPointsintersectionPoints is a parameter of type IPointCollection
Product Availability
Description
Implemented for Points, Multipoints, Polylines, Polygons, Envelopes, and Multipatches.
Remarks
This method is intended to be called against top-level geometries only (Point, Multipoint, Polyline, Polygon, Envelope, MultiPatch). To call this method against a Segment/Path or Ring, first add the part to a Polyline or Polygon container, respectively, and then call this method against the container.
public static void QueryPointsOfIntersection()
{
ILine
line =
new
LineClass();
line.FromPoint
= GetPoint();
line.ToPoint =
GetPoint();
IRay
ray =
new
RayClass();
ray.Origin =
line.FromPoint;
ray.Vector =
ConstructVector3D(line.ToPoint.X - line.FromPoint.X, line.ToPoint.Y
- line.FromPoint.Y, line.ToPoint.Z -
line.FromPoint.Z);
IGeometry multiPatchGeometry
= GetMultiPatchGeometry();
IPointCollection intersectionPointCollection = new MultipointClass();
ray.Intersect(multiPatchGeometry, intersectionPointCollection);
//intersectionPointCollection[0]
= (5, -2.13, 0.092)
//intersectionPointCollection[1]
= (1.612, -2.651, 7.012)
}
private static IPoint GetPoint()
{
const double Min = -10;
const double Max = 10;
Random random = new
Random();
double x =
Min + (Max - Min) * random.NextDouble();
double y = Min + (Max - Min) * random.NextDouble();
double z = Min + (Max - Min) * random.NextDouble();
IPoint
point =
ConstructPoint3D(x, y, z);
MakeZAware(point as
IGeometry);
return point;
}
private static IPoint ConstructPoint3D(double x, double y, double z)
{
IPoint point = ConstructPoint2D(x, y);
point.Z = z;
return
point;
}
private static IPoint ConstructPoint2D(double x, double y)
{
IPoint point = new PointClass();
point.PutCoords(x, y);
return point;
}
private static void MakeZAware(IGeometry geometry)
{
IZAware zAware = geometry as IZAware;
zAware.ZAware = true;
}
public static IVector3D ConstructVector3D(double xComponent, double yComponent, double zComponent)
{
IVector3D vector3D = new Vector3DClass();
vector3D.SetComponents(xComponent, yComponent, zComponent);
return vector3D;
}