インターセクト 3D(Intersect 3D) (3D Analyst)
サマリ
クローズド マルチパッチフィーチャのジオメトリの交差部分を計算して、交差する体積からマルチパッチを、交差する平面からポリゴンを、または交差するエッジからラインを生成します。
図
使用法
-
この解析には、クローズド マルチパッチ ジオメトリが必要です。[クローズド 3D(Is Closed 3D)] ツールを使用すると、マルチパッチ フィーチャクラスにクローズド フィーチャが含まれているかどうかを判定できます。また、[閉じたマルチパッチの作成(Enclose Multipatch)] ツールを使用すると、マルチパッチ フィーチャのギャップを除去できます。
-
この解析に使用するデータは慎重に決定する必要があります。高度に詳細なフィーチャはきわめて複雑なジオメトリを生成する場合があり、頂点の合計数と方向が原因で表示パフォーマンスの問題が発生する可能性があります。
-
入力を 1 つ指定すると、そのマルチパッチ データセットのフィーチャの交差部分が計算されますが、2 つ指定すると、両方のデータセットのフィーチャの交差部分が特定され、1 つの入力のみで検出された交差部分は無視されます。
注意:2 つの入力フィーチャを使用する場合、両方のフィーチャの属性が出力で結合されます。
このツールは、3D フィーチャの解析機能を備えた 3D セット演算子です。セット演算子の種類と、その使用方法については、「3D セット演算子の使用」をご参照ください。
構文
パラメータ | 説明 | データ タイプ |
in_feature_class_1 |
交差するマルチパッチ フィーチャ。入力フィーチャが 1 つのみの場合 | Feature Layer |
in_feature_class_2 (オプション) |
1 つめのマルチパッチ フィーチャクラスと交差するオプションの 2 つめのマルチパッチ フィーチャ。 | Feature Layer |
out_feature_class |
出力フィーチャクラス。 | Feature Class |
output_geometry_type (オプション) |
ジオメトリが作成した交差のタイプを決定します。
| String |
コードのサンプル
次のサンプルは、Python ウィンドウでこのツールを使用する方法を示しています。
import arcpy
from arcpy import env
env.workspace = 'C:/data'
arcpy.Intersect3D_3d('inMultipatch1.shp', 'outMultipatch.shp',
'inMultipatch2.shp')
次のサンプルは、スタンドアロン Python スクリプトでこのツールを使用する方法を示しています。
'''****************************************************************************
Name: Intersect3D Example
Description: This script demonstrates how to use the
Intersect3D tool
****************************************************************************'''
# Import system modules
import arcpy
import exceptions, sys, traceback
from arcpy import env
try:
# Obtain a license for the ArcGIS 3D Analyst extension
arcpy.CheckOutExtension('3D')
# Set environment settings
env.workspace = 'C:/data'
# Set Local Variables
inMP1 = 'Boston_MP_Small.shp'
inMP2 = 'Boston_MP.shp'
# Ensure output has a unique name
outMP = arcpy.CreateUniqueName('Intersect.shp')
# Execute Intersect 3D
arcpy.Intersect3D_3d(inMP1, outMP, inMP2)
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)