摘要
对面轮廓中的尖角进行平滑处理以使制图更加美观或改善制图质量。
插图
用法
提供了两种平滑方法:
- 指数核的多项式近似 (PAEK) 方法(Python 中的 PAEK)可根据平滑容差对面进行平滑处理。每个面经过平滑处理后,其折点都可能比之前多。平滑容差参数可控制计算新折点时用到的“移动”路径的长度。长度越短,保留的细节越多,处理时间也越长。
- 贝塞尔插值方法(Python 中的 BEZIER_INTERPOLATION)对面进行平滑处理时无需使用容差,而是通过创建近似的贝塞尔曲线来匹配输入面。
使用输入障碍图层参数来标识不得被平滑面越过的要素。障碍要素可以是点、线或面。
处理大型数据集可能会超出内存限制。在这类情况下,考虑通过在制图分区环境设置中确定一个相关的面要素类来通过分区处理输入数据。将按顺序处理分区边界定义的数据部分。生成的要素类无缝,而且在分区边界一致。有关详细信息,请参阅使用分区概化大型数据集。
输出线要素类具有正确的拓扑。输入数据中的任何拓扑错误都会在输出线要素类中标记出来。输出要素类包括含有相应输入要素 ID 和输入拓扑错误的两个附加字段:InPoly_FID 和 SmoPgnFlag。SmoPgnFlag 值为 1 表示存在拓扑错误;值为 0 (零)表示不存在错误。
语法
SmoothPolygon_cartography (in_features, out_feature_class, algorithm, tolerance, {endpoint_option}, {error_option}, {in_barriers})
参数 | 说明 | 数据类型 |
in_features | 要平滑处理的面要素。 | Feature Layer |
out_feature_class | 要创建的输出面要素类。 | Feature Class |
algorithm | 指定平滑算法。
| String |
tolerance | 设置 PAEK 算法使用的容差。必须指定一个容差,且值必须大于零。可以指定首选单位;默认为要素单位。使用 BEZIER_INTERPOLATION 平滑算法时,必须输入 0 作为占位符。 | Linear Unit |
endpoint_option (可选) | 这是一个不再使用的旧参数。之前曾将其用于指定是否保留孤立面环的端点。为了脚本和模型的兼容性,工具语法中仍然包含此参数,但其已从工具对话框中隐藏。 指定是否保留孤立面环的端点。该选项仅适用于 PAEK 算法。
| Boolean |
error_option (可选) | 这是一个不再使用的旧参数。以前使用该参数来指定如何处理可能在处理过程中引入的拓扑错误。为了脚本和模型的兼容性,工具语法中仍然包含此参数,但其已从工具对话框中隐藏。 指定如何处理拓扑错误(可能是在该过程中引发的,如线的交叉或重叠)。
| String |
in_barriers [in_barriers,...] (可选) | 包含将充当平滑障碍的要素的输入。生成的平滑面不会接触或越过障碍要素。 | Feature Layer |
代码示例
SmoothPolygon 示例(Python 窗口)
以下 Python 窗口脚本演示了如何在即时模式下使用 SmoothPolygon 工具。
import arcpy
import arcpy.cartography as CA
arcpy.env.workspace = "C:/data"
CA.SmoothPolygon("soils.shp", "C:/output/output.gdb/smoothed_soils", "PAEK", 100)
SmoothPolygon 示例 2(独立脚本)
以下独立脚本演示了如何使用 SmoothPolygon 工具。
# Name: SmoothPolygon_Example2.py
# Description: Eliminate small islands before simplifying and smoothing lake boundaries
# Import system modules
import arcpy
import arcpy.cartography as CA
import arcpy.management as DM
# Set environment settings
arcpy.env.workspace = "C:/data/Portland.gdb/Hydrography"
# Set local variables
inLakeFeatures = "lakes"
barriers = "C:/data/Portland.gdb/Structures/buildings"
eliminatedFeatures = "C:/data/PortlandOutput.gdb/lakes_eliminated"
simplifiedFeatures = "C:/data/PortlandOutput.gdb/lakes_simplified"
smoothedFeatures = "C:/data/PortlandOutput.gdb/lakes_smoothed"
# Eliminate small islands in lake polygons.
DM.EliminatePolygonPart(inLakeFeatures, eliminatedFeatures, 100, "OR", 0,
"CONTAINED_ONLY")
# Simplify lake polygons.
CA.SimplifyPolygon(eliminatedFeatures, simplifiedFeatures, "POINT_REMOVE", 50,
200, "RESOLVE_ERRORS", "KEEP_COLLAPSED_POINTS", barriers)
# Smooth lake polygons.
CA.SmoothPolygon(simplifiedFeatures, smoothedFeatures, "PAEK", 100, "",
"FLAG_ERRORS", barriers)
环境
许可信息
- ArcGIS Desktop Basic: 否
- ArcGIS Desktop Standard: 是
- ArcGIS Desktop Advanced: 是