From 87a1ebc36a32f626c622d813240af64cf9003198 Mon Sep 17 00:00:00 2001 From: Kostya Shishkov Date: Tue, 23 May 2017 19:09:58 +0200 Subject: [PATCH] improve audio buffer handling --- src/frame.rs | 41 +++++++++++++++++++++++++++++++++++++++-- 1 file changed, 39 insertions(+), 2 deletions(-) diff --git a/src/frame.rs b/src/frame.rs index 19c1733..97b0a50 100644 --- a/src/frame.rs +++ b/src/frame.rs @@ -88,8 +88,6 @@ impl fmt::Display for NACodecTypeInfo { } } -pub type BufferRef = Rc>>; - pub type NABufferRefT = Rc>>; #[derive(Clone)] @@ -149,6 +147,12 @@ impl NAAudioBuffer { } } +impl NAAudioBuffer { + pub fn new_from_buf(info: NAAudioInfo, data: NABufferRefT, chmap: NAChannelMap) -> Self { + NAAudioBuffer { info: info, data: data, chmap: chmap, offs: Vec::new() } + } +} + #[derive(Clone)] pub enum NABufferType { Video (NAVideoBuffer), @@ -156,6 +160,7 @@ pub enum NABufferType { VideoPacked(NAVideoBuffer), AudioU8 (NAAudioBuffer), AudioI16 (NAAudioBuffer), + AudioI32 (NAAudioBuffer), AudioF32 (NAAudioBuffer), AudioPacked(NAAudioBuffer), Data (NABufferRefT), @@ -178,6 +183,38 @@ impl NABufferType { pub fn get_vbuf(&mut self) -> Option> { match *self { NABufferType::Video(ref vb) => Some(vb.clone()), + NABufferType::VideoPacked(ref vb) => Some(vb.clone()), + _ => None, + } + } + pub fn get_vbuf16(&mut self) -> Option> { + match *self { + NABufferType::Video16(ref vb) => Some(vb.clone()), + _ => None, + } + } + pub fn get_abuf_u8(&mut self) -> Option> { + match *self { + NABufferType::AudioU8(ref ab) => Some(ab.clone()), + NABufferType::AudioPacked(ref ab) => Some(ab.clone()), + _ => None, + } + } + pub fn get_abuf_i16(&mut self) -> Option> { + match *self { + NABufferType::AudioI16(ref ab) => Some(ab.clone()), + _ => None, + } + } + pub fn get_abuf_i32(&mut self) -> Option> { + match *self { + NABufferType::AudioI32(ref ab) => Some(ab.clone()), + _ => None, + } + } + pub fn get_abuf_f32(&mut self) -> Option> { + match *self { + NABufferType::AudioF32(ref ab) => Some(ab.clone()), _ => None, } } -- 2.39.5