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

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
  • URLをコピーしました!

この記事を書いた人

伊達と酔狂のGeospatial Communicator。GIS上級技術者、Esri認定インストラクター、CompTIA CTT+ Classroom Trainer、潜水士、PADIダイブマスター、四アマ。WordPress は 2.1 からのユーザーで歴だけは長い。代表著書に『"地図リテラシー入門―地図の正しい読み方・描き方がわかる』。日本地理学会賞(著作発信部門)受賞(2024年)。好きな地図投影法はパース・クインカンシャル図法とマクブライド・トーマス平極四次曲線図法。発言は個人の見解です。

ESRIジャパン株式会社所属、日本地図学会常任委員、青山学院大学非常勤講師兼務(2021年度~2023年度)、ストーリーマップ自己紹介、researchmapポートフォリオ

目次