テレイン解像度範囲の変更(Change Terrain Resolution Bounds) (3D Analyst)
サマリ
指定したテレイン データセットでフィーチャクラスに適用するピラミッド レベルを変更します。
使用法
ピラミッド解像度範囲は、標高点として指定されていないサーフェス タイプでのみ割り当てることができます。
-
新しいピラミッドを使用する場合、または現在の範囲で表示パフォーマンスが十分でない場合は、テレイン フィーチャの解像度範囲を調整することを検討してください。
-
この操作を行っても、テレイン データセットは無効にはならないため、[Build Terrain(テレインの構築)] ツールを使用してテレイン データセットを再構築する必要はありません。
構文
ChangeTerrainResolutionBounds_3d (in_terrain, feature_class, {lower_pyramid_resolution}, {upper_pyramid_resolution}, {overview})
パラメータ | 説明 | データ タイプ |
in_terrain |
The input terrain dataset. | Terrain Layer |
feature_class |
テレインが参照するフィーチャクラスによって、そのピラミッド レベルの解像度が変更されます。 | String |
lower_pyramid_resolution (オプション) |
選択したフィーチャクラスの新しいピラミッド レベル解像度の下限です。 | Double |
upper_pyramid_resolution (オプション) |
選択したフィーチャクラスの新しいピラミッド レベル解像度の上限です。 | Double |
overview (オプション) | フィーチャクラスをテレイン データセットの概観図に適用するかどうかを指定します。
| Boolean |
コードのサンプル
ChangeTerrainResolutionBounds(テレイン解像度範囲の変更)の例 1(Python ウィンドウ)
The following sample demonstrates the use of this tool in the Python window:
import arcpy from arcpy import env arcpy.CheckOutExtension('3D') env.workspace = 'C:/data' arcpy.ChangeTerrainResolutionBounds_3d('sample.gdb/featuredataset/terrain', 'breaklines', 2.5, 7.5)
ChangeTerrainResolutionBounds(テレイン解像度範囲の変更)の例 2(スタンドアロン スクリプト)
The following sample demonstrates the use of this tool in a stand-alone Python script:
'''**************************************************************************** Name: Update Terrain Description: This script demonstrates how to update a terrain dataset with new elevation measurements obtained from Lidar by importing LAS files to multipoint features, then appending the new points to another multipoint feature that participates in a terrain. The terrain's pyramids are modified to optimize its draw speed. ****************************************************************************''' # Import system modules import arcpy from arcpy import env import exceptions, sys, traceback try: arcpy.CheckOutExtension("3D") # Set environment settings env.workspace = "C:/data" # Set Variables inTerrain = "sample.gdb/featuredataset/terrain" currentPts = "existing_points" lasFiles = ['las/NE_Philly.las', 'las/NW_Philly.las'] newPts = 'in_memory/update_pts' # Define spatial reference of LAS files using factory code # for NAD_1983_StatePlane_Pennsylvania_South lasSR = arcpy.SpatialReference() lasSR.factoryCode = 2272 lasSR.create() arcpy.AddMessage("Converting LAS files to multipoint features...") arcpy.ddd.LASToMultipoint(lasFiles, newPts, 1.5, 2, 1, 'INTENSITY', lasSR) arcpy.AddMessage("Appending LAS points to {0}..."\ .format(currentPts)) arcpy.AppendTerrainPoints_3d(inTerrain, currentPts, newPts) arcpy.AddMessage("Changing terrain pyramid reference scales...") arcpy.ddd.ChangeTerrainReferenceScale(inTerrain, 1000, 500) arcpy.ddd.ChangeTerrainReferenceScale(inTerrain, 2500, 2000) arcpy.AddMessage("Adding terrain pyramid level...") arcpy.ddd.AddTerrainPyramidLevel(inTerrain, "", "4 4500") arcpy.AddMessage("Changing pyramid resolution bounds for breaklines...") arcpy.ChangeTerrainResolutionBounds_3d(inTerrain, "breaklines", 5, 4) arcpy.AddMessage("Building terrain...") arcpy.ddd.BuildTerrain(inTerrain) arcpy.AddMessage("Completed updates.") 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) finally: arcpy.CheckInExtension("3D")
関連項目
ライセンス情報
ArcView: 必須 3D Analyst
ArcEditor: 必須 3D Analyst
ArcInfo: 必須 3D Analyst
7/10/2012