ITopologicalOperator完成裁剪功能,该方法同样适用于文件类型的裁剪图层,也适用于鼠标绘制实现裁剪。
IGeometry outputGeometry = null; //裁剪后的图形
ITopologicalOperator2 topo = null;
if (sourceGeometry.SpatialReference != clipGeometry.SpatialReference) //sourceGeometry为被裁剪的图形
{
clipGeometry.Project(sourceGeometry.SpatialReference);
} //此处应保持裁剪与被裁剪图层的空间参考一致,否则容易发生异常
switch (sourceGeometry.GeometryType)
{
case esriGeometryType.esriGeometryPolyline:
topo = sourceGeometry as ITopologicalOperator2;
topo.IsKnownSimple_2 = true;
topo.Simplify();
outputGeometry = topo.Intersect(topo.Intersect(clipGeometry, esriGeometryDimension.esriGeometry1Dimension), esriGeometryDimension.esriGeometry1Dimension);
break;
case esriGeometryType.esriGeometryPolygon:
topo = sourceGeometry as ITopologicalOperator2;
topo.IsKnownSimple_2 = true;
topo.Simplify();
outputGeometry = topo.Difference(topo.Difference(clipGeometry));
break;
default:
outputGeometry = sourceGeometry;
break;
}
return outputGeometry;