From d42b09cda8b2bc58c43c200f3aabdb0b2a7e9211 Mon Sep 17 00:00:00 2001
From: sunty <1172534965@qq.com>
Date: 星期五, 12 七月 2019 12:02:14 +0800
Subject: [PATCH] fix search controllers

---
 extend/util/util.go |   46 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 46 insertions(+), 0 deletions(-)

diff --git a/extend/util/util.go b/extend/util/util.go
index b9af7da..77cd755 100644
--- a/extend/util/util.go
+++ b/extend/util/util.go
@@ -1,9 +1,12 @@
 package util
 
 import (
+	"basic.com/pubsub/protomsg.git"
 	"encoding/json"
 	"github.com/gin-gonic/gin"
 	"github.com/golang/glog"
+	"gocv.io/x/gocv"
+	"image"
 	"webserver/extend/code"
 
 	"crypto/rand"
@@ -66,4 +69,47 @@
 	//	data[t.Field(i).Name] = v.Field(i).Interface()
 	//}
 	//return data
+}
+
+// 鎸夊昂瀵稿幓鍒囧浘
+func SubImg(i protomsg.Image, x0, y0, x1, y1 int, ) []byte {
+	img, _ := gocv.NewMatFromBytes(int(i.Height), int(i.Width), gocv.MatTypeCV8UC3, i.Data)
+	rect := image.Rect(EnlargeSize(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
 }
\ No newline at end of file

--
Gitblit v1.8.0