3D 图层转要素类 (3D Analyst)
摘要
将定义了 3D 属性的要素层导出到多面体要素类。
用法
-
仅转换可将渲染保留为多面体的要素,例如以 3D 标记符号化的点。不支持纹理填充符号,也不支持 ArcMap 图层,因为它们不会保留任何 3D 属性。
-
将仅应用某些 3D 属性,例如:
- 分配给点的 3D 符号
- 分配给线的 3D 符号
- 适用于面的拉伸
- 带 z 值的未拉伸面
- 分配给多面体的纹理缩减采样
-
不支持 ArcGlobe 中的叠加图层。由于叠加表面的动态性,将不会保留高度值。
-
不支持纹理填充符号。如果图层中的要素使用具有限制属性的 3D 标记符号(例如纹理),则不会将要素添加到输出中。
注:具有 3D 属性的要素图层可很好地处理大多数可视化应用程序并且不必转换为多面体。但是,如果生成的多面体用于第三方建模软件中的附加编辑,或者如果多面体较大且将在 ArcGlobe 中作为缓存的图层使用,则将图层转换为多面体特别有用。
语法
Layer3DToFeatureClass_3d (in_feature_layer, out_feature_class, {group_field})
参数 | 说明 | 数据类型 |
in_feature_layer |
定义了 3D 属性的输入要素图层。 | Feature Layer |
out_feature_class |
输出多面体要素类。 | Feature Class |
group_field (可选) |
输入要素类中标识将组合为同一多面体要素的要素的字段。生成的属性将被设置为其中一个输入记录。 | Field |
代码实例
Layer3DToFeatureClass 示例 1(Python 窗口)
下面的示例演示了如何在 Python 窗口中使用此工具:
import arcpy
from arcpy import env
arcpy.CheckOutExtension("3D")
env.workspace = "C:/data"
arcpy.Layer3DToFeatureClass_3d("Points_3D.lyr", "Test.gdb/trees")
Layer3DToFeatureClass 示例 2(独立脚本)
下面的示例演示了如何在独立 Python 脚本中使用此工具:
'''****************************************************************************
Name: Layer3DToFeatureClass Example
Description: This script demonstrates how to use the
Layer3DToFeatureClass tool to create multipatches from all
layers in a target workspace. The layer files are assumed to have
been saved wtih 3D rendering from ArcScene.
****************************************************************************'''
# Import system modules
import arcpy
from arcpy import env
import exceptions, sys, traceback
try:
# Obtain a license for the ArcGIS 3D Analyst extension
arcpy.CheckOutExtension("3D")
# Set environment settings
env.workspace = "C:/data"
# Use the ListFiles method to identify all layer files in workspace
if arcpy.ListFiles("*.lyr"):
for lyrFile in arcpy.ListFiles("*.lyr"):
# Set Local Variables
outFC = "Test.gdb/{0}".format(lyrFile[:-4]) #Strips '.lyr' from name
#Execute Layer3DToFeatureClass
arcpy.Layer3DToFeatureClass_3d(file, outFC)
else:
"There are no layer files in {0}.".format(env.workspace)
except arcpy.ExecuteError:
print arcpy.GetMessages()
except:
# Get the traceback object
tb = sys.exc_info()[2]
tbinfo = traceback.format_tb(tb)[0]
# Concatenate error information into message string
pymsg = 'PYTHON ERRORS:\nTraceback info:\n{0}\nError Info:\n{1}'\
.format(tbinfo, str(sys.exc_info()[1]))
msgs = 'ArcPy ERRORS:\n {0}\n'.format(arcpy.GetMessages(2))
# Return python error messages for script tool or Python Window
arcpy.AddError(pymsg)
arcpy.AddError(msgs)
环境
相关主题
许可信息
ArcGIS for Desktop Basic:需要 3D Analyst
ArcGIS for Desktop Standard:需要 3D Analyst
ArcGIS for Desktop Advanced:需要 3D Analyst
9/15/2013