From b7340a34ff68f018a4aa0e7aada3b7feaabd2fe1 Mon Sep 17 00:00:00 2001
From: chenshijun <csj_sky@126.com>
Date: 星期二, 22 十月 2019 14:52:49 +0800
Subject: [PATCH] 增加人脸跟踪检测的通道分辨率调整接口face_track_resize

---
 gosdk.go |   41 ++++++-----------------------------------
 1 files changed, 6 insertions(+), 35 deletions(-)

diff --git a/gosdk.go b/gosdk.go
index 4f9eb45..42b4dcd 100644
--- a/gosdk.go
+++ b/gosdk.go
@@ -69,6 +69,12 @@
 	C.c_api_face_tracker_init(C.int(tm), C.int(gi), C.int(w), C.int(h), C.int(maxFaces), C.int(interval), C.int(sample))
 }
 
+// ResizeFaceTracker init face tracker
+func ResizeFaceTracker(ch, w, h int) int {
+
+	return int(C.c_api_face_track_resize(C.int(ch), C.int(w), C.int(h)))
+}
+
 // Free free sdk
 func Free() {
 	C.c_api_release()
@@ -84,7 +90,6 @@
 	var count C.int
 	cfpos := C.c_api_face_detect(&count, (*C.uchar)(unsafe.Pointer(&data[0])), C.int(w), C.int(h), C.int(ch))
 	if cfpos != nil {
-		defer C.free(unsafe.Pointer(cfpos))
 		return CFacePosArrayToGoArray(unsafe.Pointer(cfpos), int(count))
 	}
 	return nil
@@ -113,7 +118,6 @@
 	pos := (*C.cFacePos)(unsafe.Pointer(&fpos))
 
 	p := C.c_api_face_extract(&featLen, pos, (*C.uchar)(unsafe.Pointer(&data[0])), C.int(w), C.int(h), C.int(ch))
-	defer C.free(unsafe.Pointer(p))
 	b := C.GoBytes(unsafe.Pointer(p), featLen)
 	return b
 }
@@ -122,36 +126,6 @@
 func FaceCompare(feat1 []byte, feat2 []byte) float32 {
 	res := C.c_api_face_compare((*C.uchar)(unsafe.Pointer(&feat1[0])), (*C.uchar)(unsafe.Pointer(&feat2[0])))
 	return float32(res)
-}
-
-// FaceTrackOnly face tracker face only
-func FaceTrackOnly(img SDKImage, ch int) []CRECT {
-	data := img.Data
-	w := img.Width
-	h := img.Height
-
-	var fCount C.int
-	rect := C.c_api_face_track_only(&fCount, (*C.uchar)(unsafe.Pointer(&data[0])), C.int(w), C.int(h), C.int(ch))
-	if rect != nil {
-		defer C.free(unsafe.Pointer(rect))
-		return CRECTArrayToGoArray(unsafe.Pointer(rect), int(fCount))
-	}
-	return nil
-}
-
-// FaceTrackDetect face tracker face detect
-func FaceTrackDetect(img SDKImage, ch int) []CFaceInfo {
-	data := img.Data
-	w := img.Width
-	h := img.Height
-
-	var fCount C.int
-	finfo := C.c_api_face_track_only(&fCount, (*C.uchar)(unsafe.Pointer(&data[0])), C.int(w), C.int(h), C.int(ch))
-	if finfo != nil {
-		defer C.free(unsafe.Pointer(finfo))
-		return CFaceInfoArrayToGoArray(unsafe.Pointer(finfo), int(fCount))
-	}
-	return nil
 }
 
 // FaceTrackingInfo face track info
@@ -171,7 +145,6 @@
 	if cFinfo == nil {
 		return
 	}
-	defer C.free(unsafe.Pointer(cFinfo))
 	goFinfo := CFaceInfoArrayToGoArray(unsafe.Pointer(cFinfo), int(fCount))
 
 	// 绌猴紝娣诲姞
@@ -244,7 +217,6 @@
 	if cFinfo == nil {
 		return faces
 	}
-	defer C.free(unsafe.Pointer(cFinfo))
 	faces = CFaceInfoArrayToGoArray(unsafe.Pointer(cFinfo), int(fCount))
 	//if len(faces) > 0{
 	// fmt.Println("faces detected:", len(faces))
@@ -265,7 +237,6 @@
 	cobjinfo := C.c_api_yolo_detect(handle.handle, &count, (*C.uchar)(unsafe.Pointer(&data[0])), C.int(w), C.int(h), C.float(thrsh), C.int(umns))
 
 	if cobjinfo != nil {
-		defer C.free(unsafe.Pointer(cobjinfo))
 		return CYoloObjInfoArrayToGoArray(unsafe.Pointer(cobjinfo), int(count))
 	}
 	return nil

--
Gitblit v1.8.0