YouTube | Facebook | Twitter  Feed

指定した地点の TIN サーフェス高を取得

2016/9/1 (木)

Private Sub UIToolControl1_MouseDown(ByVal button As Long, ByVal shift As Long, ByVal x As Long, ByVal y As Long)
 
    Dim pMxApplication As IMxApplication
    Set pMxApplication = Application
     
    Dim pMxDocument As IMxDocument
    Set pMxDocument = ThisDocument
     
    Dim pTinLayer As ITinLayer
    Set pTinLayer = pMxDocument.FocusMap.Layer(0)
     
    'GetElevation
    Dim pTinSurface As ITinSurface
    Set pTinSurface = pTinLayer.Dataset
     
    Dim pPoint As IPoint
    Set pPoint = pMxApplication.Display.DisplayTransformation.ToMapPoint(x, y)
     
    Debug.Print pTinSurface.GetElevation(pPoint)
     
    'InterpolateZ
    Dim pTinSurface3 As ITinSurface3
    Set pTinSurface3 = pTinLayer.Dataset
    pTinSurface3.InterpolationMethod = esriLinearInterpolation
    Debug.Print pTinSurface3.InterpolateZ(pPoint.x, pPoint.y)
 
End Sub

関連記事

  • この記事を書いた人

羽田 康祐

Esri認定インストラクター、GIS上級技術者、測量士補、潜水士。GISy / GISc とその関連分野である地理学・地図学について日々の出来事で学んだ記憶を記録するためにブログを書いています。行動原理は伊達と酔狂。好きな地形は圏谷。好きな地図投影法はパースクインカンシャル図法。呉市生まれ広島市出身。GIS を使った自己紹介はこちら

-プログラミング, ArcGIS
-,

© 2020 WINGFIELD since1981