YouTube | Facebook | X(Twitter) | RSS

ネットワーク データセットの範囲指定ビルド

2016/9/1 (木)

Public Sub Build()
 
On Error GoTo Error:
 
    Dim pMxDocument As IMxDocument
    Set pMxDocument = ThisDocument
 
    Dim pMap As IMap
    Set pMap = pMxDocument.FocusMap
     
    Dim pSelection As ISelection
    Set pSelection = pMap.FeatureSelection
     
    Dim pEnumFeature As IEnumFeature
    Set pEnumFeature = pSelection
    pEnumFeature.Reset
     
    Dim pFeature As IFeature
    Set pFeature = pEnumFeature.Next
     
    Dim pGeometryBag As IGeometryBag
    Set pGeometryBag = New GeometryBag
    Dim pGeometryCollection As IGeometryCollection
    Set pGeometryCollection = pGeometryBag
     
     
    Do Until pFeature Is Nothing
     
        pGeometryCollection.AddGeometry pFeature.Shape
     
        Set pFeature = pEnumFeature.Next
    Loop
     
     
    'レイヤ
    Dim pNetworkLayer As INetworkLayer
    Set pNetworkLayer = pMxDocument.FocusMap.Layer(InputBox("ネットワーク レイヤのインデックス番号を指定してください(最上位=0)"))
     
    Dim pNetworkDataset As INetworkDataset
    Set pNetworkDataset = pNetworkLayer.NetworkDataset
     
    Dim pNetworkBuild As INetworkBuild
    Set pNetworkBuild = pNetworkDataset
     
    Dim pEnvelope As IEnvelope
    Set pEnvelope = pNetworkBuild.BuildNetwork(pGeometryBag.Envelope)
     
    MsgBox "Done"
     
    Exit Sub
     
Error:
     
    MsgBox Err.Description
    Debug.Print Err.Description
 
End Sub
  • この記事を書いた人

羽田 康祐

伊達と酔狂のGISエンジニア。GIS上級技術者、Esri認定インストラクター、CompTIA CTT+ Classroom Trainer、潜水士、PADIダイブマスター、四アマ。WordPress は 2.1 からのユーザーで歴だけは長い。 代表著書『"地図リテラシー入門―地図の正しい読み方・描き方がわかる』 GIS を使った自己紹介はこちら。ESRIジャパン(株)所属、元青山学院大学非常勤講師を兼務。日本地図学会第31期常任委員。発言は個人の見解です。

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