YouTube | Facebook | X(Twitter) | RSS

4 点ポイントから外接ポリゴンを作成する方法

2016/9/1 (木)

Public Function PointToPolygon(ByRef pFClass As IFeatureClass, ByRef pFLayer As IFeatureLayer2) As IPolygon
 
  '------ ポイントデータからITopologicalOperator::Convex Hullで外接ポリゴンを作成する -------------
 
  Dim pFeature As IFeature
  Dim pFCursor As IFeatureCursor
  Dim pPointColl As IPointCollection
 
  Set pFCursor = pFClass.Search(Nothing, True)
  Set pFeature = pFCursor.NextFeature
  Set pPointColl = New Polygon
 
  Do While Not pFeature Is Nothing
    pPointColl.AddPoint pFeature.Shape
    Set pFeature = pFCursor.NextFeature
 
  Loop
 
 
  Dim pGeometryColl As IGeometryCollection
  Dim pTopoOperator As ITopologicalOperator
 
  Set pGeometryColl = pPointColl
  Set pTopoOperator = pGeometryColl
 
 
  Dim pGeoDataset As IGeoDataset
  Dim pPolygon As IPolygon
 
  Set pGeoDataset = pFLayer
  Set pPolygon = New Polygon
  Set pPolygon.SpatialReference = pGeoDataset.SpatialReference
 
  pTopoOperator.Simplify  'SimplifyしないとIPolygonにセットできない
  Set pPolygon = pTopoOperator.ConvexHull
 
  Set PointToPolygon = pPolygon
 
End Function

関連記事

  • この記事を書いた人

羽田 康祐

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

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

WINGFIELD since1981をもっと見る

今すぐ購読し、続きを読んで、すべてのアーカイブにアクセスしましょう。

続きを読む