2013-04-21 18:37:05 +04:00
|
|
|
package geom
|
|
|
|
|
|
|
|
import (
|
|
|
|
"gogeos"
|
|
|
|
"goposm/element"
|
|
|
|
)
|
|
|
|
|
2013-04-24 00:02:27 +04:00
|
|
|
func LineStringWKB(geos *gogeos.GEOS, nodes []element.Node) ([]byte, error) {
|
|
|
|
coordSeq, err := geos.CreateCoordSeq(uint32(len(nodes)), 2)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
// coordSeq inherited by LineString
|
2013-04-21 18:37:05 +04:00
|
|
|
for i, nd := range nodes {
|
|
|
|
coordSeq.SetXY(geos, uint32(i), nd.Long, nd.Lat)
|
|
|
|
}
|
2013-04-24 00:02:27 +04:00
|
|
|
geom, err := coordSeq.AsLineString(geos)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2013-04-21 18:37:05 +04:00
|
|
|
defer geos.Destroy(geom)
|
|
|
|
return geos.AsWKB(geom)
|
|
|
|
}
|
2013-04-24 00:02:27 +04:00
|
|
|
|
|
|
|
func PolygonWKB(geos *gogeos.GEOS, nodes []element.Node) ([]byte, error) {
|
|
|
|
coordSeq, err := geos.CreateCoordSeq(uint32(len(nodes)), 2)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
// coordSeq inherited by LineString, no destroy
|
|
|
|
for i, nd := range nodes {
|
|
|
|
err := coordSeq.SetXY(geos, uint32(i), nd.Long, nd.Lat)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
geom, err := coordSeq.AsLinearRing(geos)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
// geom inherited by Polygon, no destroy
|
|
|
|
geom = geos.CreatePolygon(geom, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer geos.Destroy(geom)
|
|
|
|
|
|
|
|
return geos.AsWKB(geom)
|
|
|
|
}
|