-
-
Notifications
You must be signed in to change notification settings - Fork 15
/
main.go
58 lines (47 loc) · 1.21 KB
/
main.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
package main
// This example showcases how the interfaces Ditherer implements can be easily
// used to encode a full color image as a GIF, which can only use 256 colors.
import (
"image"
"image/color"
"image/gif"
_ "image/png" // Imported for decoding of the input image
"os"
"github.com/makeworld-the-better-one/dither/v2"
)
func main() {
// Create the kind of Dither we want
palette := []color.Color{
color.Black,
color.White,
color.RGBA{255, 255, 0, 255}, // Yellow
}
d := dither.NewDitherer(palette)
d.Mapper = dither.Bayer(8, 8, 1.0) // Why not?
// GIF settings - all of these are required!
opts := gif.Options{
NumColors: len(palette),
Quantizer: d, // dither.Ditherer fulfills both these interfaces!
Drawer: d, // How useful!
}
// Open an image and save it as a dithered GIF
f, err := os.Open("../../images/input/peppers.png")
if err != nil {
panic(err)
}
defer f.Close()
img, _, err := image.Decode(f)
if err != nil {
panic(err)
}
f2, err := os.Create("../output/gif_image.gif")
if err != nil {
panic(err)
}
// The GIF encoder calls on the Ditherer itself, because it's the Drawer in
// the GIF options.
err = gif.Encode(f2, img, &opts)
if err != nil {
panic(err)
}
}