---
panlei
2019-07-02 0c8dffc024fc2f8f6b185a2b85387309e4e62aca
util/image.go
@@ -1,31 +1,33 @@
package util
import (
   "basic.com/pubsub/protomsg.git"
   "bytes"
   "fmt"
   "github.com/gogo/protobuf/proto"
   "gocv.io/x/gocv"
   "image"
   "image/jpeg"
   "reflect"
)
// 按尺寸去切图
func Subimg(dbyte []byte,x0,y0,x1,y1 int,) protomsg.Image{
func Subimg(dbyte []byte,x0,y0,x1,y1 int,) []byte{
   bbb := bytes.NewBuffer(dbyte)                           // 必须加一个buffer 不然没有read方法就会报错
   m, _, _ := image.Decode(bbb)                          // 图片文件解码
   rgbImg := m.(*image.YCbCr)
   subImg := rgbImg.SubImage(image.Rect(x0, y0, x1, y1)) //图片裁剪x0 y0 x1 y1
   fmt.Println(reflect.TypeOf(subImg))
   //f, _ := os.Create("./test.jpg")                //创建文件
   //defer f.Close()                                    //关闭文件
   emptyBuff := bytes.NewBuffer(nil)                 //开辟一个新的空buff
   jpeg.Encode(emptyBuff, subImg, nil)                //img写入到buff
   bytes := emptyBuff.Bytes()
   i := protomsg.Image{}
   proto.Unmarshal(bytes,&i)
   return i
   //bbb := bytes.NewBuffer(dbyte)                           // 必须加一个buffer 不然没有read方法就会报错
   ////log.Println("==================看看这个buffer",bbb)
   //m, _, _ := image.Decode(bbb)                          // 图片文件解码
   //rgbImg := m.(*image.YCbCr)
   //subImg := rgbImg.SubImage(image.Rect(x0, y0, x1, y1)) //图片裁剪x0 y0 x1 y1
   //fmt.Println(reflect.TypeOf(subImg))
   ////f, _ := os.Create("./test.jpg")                //创建文件
   ////defer f.Close()                                    //关闭文件
   //emptyBuff := bytes.NewBuffer(nil)                 //开辟一个新的空buff
   //jpeg.Encode(emptyBuff, subImg, nil)                //img写入到buff
   //bytes := emptyBuff.Bytes()
   //i := protomsg.Image{}
   //proto.Unmarshal(bytes,&i)
   //return i
   //f, _ := os.Create("./test.jpg")                //创建文件
   //defer f.Close()                                    //关闭文件
   //jpeg.Encode(f, subImg, nil)                     //写入文件
}
   img,_ := gocv.NewMatFromBytes(100,100,gocv.MatTypeCV8UC3,dbyte)
   rect := image.Rect(x0,y0,x0+100,y0+100)
   region := img.Region(rect)
   bytes, _ := gocv.IMEncode(".jpg", region)
   return bytes
}