需要 Spatial Analyst 许可。
摘要
通过向前函数定义水平成本系数和水平相对移动角度之间的关系。此函数只允许建立向前移动。
插图
说明
HfForward 对象用于 Spatial Analyst 工具路径距离、路径距离分配和路径距离回溯链接。
如果某段行程的水平相对移动角度 (HRMA) 小于 45 度,则将水平系数 (HF) 设置为与零系数相关联的值。当 HRMA 大于或等于 45 度且小于 90 度时,将 HF 设置为边值。如果 HRMA 大于或等于 90 度,则将 HF 设置为无穷大。
语法
HfForward ({zeroFactor}, {sideValue})
参数 | 说明 | 数据类型 |
zeroFactor | zeroFactor 将用于确定正向函数的 y 截距。 (默认值为 0.5) | Double |
sideValue | 确定为大于或等于 45 度且小于 90 度的 HRMA 指定的 HF 值。在上图中,sideValue 被指定为 1。 (默认值为 1.0) | Double |
属性
属性 | 说明 | 数据类型 |
zeroFactor (可读写) | zeroFactor 将用于确定函数的 y 截距。 当 HRMA 小于交角时,zeroFactor 将被指定为水平系数。 | Double |
sideValue (可读写) | 确定为大于或等于 45 度且小于 90 度的 HRMA 指定的 HF 值。在上图中,sideValue 被指定为 1。 | Double |
代码示例
演示如何创建 HfForward 类以及如何在 Python 窗口的 PathDistance 工具中使用该类。
import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
myHorizFactor = HfForward(0.5, 1.0)
outPathDist = PathDistance("sourcepts.shp", "costraster", "", "", myHorizFactor)
outPathDist.save("C:/sapyexamples/output/pathdisthff")
使用 HfForward 类执行 PathDistance 分析。
# Name: HfForward_Ex_02.py
# Description: Uses the HfForward object to execute the PathDistance tool.
# 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
inSourceData = "sourcepts.shp"
inCostRaster = "costraster"
# Create the HfForward Object
zeroFactor = 0.5
sideValue = 1.0
myHorizFactor = HfForward(zeroFactor, sideValue)
# Execute PathDistance
outPathDist = PathDistance(inSourceData, inCostRaster, "", "", myHorizFactor)
# Save the output
outPathDist.save("C:/sapyexamples/output/pathdisthff2")