From 49bea897a567d059e159509340ce8c68fad56a1c Mon Sep 17 00:00:00 2001 From: sunty <1172534965@qq.com> Date: 星期一, 22 七月 2019 16:28:09 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- service/CamraUpdatesnashot.go | 49 +++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 41 insertions(+), 8 deletions(-) diff --git a/service/CamraUpdatesnashot.go b/service/CamraUpdatesnashot.go index 233447d..4027daf 100644 --- a/service/CamraUpdatesnashot.go +++ b/service/CamraUpdatesnashot.go @@ -1,25 +1,26 @@ package service import ( - "flag" - "fmt" - "os" - "os/exec" - "strconv" - "time" - "webserver/extend/config" - "bytes" "encoding/json" "errors" + "flag" + "fmt" "gocv.io/x/gocv" "io" "log" "mime/multipart" "net/http" + "os" + "os/exec" "path/filepath" + "strconv" + "time" + "webserver/extend/config" + "webserver/extend/esutil" "basic.com/dbapi.git" + "basic.com/valib/capture.git" ) func PostFormBufferData(uri string, filepath string, fileName string) (maps map[string]interface{}, err0 error) { @@ -143,3 +144,35 @@ } return filename, nil } + +//璋冪敤缁熶竴鎺ュ彛锛屽埛鏂板簳鍥撅紙闆嗘垚鍥芥爣搴曞浘鍒锋柊锛� +func UpdateCapture(cid string) (fileName string,err error){ + var cameraApi dbapi.CameraApi + camera, err := cameraApi.GetCameraById(cid) + if err !=nil{ + return "",errors.New("camera not exist") + } + + m := capture.Rtsp + if camera.Type == 1{//鍥芥爣鎽勫儚鏈� + m = capture.GB28181 + } + b,err := capture.Capture("./runtime/libcffmpeg.so",m,camera.Rtsp,capture.JPEGFileExt,1280,720,10) + if err == nil{ + var weedfsUri = "http://"+config.WeedFs.Ip+":"+strconv.Itoa(config.WeedFs.UploadPort)+"/submit" + resp, err := esutil.PostFormBufferData(weedfsUri, camera.Name+".jpg", "file", b) + if err != nil { + return "",err + } else { + fileurl := resp["fileUrl"].(string) // 鏂囦欢璺緞 + filename := filepath.Base(fileurl) + ok := cameraApi.UpdateSnapshotUrl(cid, filename) + if !ok { + return "", errors.New("update camera's snapshot fail") + } + return filename, nil + } + }else{ + return "",err + } +} -- Gitblit v1.8.0