From 308defe0578c2184d35a59fde31b9cb007f2f889 Mon Sep 17 00:00:00 2001
From: zhangzengfei <zhangzengfei@iotlink.com>
Date: 星期三, 20 十一月 2019 19:57:44 +0800
Subject: [PATCH] feat: add its vehicle sdk

---
 gosdk.go |   37 ++++++++++++++++++++++++++++++++-----
 1 files changed, 32 insertions(+), 5 deletions(-)

diff --git a/gosdk.go b/gosdk.go
index 13abe89..993dba9 100644
--- a/gosdk.go
+++ b/gosdk.go
@@ -2,13 +2,14 @@
 
 /*
 #cgo CFLAGS: -I. -I./sdk/face/include -I./sdk/darknet/include -I/usr/local/cuda/include -w -g
-#cgo CFLAGS:  -I./sdk/plate/eparking/include -I./sdk/plate/cloud/include
+#cgo CFLAGS:  -I./sdk/plate/eparking/include -I./sdk/plate/cloud/include -I./sdk/plate/vehicle/include
 #cgo CXXFLAGS: -I. -I./sdk/face/include -I./sdk/darknet/include -I/usr/local/cuda/include -w -g -std=c++11
-#cgo CXXFLAGS: -I./sdk/plate/eparking/include -I./sdk/plate/cloud/include
+#cgo CXXFLAGS: -I./sdk/plate/eparking/include -I./sdk/plate/cloud/include -I./sdk/plate/vehicle/include
 #cgo LDFLAGS: -L/usr/local/cuda/lib64 -L${SRCDIR}/sdk/face/lib/gpu -L${SRCDIR}/sdk/darknet/lib
-#cgo LDFLAGS: -L${SRCDIR}/sdk/plate/eparking/lib -L${SRCDIR}/sdk/plate/cloud/lib
-#cgo LDFLAGS: -Wl,-rpath,${SRCDIR}/sdk/face/lib/gpu:${SRCDIR}/sdk/darknet/lib:${SRCDIR}/sdk/plate/cloud/lib
+#cgo LDFLAGS: -L${SRCDIR}/sdk/plate/eparking/lib -L${SRCDIR}/sdk/plate/cloud/lib -L${SRCDIR}/sdk/plate/vehicle/lib
+#cgo LDFLAGS: -Wl,-rpath,${SRCDIR}/sdk/face/lib/gpu:${SRCDIR}/sdk/darknet/lib:${SRCDIR}/sdk/plate/cloud/lib:${SRCDIR}/sdk/plate/vehicle/lib
 #cgo LDFLAGS: -ldarknet -lTHFaceImage -lTHFeature -lTHFaceProperty -lTHFaceTracking -lcudart -lcublas -lcurand -lrt -ldl -lpthread -lthplateid -lLPRecognition
+#cgo LDFLAGS: -lVehicleTypeRecognition -lDetection -lExtractor -lvehicleFeatureExt -lopenblas -lprotobuf
 #include <stdlib.h>
 #include "csdk.h"
 */
@@ -521,4 +522,30 @@
 // FreePlateIDCloudSDKDetector free
 func FreePlateIDCloudSDKDetector() {
 	C.c_api_plate_id_free()
-}
\ No newline at end of file
+}
+
+
+// InitVehicleITSDetector init vehicle detector
+func InitVehicleITSDetector(sceneMode, modelMode int, keyPath, modelPath[]byte) int {
+	return int(C.c_api_init_vehicle_its_detector(C.int(sceneMode), C.int(modelMode), (*C.char)(unsafe.Pointer(&keyPath[0])), (*C.char)(unsafe.Pointer(&modelPath[0]))))
+}
+
+// VehicleITSDetect vehicle detect
+func VehicleITSDetect(img SDKImage, rcDetect *CRECT) []CVehicleITSResult {
+	data := img.Data
+	w := img.Width
+	h := img.Height
+
+	var count C.int
+	cppos := C.c_api_vehicle_its_detect(&count, (*C.uchar)(unsafe.Pointer(&data[0])), C.int(w), C.int(h), (*C.cRECT)(unsafe.Pointer(rcDetect)))
+	if cppos != nil {
+		defer C.free(unsafe.Pointer(cppos))
+		return CVehicleITSPosArrayToGoArray(unsafe.Pointer(cppos), int(count))
+	}
+	return nil
+}
+
+// FreeVehicleITSDetector free
+func FreeVehicleITSDetector() {
+	C.c_api_vehicle_its_free()
+}

--
Gitblit v1.8.0