imposm3/geom/geom.go

65 lines
1.4 KiB
Go
Raw Normal View History

2013-04-21 18:37:05 +04:00
package geom
import (
"gogeos"
"goposm/element"
)
2013-05-06 18:17:07 +04:00
func PointWKB(geos *gogeos.GEOS, node element.Node) ([]byte, error) {
coordSeq, err := geos.CreateCoordSeq(1, 2)
if err != nil {
return nil, err
}
// coordSeq inherited by LineString
coordSeq.SetXY(geos, 0, nd.Long, nd.Lat)
geom, err := coordSeq.AsPoint(geos)
if err != nil {
return nil, err
}
defer geos.Destroy(geom)
return geos.AsWKB(geom)
}
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)
}