Краткая информация
Создает полигональные контуры, представляющие двухмерную область объектов мультипатч.
Иллюстрация
Использование
Выходной контур будет содержать те же поля, что и входной объект, а также следующие:
- Z_Min – минимальное Z-значение из объекта-мультипатч.
- Z_Max – наибольшее Z-значение из объекта-мультипатч.
Используйте параметр Поле группы, если структура состоит из нескольких объектов, которые используют общий идентификатор в атрибутивной таблице.
Синтаксис
MultiPatchFootprint(in_feature_class, out_feature_class, {group_field})
Параметр | Объяснение | Тип данных |
in_feature_class | Объект-мультипатч, для которого создается контур. | Feature Layer |
out_feature_class | Выходной класс полигональных пространственных объектов с контурами. | Feature Class |
group_field (Дополнительный) | Поле, используемое для комбинирования объектов-мультипатч, что позволяет включать их в один полигон контура. | Field |
Пример кода
MultipatchFootprint, пример 1 (окно Python)
В следующем примере показано использование этого инструмента в окне Python.
import arcpy
from arcpy import env
arcpy.CheckOutExtension("3D")
env.workspace = "C:/data"
arcpy.MultiPatchFootprint_3d("multipatch.shp","multipatch_footprint.shp")
MultipatchFootprint, пример 2 (автономный скрипт)
В следующем примере показано использование этого инструмента в автономном скрипте Python.
'''****************************************************************************
Name: MultiPatchFootprint Example
Description: Creates footprint polygons for all multipatches in a workspace.
****************************************************************************'''
import arcpy
import exceptions, sys, traceback
from arcpy import env
try:
arcpy.CheckOutExtension('3D')
# Set environment settings
env.workspace = 'C:/data'
fcList = arcpy.ListFeatureClasses()
if fcList:
for fc in fcList:
# Determine if the feature class is a multipatch
desc = arcpy.Describe(fc)
if desc.shapeType is "MultiPatch":
outPoly = "{0}_Footprint.shp".format(desc.baseName)
#Execute MultiPatchFootprint
arcpy.ddd.MultiPatchFootprint(fc, outPoly)
arcpy.CheckInExtension('3D')
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)
Параметры среды
Информация о лицензиях
- Basic: Требуется 3D Analyst
- Standard: Требуется 3D Analyst
- Advanced: Требуется 3D Analyst