-
Notifications
You must be signed in to change notification settings - Fork 105
/
linearring.go
60 lines (50 loc) · 1.44 KB
/
linearring.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package geom
// A LinearRing is a linear ring.
type LinearRing struct {
geom1
}
// NewLinearRing returns a new LinearRing with no coordinates.
func NewLinearRing(layout Layout) *LinearRing {
return NewLinearRingFlat(layout, nil)
}
// NewLinearRingFlat returns a new LinearRing with the given flat coordinates.
func NewLinearRingFlat(layout Layout, flatCoords []float64) *LinearRing {
g := new(LinearRing)
g.layout = layout
g.stride = layout.Stride()
g.flatCoords = flatCoords
return g
}
// Area returns the area.
func (g *LinearRing) Area() float64 {
return doubleArea1(g.flatCoords, 0, len(g.flatCoords), g.stride) / 2
}
// Clone returns a deep copy.
func (g *LinearRing) Clone() *LinearRing {
return deriveCloneLinearRing(g)
}
// Length returns the length of the perimeter.
func (g *LinearRing) Length() float64 {
return length1(g.flatCoords, 0, len(g.flatCoords), g.stride)
}
// MustSetCoords sets the coordinates and panics if there is any error.
func (g *LinearRing) MustSetCoords(coords []Coord) *LinearRing {
Must(g.SetCoords(coords))
return g
}
// SetCoords sets the coordinates.
func (g *LinearRing) SetCoords(coords []Coord) (*LinearRing, error) {
if err := g.setCoords(coords); err != nil {
return nil, err
}
return g, nil
}
// SetSRID sets the SRID of g.
func (g *LinearRing) SetSRID(srid int) *LinearRing {
g.srid = srid
return g
}
// Swap swaps the values of g and g2.
func (g *LinearRing) Swap(g2 *LinearRing) {
*g, *g2 = *g2, *g
}