forked from mirrors/gstreamer-rs
72 lines
2.4 KiB
Rust
72 lines
2.4 KiB
Rust
// Take a look at the license at the top of the repository in the LICENSE file.
|
|
|
|
use glib::object::IsA;
|
|
use gst::prelude::*;
|
|
|
|
use crate::{auto::AudioVisualizer, subclass::AudioVisualizerSetupToken};
|
|
|
|
pub trait AudioVisualizerExtManual: 'static {
|
|
// rustdoc-stripper-ignore-next
|
|
/// Returns the number of samples per frame required before calling the render method
|
|
fn req_spf(&self) -> u32;
|
|
|
|
// rustdoc-stripper-ignore-next
|
|
/// Modify the request of samples per frame required to be present in buffer before calling
|
|
/// the render method
|
|
fn set_req_spf(&self, spf: u32, token: &AudioVisualizerSetupToken);
|
|
|
|
fn audio_info(&self) -> gst_audio::AudioInfo;
|
|
|
|
fn video_info(&self) -> gst_video::VideoInfo;
|
|
}
|
|
|
|
impl<O: IsA<AudioVisualizer> + ElementExt> AudioVisualizerExtManual for O {
|
|
fn req_spf(&self) -> u32 {
|
|
let sinkpad = self.static_pad("sink").expect("sink pad presence");
|
|
let _stream_lock = sinkpad.stream_lock();
|
|
|
|
let ptr = self.as_ptr() as *mut ffi::GstAudioVisualizer;
|
|
unsafe { (*ptr).req_spf }
|
|
}
|
|
|
|
fn set_req_spf(&self, spf: u32, token: &AudioVisualizerSetupToken) {
|
|
assert_eq!(
|
|
self.as_ptr() as *mut ffi::GstAudioVisualizer,
|
|
token.0.as_ptr() as *mut ffi::GstAudioVisualizer
|
|
);
|
|
|
|
let sinkpad = self.static_pad("sink").expect("sink pad presence");
|
|
let _stream_lock = sinkpad.stream_lock();
|
|
|
|
let mut ptr = self.as_ptr() as *mut ffi::GstAudioVisualizer;
|
|
unsafe {
|
|
(*ptr).req_spf = spf;
|
|
}
|
|
}
|
|
|
|
fn audio_info(&self) -> gst_audio::AudioInfo {
|
|
let sinkpad = self.static_pad("sink").expect("sink pad presence");
|
|
let _stream_lock = sinkpad.stream_lock();
|
|
|
|
let ptr = self.as_ptr() as *mut ffi::GstAudioVisualizer;
|
|
unsafe {
|
|
let info = &(*ptr).ainfo;
|
|
glib::translate::from_glib_none(glib::translate::mut_override(
|
|
info as *const gst_audio::ffi::GstAudioInfo,
|
|
))
|
|
}
|
|
}
|
|
|
|
fn video_info(&self) -> gst_video::VideoInfo {
|
|
let srcpad = self.static_pad("src").expect("src pad presence");
|
|
let _stream_lock = srcpad.stream_lock();
|
|
|
|
let ptr = self.as_ptr() as *mut ffi::GstAudioVisualizer;
|
|
unsafe {
|
|
let info = &(*ptr).vinfo;
|
|
glib::translate::from_glib_none(glib::translate::mut_override(
|
|
info as *const gst_video::ffi::GstVideoInfo,
|
|
))
|
|
}
|
|
}
|
|
}
|