-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathprocess.go
67 lines (57 loc) · 991 Bytes
/
process.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
61
62
63
64
65
66
67
package main
import (
"fmt"
"github.com/disintegration/imaging"
"image"
"image/color"
"strconv"
"time"
)
type size struct {
w int
h int
}
var all []size
func main() {
start := time.Now()
all := []size{
size{
w: 100,
h: 100,
},
size{
w: 200,
h: 200,
},
size{
w: 300,
h: 300,
},
size{
w: 400,
h: 400,
},
size{
w: 500,
h: 500,
},
}
// input file
file := "img/eg.jpeg"
img, err := imaging.Open(file)
if err != nil {
panic(err)
}
// Generate all resized image sizes to output folder
for _, s := range all {
r := imaging.Resize(img, s.w, s.h, imaging.Lanczos)
dst := imaging.New(s.w, s.h, color.NRGBA{0, 0, 0, 0})
dst = imaging.Paste(dst, r, image.Pt(0, 0))
err := imaging.Save(dst, "output/dst"+strconv.Itoa(s.w)+strconv.Itoa(s.h)+".jpg")
if err != nil {
panic(err)
}
}
elapsed := time.Since(start)
fmt.Printf("Resize timing millisecond : %s\n", strconv.Itoa(int(elapsed.Nanoseconds()/1000000)))
}