From 83cb634a6c385ccdf50354b7de9e2e299a6e63b5 Mon Sep 17 00:00:00 2001
From: sunty <suntianyu0923@163.com>
Date: 星期三, 24 七月 2019 15:37:14 +0800
Subject: [PATCH] fix alarmLever defenceState
---
extend/util/util.go | 123 +++++++++++++++++++++++++++++++++++++++++
1 files changed, 123 insertions(+), 0 deletions(-)
diff --git a/extend/util/util.go b/extend/util/util.go
index b9af7da..cc2dd98 100644
--- a/extend/util/util.go
+++ b/extend/util/util.go
@@ -1,9 +1,17 @@
package util
import (
+ "basic.com/pubsub/protomsg.git"
+ "bytes"
"encoding/json"
+ "errors"
"github.com/gin-gonic/gin"
"github.com/golang/glog"
+ "gocv.io/x/gocv"
+ "image"
+ "net"
+ "os/exec"
+ "strconv"
"webserver/extend/code"
"crypto/rand"
@@ -66,4 +74,119 @@
// 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
+}
+
+
+// 鑾峰彇鏈満缃戝崱IP
+func GetLocalIP(networkName string) (ipv4 string,mask string, err error) {
+ interfaces, err := net.Interfaces()
+ if err != nil {
+ return "","", err
+ }
+
+ for _, i := range interfaces {
+ byName, err := net.InterfaceByName(i.Name)
+ if err != nil {
+ return "","", err
+ }
+ addresses, err := byName.Addrs()
+ for _, v := range addresses {
+ if ipnet, ok:=v.(*net.IPNet);ok && !ipnet.IP.IsLoopback(){
+ if ipnet.IP.To4() !=nil{
+ if byName.Name == networkName{
+ maskStr := ipnet.Mask.String()
+ mask64, _ := strconv.ParseUint(maskStr, 16, 32)
+ return ipnet.IP.String(),IpIntToString(int(mask64)),nil
+ }
+ }
+ }
+ }
+ }
+ return "","", errors.New("ipv4 not found")
+}
+
+func GetDefaultRoute(networkName string)(route string,err error){
+ cmdStr := fmt.Sprintf("route | grep -P \"^default.*%s$\" | awk '{print $2}'",networkName)
+ cmd := exec.Command("/bin/sh","-c",cmdStr)
+ b, err := cmd.Output()
+ if err!=nil{
+ return "",err
+ }
+ return string(b),nil
+
+}
+
+func StringIpToInt(ipstring string) int {
+ ipSegs := strings.Split(ipstring, ".")
+ var ipInt int = 0
+ var pos uint = 24
+ for _, ipSeg := range ipSegs {
+ tempInt, _ := strconv.Atoi(ipSeg)
+ tempInt = tempInt << pos
+ ipInt = ipInt | tempInt
+ pos -= 8
+ }
+ return ipInt
+}
+
+func IpIntToString(ipInt int) string{
+ ipSegs := make([]string, 4)
+ var len int = len(ipSegs)
+ buffer := bytes.NewBufferString("")
+ for i := 0; i < len; i++ {
+ tempInt := ipInt & 0xFF
+ ipSegs[len-i-1] = strconv.Itoa(tempInt)
+
+ ipInt = ipInt >> 8
+ }
+ for i := 0; i < len; i++ {
+ buffer.WriteString(ipSegs[i])
+ if i < len-1 {
+ buffer.WriteString(".")
+ }
+ }
+ return buffer.String()
}
\ No newline at end of file
--
Gitblit v1.8.0