データ フレーム間でレンダラーのコピー

'コピー元のデータフレーム(1番目)とコピー先のデータフレーム(2番目)
'レイヤ数とその順序は同じであること
'フィーチャレイヤのみ追加されていること(ラスタやTIN、グループレイヤなどが含まれていないこと)
 
Sub CopyRenderer()
 
    Dim pMxDoc As IMxDocument
    Set pMxDoc = ThisDocument
     
    'Mapsの取得
    Dim pMaps As IMaps
    Set pMaps = pMxDoc.Maps
     
    'Map(データフレーム)の取得
    Dim pMapFrom As IMap
    Set pMapFrom = pMaps.Item(0)
     
    Dim pMapTo As IMap
    Set pMapTo = pMaps.Item(1)
     
    Dim i As Integer
    Dim pLayerFrom As IGeoFeatureLayer
    Dim pLayerTo As IGeoFeatureLayer
     
    For i = 0 To pMapFrom.LayerCount - 1
         
        'コピー元、コピー先レイヤ取得
        Set pLayerFrom = pMapFrom.Layer(i)
        Set pLayerTo = pMapTo.Layer(i)
         
        'レンダラのコピー
        Set pLayerTo.Renderer = pLayerFrom.Renderer
     
    Next i
     
     
    'TOCの更新
    pMxDoc.UpdateContents
 
End Sub
  • URLをコピーしました!

この記事を書いた人

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

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

目次