Heim >Backend-Entwicklung >Golang >Überprüfen Sie, ob ein Breiten-/Längengradpunkt innerhalb einer Region liegt

Überprüfen Sie, ob ein Breiten-/Längengradpunkt innerhalb einer Region liegt

WBOY
WBOYnach vorne
2024-02-06 09:24:091137Durchsuche

Überprüfen Sie, ob ein Breiten-/Längengradpunkt innerhalb einer Region liegt

Frageninhalt

Ich versuche eine Möglichkeit zu finden, zu überprüfen, ob sich ein Paar Breiten-/Längenkoordinaten innerhalb einer Region befindet (generiert aus anderen Breiten-/Längenkoordinaten).

Zum Beispiel, wenn meine Fläche ein Rechteck ist, das mit diesen Koordinaten generiert wurde:

43.672162 , -79.43585
43.629845 , -79.314585

Ich möchte überprüfen, ob diese Koordinaten innerhalb des Bereichs liegen: 43.651989,-79.371993

Ich habe versucht, dieses Paket zu verwenden, konnte es aber nicht zum Laufen bringen: github.com/kellydunn/golang-geo

p1 := geo.NewPoint(coords[0].LatX, coords[0].LonX)
p2 := geo.NewPoint(coords[0].LatY, coords[0].LonY)
geo.NewPolygon(p1, p2)

Ich habe mich gefragt, ob jemand eine Implementierung davon teilen könnte oder über Ressourcen verfügt, die mich in die richtige Richtung weisen könnten? Ich bin auch bereit, die Google Maps API zu verwenden.


Richtige Antwort


In deinem Beispiel ist das ein Rechteck, du kannst es so berechnen:

  1. Finden Sie den kleinsten Punkt mit Fläche. minimumpoint.x = min(p1.x, p2.x)minimumpoint.y = min(p1.y, p2.y)
  2. Finden Sie den maximalen Flächenpunkt. maximumpoint.x = max(p1.x, p2.x)maximumpoint.y = max(p1.y, p2.y)
  3. Überprüfen Sie, ob der Punkt zwischen ihnen liegt: checkpoint.x >=minimumpoint.xcheckpoint.x 和<code>checkpoint.y >=minimumpoint.ycheckpoint.y

Oder Sie können die Funktion enthält verwenden: https://www.php.cn/link/fb6e7c396949fea1f6f6bf144dbc7908

Zum Projekt hinzufügen: go get github.com/paulmach/orb

Hier ist der Beispielcode, den ich für Ihre Frage geschrieben habe:

package main

import (
    "fmt"

    "github.com/paulmach/orb"
)

func main() {
    p1 := orb.point{43.672162, -79.43585}
    p2 := orb.point{43.629845, -79.314585}

    bound := orb.multipoint{p1, p2}.bound()

    fmt.printf("bound: %+v\n", bound)

    checklist := []orb.point{orb.point{43.651989, -79.371993}, p1, p2, orb.point{43, -79}}

    fmt.printf("\ncontains?\n")
    for _, checkpoint := range checklist {
        fmt.printf("    %+v:%t\n", checkpoint, bound.contains(checkpoint))
    }
}

Ergebnis:

bound: {Min:[43.629845 -79.43585] Max:[43.672162 -79.314585]}

contains?
    [43.651989 -79.371993]:true
    [43.672162 -79.43585]:true
    [43.629845 -79.314585]:true
    [43 -79]:false

Das obige ist der detaillierte Inhalt vonÜberprüfen Sie, ob ein Breiten-/Längengradpunkt innerhalb einer Region liegt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:stackoverflow.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen