Documentation ¶
Index ¶
- Constants
- func EuclideanDistance(x1, y1, x2, y2 float64) float64
- func GetUnitNormalVector(x1, y1, x2, y2 float64) (float64, float64)
- func PrecisionCompare(a, b, e float64) int
- func Sign(i float64) int
- func TruncateDecimals(v float64) float64
- type BezierCurve
- type Box
- type Ellipse
- type Intersectable
- type Orientation
- type Point
- func (start *Point) AddVector(v Vector) *Point
- func (p1 *Point) Compare(p2 *Point) int
- func (p *Point) Copy() *Point
- func (p *Point) DistanceToLine(p1, p2 *Point) float64
- func (p1 *Point) Equals(p2 *Point) bool
- func (p *Point) FormattedCoordinates() string
- func (pFrom *Point) GetOrientation(pTo *Point) Orientation
- func (q *Point) OnSegment(p, r *Point) bool
- func (p *Point) ToString() string
- func (p *Point) Transpose()
- func (start *Point) VectorTo(endpoint *Point) Vector
- type Points
- type RelativePoint
- type Route
- type Segment
- type Vector
Constants ¶
const PRECISION = 0.0001
How precise should comparisons be, avoid being too precise due to floating point issues
Variables ¶
This section is empty.
Functions ¶
func EuclideanDistance ¶
func GetUnitNormalVector ¶
func PrecisionCompare ¶
compare a and b and consider them equal if difference is less than precision e (e.g. e=0.001)
func TruncateDecimals ¶
TruncateDecimals truncates floats to keep up to 3 digits after decimal, to avoid issues with floats on different machines. Since we're not launching rockets, 3 decimals is enough precision for what we're doing
Types ¶
type BezierCurve ¶
func NewBezierCurve ¶
func NewBezierCurve(points []*Point) *BezierCurve
func (BezierCurve) At ¶
func (bc BezierCurve) At(point float64) *Point
func (BezierCurve) Intersections ¶
func (bc BezierCurve) Intersections(segment Segment) []*Point
type Box ¶
func (*Box) Intersections ¶
type Intersectable ¶
type Orientation ¶
type Orientation int
const ( TopLeft Orientation = iota TopRight BottomLeft BottomRight Top Right Bottom Left NONE )
func (Orientation) GetOpposite ¶
func (o Orientation) GetOpposite() Orientation
func (Orientation) IsDiagonal ¶
func (o Orientation) IsDiagonal() bool
func (Orientation) IsHorizontal ¶
func (o Orientation) IsHorizontal() bool
func (Orientation) IsVertical ¶
func (o Orientation) IsVertical() bool
func (Orientation) SameSide ¶
func (o1 Orientation) SameSide(o2 Orientation) bool
func (Orientation) ToString ¶
func (o Orientation) ToString() string
type Point ¶
func IntersectionPoint ¶
get the point of intersection between line segments u and v (or nil if they do not intersect)
func (*Point) DistanceToLine ¶
https://stackoverflow.com/questions/849211/shortest-distance-between-a-point-and-a-line-segment
func (*Point) FormattedCoordinates ¶
func (*Point) GetOrientation ¶
func (pFrom *Point) GetOrientation(pTo *Point) Orientation
GetOrientation gets orientation of pFrom to pTo E.g. pFrom ---> pTo, here, pFrom is to the left of pTo, so Left would be returned
type RelativePoint ¶
func NewRelativePoint ¶
func NewRelativePoint(xPercentage, yPercentage float64) *RelativePoint
type Route ¶
type Route []*Point
func (Route) GetBoundingBox ¶
func (Route) GetPointAtDistance ¶
return the point at _distance_ along the route, and the index of the segment it's on
type Segment ¶
func NewSegment ¶
func (*Segment) GetBounds ¶
getBounds takes a segment and returns the floor and ceil of where it can shift to If there is no floor or ceiling, negative or positive infinity is used, respectively The direction is inferred, e.g. b/c the passed in segment is vertical, it's inferred we want horizontal bounds buffer says how close the segment can be, on both axes, to other segments given
│ │ │ │ │ │ │ │ │ non-overlap │ │ │ │ segment │ │ │ │ ceil │ │ │ │ │
floor │ │
│ │ │ │
NOTE: the assumption is that all segments given are orthogonal