3D 缓冲 (3D Analyst)

摘要

围绕点或线创建三维缓冲区以生成球形或圆柱形的多面体要素。

插图

3D 缓冲图示

使用情况

  • 此工具的输出是闭合多面体要素,可用于体积计算和其他 3D 集合操作工具。

  • 考虑指定一个简化值以提高复杂线要素(例如带有大量折点的曲线)的性能。

  • 如果线几何和缓冲距离生成折点密集的重叠区域,则此工具可能无法生成某些线要素的闭合多面体。一般来说,最好避开可能会导致在同一要素内创建重叠区域的缓冲距离。

参数

标注说明数据类型
输入要素

待缓冲的线或点要素。

Feature Layer
输出要素类

包含 3D 缓冲区的输出多面体。

Feature Class
Distance

输入要素的缓冲距离,可以是线性距离或从输入要素属性表中的数值字段获取。如果已通过输入字段指定缓冲距离,则将通过要素空间参考获得其测量单位。如果已将线性距离指定为数值,则支持以下测量单位:

  • 未知未知
  • 英寸英寸
  • 英尺英尺
  • 英里英里
  • 毫米毫米
  • 厘米厘米
  • 分米分米
  • 千米千米
Linear Unit; Field
联合类型
(可选)

线段折点之间的缓冲区形状。此参数只对线输入要素有效。

  • 平直折点之间的连接线形状是平直的。这是默认设置。
  • 圆形折点之间的连接线形状为圆形。
String
缓冲质量
(可选)

用于表示生成的多面体要素的线段数。默认为 20,但可输入 6 到 60 范围内的任何数字。缓冲质量值越高,生成的 3D 要素越平滑,但同时也会增加处理时间。

Long
简化(最大允许偏移量)
(可选)

简化输入线,方法是保持它们在其原始形态的指定偏移范围内的形状。如果未指定值,则不会进行简化。支持以下测量单位:

  • 未知未知
  • 英寸英寸
  • 英尺英尺
  • 英里英里
  • 毫米毫米
  • 厘米厘米
  • 分米分米
  • 千米千米
Linear Unit

arcpy.ddd.Buffer3D(in_features, out_feature_class, buffer_distance_or_field, {buffer_joint_type}, {buffer_quality}, {simplification_tolerance})
名称说明数据类型
in_features

待缓冲的线或点要素。

Feature Layer
out_feature_class

包含 3D 缓冲区的输出多面体。

Feature Class
buffer_distance_or_field

输入要素的缓冲距离,可以是线性距离或从输入要素属性表中的数值字段获取。如果已通过输入字段指定缓冲距离,则将通过要素空间参考获得其测量单位。如果已将线性距离指定为数值,则支持以下测量单位:

  • UNKNOWN未知
  • INCHES英寸
  • FEET英尺
  • YARDS
  • MILES英里
  • MILLIMETERS毫米
  • CENTIMETERS厘米
  • DECIMETERS分米
  • METERS
  • KILOMETERS千米
Linear Unit; Field
buffer_joint_type
(可选)

线段折点之间的缓冲区形状。此参数只对线输入要素有效。

  • STRAIGHT折点之间的连接线形状是平直的。这是默认设置。
  • ROUND折点之间的连接线形状为圆形。
String
buffer_quality
(可选)

用于表示生成的多面体要素的线段数。默认为 20,但可输入 6 到 60 范围内的任何数字。缓冲质量值越高,生成的 3D 要素越平滑,但同时也会增加处理时间。

Long
simplification_tolerance
(可选)

简化输入线,方法是保持它们在其原始形态的指定偏移范围内的形状。如果未指定值,则不会进行简化。支持以下测量单位:

  • UNKNOWN未知
  • INCHES英寸
  • FEET英尺
  • YARDS
  • MILES英里
  • MILLIMETERS毫米
  • CENTIMETERS厘米
  • DECIMETERS分米
  • METERS
  • KILOMETERS千米
Linear Unit

代码示例

Buffer3D 示例 1(Python 窗口)

下面的示例演示了如何在 Python 窗口中使用此工具。

arcpy.env.workspace = 'C:/data'
arcpy.Buffer3D_3d('lineFC.shp', 'buffer3d.shp', '15 Meters', 
                 'Round', 30, '1 Meters')
Buffer3D 示例 2(独立脚本)

下面的示例演示了如何在独立 Python 脚本中使用此工具。

'''****************************************************************************
Name: Buffer 3D Example
Description: This script demonstrates an application of
             the Buffer 3D and Inside 3D tools.
****************************************************************************'''
# Import system modules
import arcpy

# Set environment settings
arcpy.env.workspace = 'C:/data'

# Set Local Variables
inFC = 'lineFC.shp'
bufferOut = 'buffer3d.shp'

# Execute Buffer 3D
arcpy.Buffer3D_3d(inFC, bufferOut, '15 Meters', 'Round', '30', '1 Meters')
arcpy.Inside3D_3d(bufferOut, 'survey_pts.shp', 'inside_analysis.dbf')

许可信息

  • Basic: 需要 3D Analyst
  • Standard: 需要 3D Analyst
  • Advanced: 需要 3D Analyst

相关主题