3D-Layer zu Feature-Class (ArcGIS 3D Analyst)
Zusammenfassung
Exportiert Feature-Layer mit definierten 3D-Eigenschaften in eine Multipatch-Feature-Class.
Verwendung
-
Nur Features, deren Rendering als Multipatch beibehalten werden kann, werden konvertiert, z. B. mit 3D-Markern symbolisierte Punkte. Texturfüllsymbole werden nicht unterstützt. Auch ArcMap-Layer werden nicht unterstützt, da sie keine 3D-Eigenschaften beibehalten.
-
Es werden nur bestimmte 3D-Eigenschaften angewendet, Beispiele:
- Punkten zugewiesene 3D-Symbole
- Linien zugewiesene 3D-Symbole
- Auf Polygone angewendete Extrusionen
- Nicht extrudierte Polygone mit Z-Werten
- Multipatches zugewiesene Texturreduzierung
-
Drapierte Layer in ArcGlobe werden nicht unterstützt. Aufgrund der Dynamik drapierter Oberflächen bleiben Höhenwerte nicht erhalten.
-
Füllsymbole mit Textur werden nicht unterstützt. Wenn ein Feature im Layer 3D-Markersymbole mit eingeschränkten Eigenschaften, z. B. Texturen, aufweist, wird das Feature nicht zur Ausgabe hinzugefügt.
Hinweis:Ein Feature-Layer mit 3D-Eigenschaften ist für die meisten Visualisierungsanwendungen geeignet und muss nicht in ein Multipatch konvertiert werden. Dagegen ist das Konvertieren des Layers in ein Multipatch besonders nützlich, wenn das Ergebnis-Multipatch für die weitere Bearbeitung in der Modelliersoftware eines Drittanbieters verwendet wird, oder wenn das Multipatch groß ist und in ArcGlobe als gecachter Layer verwendet würde.
Syntax
Parameter | Erläuterung | Datentyp |
in_feature_layer |
Der Eingabe-Feature-Layer, für den 3D-Eigenschaften definiert sind. | Feature Layer |
out_feature_class |
Die Ausgabe-Multipatch-Feature-Class. | Feature Class |
group_field (optional) |
Das Feld in der Eingabe-Feature-Class, das die Features definiert, die in das gleiche Multipatch-Feature kombiniert werden. Die resultierenden Attribute werden auf einen der Eingabedatensätze festgelegt. | Field |
Codebeispiel
Anhand des folgenden Beispiels wird die Verwendung dieses Werkzeugs im Python-Fenster veranschaulicht:
import arcpy
from arcpy import env
arcpy.CheckOutExtension("3D")
env.workspace = "C:/data"
arcpy.Layer3DToFeatureClass_3d("Points_3D.lyr", "Test.gdb/trees")
Im folgenden Beispiel wird die Verwendung dieses Werkzeugs in einem eigenständigen Python-Skript veranschaulicht:
'''****************************************************************************
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)