changed LFLAGS so it works on ubuntu and switched to non-deprecated libav calls
This commit is contained in:
parent
6e08365b9b
commit
0b26955b16
@ -1,4 +1,3 @@
|
||||
|
||||
package codec
|
||||
|
||||
import (
|
||||
@ -36,8 +35,8 @@ import (
|
||||
}
|
||||
*/
|
||||
"C"
|
||||
"unsafe"
|
||||
"errors"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
type AACDecoder struct {
|
||||
@ -70,7 +69,7 @@ func (m *AACDecoder) Decode(data []byte) (sample []byte, err error) {
|
||||
err = errors.New("no data")
|
||||
return
|
||||
}
|
||||
size := int(m.m.f.linesize[0])*2
|
||||
size := int(m.m.f.linesize[0]) * 2
|
||||
sample = make([]byte, size*2)
|
||||
for i := 0; i < 2; i++ {
|
||||
C.memcpy(
|
||||
@ -81,4 +80,3 @@ func (m *AACDecoder) Decode(data []byte) (sample []byte, err error) {
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
|
||||
package codec
|
||||
|
||||
import (
|
||||
@ -45,8 +44,8 @@ import (
|
||||
}
|
||||
*/
|
||||
"C"
|
||||
"unsafe"
|
||||
"errors"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
type AACEncoder struct {
|
||||
@ -90,4 +89,3 @@ func (m *AACEncoder) Encode(sample []byte) (ret []byte, err error) {
|
||||
)
|
||||
return
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
|
||||
package codec
|
||||
|
||||
import (
|
||||
@ -33,9 +32,9 @@ import (
|
||||
}
|
||||
*/
|
||||
"C"
|
||||
"unsafe"
|
||||
"errors"
|
||||
"image"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
type H264Decoder struct {
|
||||
@ -87,4 +86,3 @@ func (m *H264Decoder) Decode(nal []byte) (f *image.YCbCr, err error) {
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
|
20
h264enc.go
20
h264enc.go
@ -1,4 +1,3 @@
|
||||
|
||||
package codec
|
||||
|
||||
import (
|
||||
@ -39,10 +38,10 @@ import (
|
||||
|
||||
*/
|
||||
"C"
|
||||
"unsafe"
|
||||
"image"
|
||||
"errors"
|
||||
"image"
|
||||
"strings"
|
||||
"unsafe"
|
||||
//"log"
|
||||
)
|
||||
|
||||
@ -111,12 +110,12 @@ func (m *H264Encoder) Encode(img *image.YCbCr) (out h264Out, err error) {
|
||||
return
|
||||
}
|
||||
f = m.m.f
|
||||
f.data[0] = (*C.uint8_t)(unsafe.Pointer(&img.Y[0]));
|
||||
f.data[1] = (*C.uint8_t)(unsafe.Pointer(&img.Cb[0]));
|
||||
f.data[2] = (*C.uint8_t)(unsafe.Pointer(&img.Cr[0]));
|
||||
f.linesize[0] = (C.int)(img.YStride);
|
||||
f.linesize[1] = (C.int)(img.CStride);
|
||||
f.linesize[2] = (C.int)(img.CStride);
|
||||
f.data[0] = (*C.uint8_t)(unsafe.Pointer(&img.Y[0]))
|
||||
f.data[1] = (*C.uint8_t)(unsafe.Pointer(&img.Cb[0]))
|
||||
f.data[2] = (*C.uint8_t)(unsafe.Pointer(&img.Cr[0]))
|
||||
f.linesize[0] = (C.int)(img.YStride)
|
||||
f.linesize[1] = (C.int)(img.CStride)
|
||||
f.linesize[2] = (C.int)(img.CStride)
|
||||
}
|
||||
|
||||
C.av_init_packet(&m.m.pkt)
|
||||
@ -130,7 +129,7 @@ func (m *H264Encoder) Encode(img *image.YCbCr) (out h264Out, err error) {
|
||||
err = errors.New("no picture")
|
||||
return
|
||||
}
|
||||
if (m.m.pkt.size == 0) {
|
||||
if m.m.pkt.size == 0 {
|
||||
err = errors.New("packet size == 0")
|
||||
return
|
||||
}
|
||||
@ -145,4 +144,3 @@ func (m *H264Encoder) Encode(img *image.YCbCr) (out h264Out, err error) {
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
|
7
util.go
7
util.go
@ -1,4 +1,3 @@
|
||||
|
||||
/*
|
||||
|
||||
Golang h264,aac decoder/encoder libav wrapper
|
||||
@ -19,11 +18,11 @@ Golang h264,aac decoder/encoder libav wrapper
|
||||
package codec
|
||||
|
||||
import (
|
||||
"unsafe"
|
||||
"reflect"
|
||||
"unsafe"
|
||||
|
||||
/*
|
||||
#cgo darwin LDFLAGS: -lavformat -lavutil -lavcodec
|
||||
#cgo LDFLAGS: -lavformat -lavutil -lavcodec
|
||||
|
||||
#include <libavutil/avutil.h>
|
||||
#include <libavformat/avformat.h>
|
||||
@ -47,5 +46,3 @@ func fromCPtr(buf unsafe.Pointer, size int) (ret []uint8) {
|
||||
hdr.Data = uintptr(buf)
|
||||
return
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user