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
68
69
70
71
72
73
| package util
|
| import (
| "basic.com/pubsub/protomsg.git"
| "gocv.io/x/gocv"
| "image"
| )
|
| // 按尺寸去切图
| func SubImg(i protomsg.Image, x0, y0, x1, y1 int, type1 string ) []byte {
| img, _ := gocv.NewMatFromBytes(int(i.Height), int(i.Width), gocv.MatTypeCV8UC3, i.Data)
| if type1 == "face" {
| rect := image.Rect(EnlargeSize(x0, y0, x1, y1, i))
| region := img.Region(rect)
| bytes, _ := gocv.IMEncode(".jpg", region)
| return bytes
| } else {
| rect := image.Rect(EnlargeSizeForCar(x0, y0, x1, y1, i))
| region := img.Region(rect)
| bytes, _ := gocv.IMEncode(".jpg", region)
| return bytes
| }
| }
|
| // 长宽变为一比一,每边各扩百分之20
| func EnlargeSize(x0, y0, x1, y1 int, i protomsg.Image) (x0_new, y0_new, x1_new, y1_new int) {
| // 先把长宽变为一比一
| chazhi := (y1 - y0) - (x1 - x0)
| x0 = x0 - chazhi/2
| if x0 < 0 {
| x0 = 0
| }
| x1 = x1 + chazhi/2
| if x1 > int(i.Width) {
| x1 = int(i.Width)
| }
|
| // 再把每边各扩大百分之20
| enlarge := float32(0.2)
| x0_new = int((1+enlarge)*float32(x0) - enlarge*float32(x1))
| if x0_new < 0 {
| x0_new = 0
| }
| x1_new = int((1+enlarge)*float32(x1) - enlarge*float32(x0))
| if x1_new > int(i.Width) {
| x1_new = int(i.Width)
| }
| y0_new = int((1+enlarge)*float32(y0) - enlarge*float32(y1))
| if y0_new < 0 {
| y0_new = 0
| }
| y1_new = int((1+enlarge)*float32(y1) - enlarge*float32(y0))
| if y1_new > int(i.Height) {
| y1_new = int(i.Height)
| }
| return
| }
|
| // 每边各扩百分之20
| func EnlargeSizeForCar(x0, y0, x1, y1 int, i protomsg.Image) (int,int,int,int) {
|
| // 先把长宽变为一比一
| chazhi := (y1 - y0) - (x1 - x0)
| x0 = x0 - chazhi/2
| if x0 < 0 {
| x0 = 0
| }
| x1 = x1 + chazhi/2
| if x1 > int(i.Width) {
| x1 = int(i.Width)
| }
| return x0, y0, x1, y1
| }
|
|