描述
基于三角形的边长度重新定义不规则三角网 (TIN) 的数据区或内插区。
插图
使用方法
此工具不会消除任何源数据。该工具通过将输入 TIN 的边进行重新分类为是否包含在插值区内来对其进行修改。如果希望保留要进行处理的 TIN 的未修改版本,请在运行该工具前考虑使用复制 TIN 工具创建副本数据集。
在边长分类开始之前,将对所有三角形边进行求值。这可有效撤消任何现有的数据区分类。如果从某一执行过程中获得的结果不尽如人意,则可在无需获得原始数据的情况下再次执行生成的 TIN。
通过此工具,可以从 TIN 的有效数据区中移除由 TIN 的源测量中的凹特征生成的极端边长。有一条边大于最大边长的三角形将被掩膜为 NoData 区域。
注:
最大边长值最好由被视为有效数据区的区域内 TIN 结点的平均间距来确定。因此请提供一个大于平均间距的值。若要更好地应用该工具,则需了解用于创建 TIN 的数据。
方法用于确定要计算的三角形。
注:
如果凹数据部分被归为 TIN 的外部端点,则可以使用周长边(Python 中为 method = "PERIMETER_ONLY")。
语法
DelineateTinDataArea(in_tin, max_edge_length, {method})
参数 | 说明 | 数据类型 |
in_tin | 待处理的 TIN 数据集。 | TIN Layer |
max_edge_length | 用于在 TIN 数据区中定义 TIN 三角形边的最大长度的二维距离。如果三角形的一个或多个边大于此值,则会将其视为处于 TIN 插值区之外,并且不会在地图中进行渲染或用于表面分析。 | Double |
method (可选) | 描绘 TIN 数据区时将对 TIN 边进行求值。
| String |
派生输出
名称 | 说明 | 数据类型 |
derived_out_tin | 更新后的 TIN。 | TIN 图层 |
代码示例
下面的示例演示了如何在 Python 窗口中使用此工具。
arcpy.env.workspace = "C:/data"
arcpy.DelineateTinDataArea_3d("elevation", 10, "PERIMETER_ONLY")
下面的示例演示了如何在独立 Python 脚本中使用此工具。
'''****************************************************************************
Name: Define Data Boundary of LAS File
Description: This script demonstrates how to delineate data boundaries of
LAS files with irregularly clustered points. It is intended for
use as a script tool with one input LAS file.
****************************************************************************'''
# Import system modules
import arcpy
# Set local variables
inLas = arcpy.GetParameterAsText(0) # input LAS file
ptSpacing = arcpy.GetParameterAsText(1) # LAS point spacing
classCode = arcpy.GetParameterAsText(2) # List of integers
returnValue = arcpy.GetParameterAsText(3) # List of strings
outTin = arcpy.GetParameterAsText(4) # TIN created to delineate data area
outBoundary = arcpy.GetParameterAsText(5) # Polygon boundary file
try:
# Execute LASToMultipoint
lasMP = arcpy.CreateUniqueName('lasMultipoint', 'in_memory')
arcpy.ddd.LASToMultipoint(inLas, LasMP, ptSpacing, class_code,
"ANY_RETURNS", "", sr, inFormat, zfactor)
# Execute CreateTin
arcpy.ddd.CreateTin(outTin, sr, "{0} Shape.Z masspoints"\
.format(lasMP), "Delaunay")
# Execute CopyTin
arcpy.ddd.CopyTin(outTin, "{0}_copy".format(outTin))
# Execute DelineateTinDataArea
maxEdge = ptSpacing * 4
arcpy.ddd.DelineateTinDataArea(outTin, maxEdge, "PERIMETER_ONLY")
# Execute TinDomain
arcpy.ddd.TinDomain(outTin, outBoundary, "POLYGON")
except arcpy.ExecuteError:
print(arcpy.GetMessages())
except Exception as err:
print(err)
环境
许可信息
- Basic: 需要 3D Analyst
- Standard: 需要 3D Analyst
- Advanced: 需要 3D Analyst