From d2bec7c45f71a12734b359f10bda6302ecd8a657 Mon Sep 17 00:00:00 2001
From: chenshijun <csj_sky@126.com>
Date: 星期一, 29 七月 2019 11:49:22 +0800
Subject: [PATCH] Merge branch 'master' of ssh://192.168.1.14:29418/valib/goffmpeg

---
 goffmpeg.go |   86 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 86 insertions(+), 0 deletions(-)

diff --git a/goffmpeg.go b/goffmpeg.go
index b8739f8..8569084 100644
--- a/goffmpeg.go
+++ b/goffmpeg.go
@@ -126,6 +126,92 @@
 	return nil, 0, 0
 }
 
+// FireRecorder fire recorder
+func (h *GoFFMPEG) FireRecorder(sid string, id int64) {
+	csid := C.CString(sid)
+	defer C.free(unsafe.Pointer(csid))
+	C.wrap_fn_fire_recorder(h.ffmpeg, csid, C.long(id))
+}
+
+// BuildRecorder build recorder
+func (h *GoFFMPEG) BuildRecorder(sid, output string, mind, maxd int) {
+	out := C.CString(output)
+	defer C.free(unsafe.Pointer(out))
+	csid := C.CString(sid)
+	defer C.free(unsafe.Pointer(csid))
+
+	C.wrap_fn_recorder(h.ffmpeg, csid, out, C.int(mind), C.int(maxd))
+}
+
+// GetInfoRecorder info
+func (h *GoFFMPEG) GetInfoRecorder() (int, string) {
+	var i C.int = -1
+	var l C.int
+
+	p := C.wrap_fn_info_recorder(h.ffmpeg, &i, &l)
+	// if p == nil {
+	// 	return -1, ""
+	// }
+	path := C.GoString(p)
+	C.free(unsafe.Pointer(p))
+
+	// fmt.Println("Go get info : ", path, " len: ", l)
+
+	return int(i), path
+}
+
+func (h *GoFFMPEG) GetRecID(p string) string {
+	pt := C.CString(p)
+	defer C.free(unsafe.Pointer(pt))
+	var i C.int
+
+	cid := C.wrap_fn_rec_id(h.ffmpeg, pt, &i)
+
+	id := C.GoString(cid)
+	C.free(unsafe.Pointer(cid))
+
+	return id
+}
+
+// BuildDecoder build decoder
+func (h *GoFFMPEG) BuildDecoder() {
+	C.wrap_fn_decoder(h.ffmpeg)
+}
+
+// GetPicDecoder get pic from decoder
+func (h *GoFFMPEG) GetPicDecoder() ([]byte, int, int) {
+	var width C.int
+	var height C.int
+
+	p := C.wrap_fn_decoder_pic(h.ffmpeg, &width, &height)
+	if width == 0 && height == 0 {
+		return nil, 0, 0
+	}
+	defer C.free(unsafe.Pointer(p))
+	d := C.GoBytes(p, width*height*3)
+	wid := int(width)
+	hei := int(height)
+
+	return d, wid, hei
+}
+
+//GetAVPacket get AVPacket
+func (h *GoFFMPEG) GetAVPacket() ([]byte, int, int) {
+	var key C.int
+	var size C.int
+
+	p := C.wrap_fn_get_avpacket(h.ffmpeg, &size, &key)
+	if size <= 0 {
+		return nil, 0, -1
+	}
+	defer C.free(unsafe.Pointer(p))
+	d := C.GoBytes(p, size)
+	s := int(size)
+	k := int(key)
+
+	return d, s, k
+}
+
 ///////////////for encoder
 
 // GoEncoder encoder

--
Gitblit v1.8.0