3D 线与多面体相交 (3D Analyst)
摘要
确定并返回线与多面体要素之间几何交集的数量。可选择性地将表示交集的点要素和表示在此类点分开的输入线的线要素写入输出要素类中。
插图
用法
-
此工具不支持 2D 线要素。因为要在 3D 欧氏空间中对 3D 要素执行求交计算,所以需要使用已启用 Z 值的线要素。通过依据属性实现要素转 3D,可将属性字段中存储了高度定义的 2D 线要素转换为 3D 线要素。
交点计数将在消息窗口中作为整数结果返回,并可在模型和脚本中用于建立后续操作的前提条件。
-
可选点输出用于表示输入线和多面体要素之间的交叉点,并包含下列属性:
- LINE_OID - 沿原始线找到交集的原始线 OBJECTID。
- MPATCH_OID - 在此处与线相交的多面体的 OBJECTID。
- DIST_3D - 沿原始线找到交集的 3D 距离。
-
可选线输出会在交点处对输入线要素进行分割,并包含下列属性:
- LINE_OID - 派生新线的原始线的 OBJECTID。
- FROM_MP_ID - 与线的起点相交的多面体要素的 OBJECTID。值 -1 用于表示线的起点不是交点。
- TO_MP_ID - 与线的终点相交的多面体的 OBJECTID。值 -1 用于表示线的起点不是交点。注:
如果线与多面体不相交,则直接将线复制到输出中,而且线的 FROM_MP_ID 和 TO_MP_ID 字段将值 -1 作为属性。
- DIST_3D - 沿原始线找到表示新线起点的相交位置的 3D 距离。
- LENGTH_3D - 此新线的 3D 长度。从原始线派生的各新线的长度总和将等于原始线的 3D 长度。
通过连接属性参数使用输出线要素类可在可选输出要素中引用原始线的属性值。
此工具是提供针对 3D 要素的分析函数的 3D 集合运算符。有关什么是集合运算符以及如何使用它们的详细信息,请参阅使用 3D 集合运算符。
语法
Intersect3DLineWithMultiPatch_3d (in_line_features, in_multipatch_features, {join_attributes}, {out_point_feature_class}, {out_line_feature_class})
参数 | 说明 | 数据类型 |
in_line_features |
要与多面体要素相交的线要素。 | Feature Layer |
in_multipatch_features |
要与线相交的多面体要素。 | Feature Layer |
join_attributes (可选) |
定义是否会将输入线要素的属性保留在输出线要素类中。
| String |
out_point_feature_class (可选) |
用于表示 3D 线和多面体之间交点的可选要素。 | Feature Class |
out_line_feature_class (可选) |
在与多面体要素的交点处对输入 3D 线进行分割的可选线要素。 | Feature Class |
代码实例
Intersect3DLineWithMultipatch 示例 1(Python 窗口)
下面的示例演示了如何在 Python 窗口中使用此工具:
import arcpy
from arcpy import env
arcpy.CheckOutExtension('3D')
env.workspace = 'C:/data'
arcpy.Intersect3DLineWithMultiPatch_3d('inLine.shp', 'inMultipatch.shp',
'IDS_ONLY', 'outPts.shp', 'outLine.shp')
Intersect3DLineWithMultipatch 示例 2(独立脚本)
下面的示例演示了如何在独立 Python 脚本中使用此工具:
'''****************************************************************************
Name: Intersect3DLineWithMultiPatch Example
Description: This script demonstrates how to
use the Intersect3DLine tool.
****************************************************************************'''
# Import system modules
import arcpy
import exceptions, sys, traceback
from arcpy import env
try:
# Obtain a license for the ArcGIS 3D Analyst extension
arcpy.CheckOutExtension('3D')
# Set environment settings
env.workspace = 'C:/data'
# Set Local Variables
inLineFC = 'sample.gdb/lines_3d'
inMP = 'sample.gdb/test_MP'
# Ensure a unique name is produced for output files
outPoint = arcpy.CreateUniqueName('OutPt_3DIntersect', 'sample.gdb')
outLine = arcpy.CreateUniqueName('OutLine_3DIntersect', 'sample.gdb')
# Execute Intersect 3D Line with Multipatch
arcpy.Intersect3DLineWithMultiPatch_3d(inLineFC, inMP, 'IDS_ONLY',
outPoint, outLine)
except arcpy.ExecuteError:
print arcpy.GetMessages()
except:
# Get the traceback object
tb = sys.exc_info()[2]
tbinfo = traceback.format_tb(tb)[0]
# Concatenate error information into message string
pymsg = 'PYTHON ERRORS:\nTraceback info:\n{0}\nError Info:\n{1}'\
.format(tbinfo, str(sys.exc_info()[1]))
msgs = 'ArcPy ERRORS:\n {0}\n'.format(arcpy.GetMessages(2))
# Return python error messages for script tool or Python Window
arcpy.AddError(pymsg)
arcpy.AddError(msgs)
环境
相关主题
许可信息
ArcGIS for Desktop Basic:需要 3D Analyst
ArcGIS for Desktop Standard:需要 3D Analyst
ArcGIS for Desktop Advanced:需要 3D Analyst
9/15/2013