细化 (Spatial Analyst)

摘要

通过减少表示要素宽度的像元数来对栅格化的线状要素进行细化。

用法

语法

Thin (in_raster, {background_value}, {filter}, {corners}, {maximum_thickness})
参数说明数据类型
in_raster

要进行细化的输入栅格。

必须为整型。

Raster Layer
background_value
(可选)

指定用于识别背景像元的像元值。线状要素将基于前景单元生成。

  • ZERO 背景由 0 像元、less 像元或 NoData 像元组成。值大于 0 的所有像元均为前景像元。
  • NODATA 背景由 NoData 单元组成。所有具备有效值的单元均属于前景单元。
String
filter
(可选)

指定是否要在细化的第一阶段使用过滤器。

  • NOFILTER 不应用过滤器。 这是默认设置。
  • FILTER 将过滤栅格以平滑前景像元和背景像元间的边界。此选项将排除输出栅格中次要的不规则内容。
Boolean
corners
(可选)

指定在转弯处或交汇点处使用圆拐角还是尖拐角。

在样条化曲线或创建尖交点和拐角等矢量转换过程中,同样会使用此选项。

  • ROUND 尝试对拐角处和交汇点处进行平滑。对等值线或河流等自然要素进行矢量化时,最好选中此选项。
  • SHARP 尝试保留直角拐角和交汇点。对街道等人造要素进行矢量化时,最好选中此选项。
String
maximum_thickness
(可选)

输入栅格中线状要素的最大线宽(以地图单位表示)。

默认线宽是像元大小的十倍。

Double

返回值

名称说明数据类型
out_raster

细化的输出栅格。

Raster

代码示例

“细化”示例 1(Python 窗口)

本例对背景值为 NoData 的栅格进行细化,并在尝试保留拐角和交汇点的同时对边界进行平滑处理。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
thinOut = Thin("land","NODATA", "FILTER", "SHARP", 300)
thinOut.save("c:/sapyexamples/output/thinout")
“细化”示例 2(独立脚本)

本例对背景值为 NoData 的栅格进行细化,并在尝试保留拐角和交汇点的同时对边界进行平滑处理。

# Name: Thin_Ex_02.py
# Description: Thins rasterized linear features by 
#              reducing the number of cells 
#              representing the width of the features.
# Requirements: Spatial Analyst Extension

# Import system modules
import arcpy
from arcpy import env
from arcpy.sa import *

# Set environment settings
env.workspace = "C:/sapyexamples/data"

# Set local variables
inRaster = "land"
tolerance = 300

# Check out the ArcGIS Spatial Analyst extension license
arcpy.CheckOutExtension("Spatial")

# Execute Thin
thinOut = Thin(inRaster, "NODATA", "FILTER", "SHARP", tolerance)

# Save the output 
thinOut.save("c:/sapyexamples/output/thinoutput")

环境

相关主题

许可信息

ArcView: 需要 Spatial Analyst
ArcEditor: 需要 Spatial Analyst
ArcInfo: 需要 Spatial Analyst

7/10/2012