YouTube | Facebook | X(Twitter) | RSS

地球の裏の緯度経度を求める

2016/9/1 (木)

Public Function GetBackLatLon(FromPoint As IPoint) As IPoint
    '入力座標が地理座標系でない場合、Nothingを返す
    If FromPoint.SpatialReference Is Nothing Then
        Set GetBackLatLon = Nothing
        Exit Function
    ElseIf Not TypeOf FromPoint.SpatialReference Is IGeographicCoordinateSystem Then
        Set GetBackLatLon = Nothing
        Exit Function
    End If
     
    Dim pPoint As IPoint
    Set pPoint = New Point
    Set pPoint.SpatialReference = FromPoint.SpatialReference
     
    '経度の計算
    If FromPoint.X > 0 Then
        pPoint.X = FromPoint.X - 180
    Else
        pPoint.X = FromPoint.X + 180
    End If
     
    '緯度の計算
    If FromPoint.Y > 0 Then
        pPoint.Y = FromPoint.Y - Abs(FromPoint.Y) * 2
    Else
        pPoint.Y = FromPoint.Y + Abs(FromPoint.Y) * 2
    End If
     
    Set GetBackLatLon = pPoint
 
End Function
  • この記事を書いた人

羽田 康祐

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

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