YouTube | Facebook | Twitter  Feed

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

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

関連記事

  • この記事を書いた人

羽田 康祐

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

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

© 2020 WINGFIELD since1981