forked from lukeroth/gdal
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdoc.go
52 lines (40 loc) · 1.54 KB
/
doc.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
/*
Package gdal provides a wrapper for GDAL, the Geospatial Data Abstraction Library. This C/C++ library provides access to a large number of geospatial raster data formats. It also contains a wrapper for the related OGR Simple Feature Library which provides similar functionality for vector formats.
Limitations
Some less oftenly used functions are not yet implemented. The majoriry of these involve style tables, asynchronous I/O, and GCPs.
The documentation is fairly limited, but the functionality fairly closely matches that of the C++ api.
This wrapper has only been tested on 64-bit Ubuntu Linux, with version 1.9.1 of the GDAL library.
Usage
A simple program to create a georeferenced blank 256x256 GeoTIFF:
package main
import (
"fmt"
"flag"
gdal "github.com/lukeroth/gdal_go"
)
func main() {
flag.Parse()
filename := flag.Arg(0)
if filename == "" {
fmt.Printf("Usage: test_tiff [filename]\n")
return
}
buffer := make([]uint8, 256 * 256)
driver, err := gdal.GetDriverByName("GTiff")
if err != nil {
fmt.Println(err.Error())
return
}
dataset := driver.Create(filename, 256, 256, 1, gdal.Byte, nil)
defer dataset.Close()
spatialRef := gdal.CreateSpatialReference("")
spatialRef.FromEPSG(3857)
srString, err := spatialRef.ToWKT()
dataset.SetProjection(srString)
dataset.SetGeoTransform([]float64{444720, 30, 0, 3751320, 0, -30})
raster := dataset.RasterBand(1)
raster.IO(gdal.Write, 0, 0, 256, 256, buffer, 256, 256, 0, 0)
}
More examples can be found in the ./examples subdirectory.
*/
package gdal