From 000e51f17eba47c3502ee8f717f53f1fae3d0bbd Mon Sep 17 00:00:00 2001
From: liuxiaolong <736321739@qq.com>
Date: 星期三, 13 十一月 2019 19:11:35 +0800
Subject: [PATCH] new files

---
 service/CamraUpdatesnashot.go |   59 ++++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 38 insertions(+), 21 deletions(-)

diff --git a/service/CamraUpdatesnashot.go b/service/CamraUpdatesnashot.go
index be1a621..0ca5c58 100644
--- a/service/CamraUpdatesnashot.go
+++ b/service/CamraUpdatesnashot.go
@@ -1,25 +1,14 @@
 package service
 
 import (
-	"flag"
-	"fmt"
-	"os"
-	"os/exec"
-	"time"
-
-	"bytes"
-	"encoding/json"
-	"errors"
-	"gocv.io/x/gocv"
-	"io"
-	"log"
-	"mime/multipart"
-	"net/http"
-	"path/filepath"
-
 	"basic.com/dbapi.git"
+	"basic.com/fileServer/WeedFSClient.git"
+	"basic.com/valib/capture.git"
+	"errors"
+	"strconv"
+	"webserver/extend/config"
 )
-
+/*浠ヤ笅灞炰簬鏃х増鏈湴鎽勫儚鏈鸿幏鍙栨埅鍥撅紙鍥芥爣鎽勫儚鏈哄簳鍥炬棤娉曞埛鏂帮級
 func PostFormBufferData(uri string, filepath string, fileName string) (maps map[string]interface{}, err0 error) {
 	// 瑕佹寚瀹氳浆byte鐨勬牸寮�
 	picMat := gocv.IMRead(filepath, gocv.IMReadColor)
@@ -117,8 +106,6 @@
 	return piclocal, nil
 }
 
-var fileurl = flag.String("fileurl", "http://192.168.1.182:6333/submit", "url of file server.")
-
 func UpdateSnapshotUrl(cid string) (filename string, err error) {
 	var camApi dbapi.CameraApi
 
@@ -128,8 +115,8 @@
 	if err != nil {
 		return "", err
 	}
-
-	resp, err := PostFormBufferData(*fileurl, piclocal, piclocal)
+	var weedfsUrl = "http://"+config.WeedFs.Ip+":"+strconv.Itoa(config.WeedFs.UploadPort)+"/submit"
+	resp, err := PostFormBufferData(weedfsUrl, piclocal, piclocal)
 	if err != nil {
 		fmt.Println(err)
 		return "", err
@@ -142,4 +129,34 @@
 		return "", errors.New("update filelocal to camera fail")
 	}
 	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"
+		weedFilePath, err := WeedFSClient.UploadFile(weedfsUri, camera.Name+".jpg", b)
+		if err != nil {
+			return "",err
+		} else {
+			ok := cameraApi.UpdateSnapshotUrl(cid, weedFilePath)
+			if !ok {
+				return "", errors.New("update camera's snapshot fail")
+			}
+			return weedFilePath, nil
+		}
+	}else{
+		return "",err
+	}
 }

--
Gitblit v1.8.0