// This file was generated by gir (https://github.com/gtk-rs/gir) // from gir-files (https://github.com/gtk-rs/gir-files) // DO NOT EDIT use crate::PlayerAudioInfo; use crate::PlayerColorBalanceType; use crate::PlayerMediaInfo; use crate::PlayerSnapshotFormat; use crate::PlayerState; use crate::PlayerSubtitleInfo; use crate::PlayerVideoInfo; use crate::PlayerVisualization; use glib::object::ObjectType as ObjectType_; use glib::signal::connect_raw; use glib::signal::SignalHandlerId; use glib::translate::*; use glib::StaticType; use glib::Value; use std::boxed::Box as Box_; use std::mem::transmute; glib::glib_wrapper! { pub struct Player(Object) @extends gst::Object; match fn { get_type => || ffi::gst_player_get_type(), } } impl Player { pub fn get_audio_video_offset(&self) -> i64 { unsafe { ffi::gst_player_get_audio_video_offset(self.to_glib_none().0) } } pub fn get_color_balance(&self, type_: PlayerColorBalanceType) -> f64 { unsafe { ffi::gst_player_get_color_balance(self.to_glib_none().0, type_.to_glib()) } } pub fn get_current_audio_track(&self) -> Option { unsafe { from_glib_full(ffi::gst_player_get_current_audio_track( self.to_glib_none().0, )) } } pub fn get_current_subtitle_track(&self) -> Option { unsafe { from_glib_none(ffi::gst_player_get_current_subtitle_track( self.to_glib_none().0, )) } } pub fn get_current_video_track(&self) -> Option { unsafe { from_glib_full(ffi::gst_player_get_current_video_track( self.to_glib_none().0, )) } } pub fn get_current_visualization(&self) -> Option { unsafe { from_glib_full(ffi::gst_player_get_current_visualization( self.to_glib_none().0, )) } } pub fn get_duration(&self) -> gst::ClockTime { unsafe { from_glib(ffi::gst_player_get_duration(self.to_glib_none().0)) } } pub fn get_media_info(&self) -> Option { unsafe { from_glib_full(ffi::gst_player_get_media_info(self.to_glib_none().0)) } } pub fn get_multiview_flags(&self) -> gst_video::VideoMultiviewFlags { unsafe { from_glib(ffi::gst_player_get_multiview_flags(self.to_glib_none().0)) } } pub fn get_multiview_mode(&self) -> gst_video::VideoMultiviewFramePacking { unsafe { from_glib(ffi::gst_player_get_multiview_mode(self.to_glib_none().0)) } } pub fn get_mute(&self) -> bool { unsafe { from_glib(ffi::gst_player_get_mute(self.to_glib_none().0)) } } pub fn get_pipeline(&self) -> gst::Element { unsafe { from_glib_full(ffi::gst_player_get_pipeline(self.to_glib_none().0)) } } pub fn get_position(&self) -> gst::ClockTime { unsafe { from_glib(ffi::gst_player_get_position(self.to_glib_none().0)) } } pub fn get_rate(&self) -> f64 { unsafe { ffi::gst_player_get_rate(self.to_glib_none().0) } } pub fn get_subtitle_uri(&self) -> Option { unsafe { from_glib_full(ffi::gst_player_get_subtitle_uri(self.to_glib_none().0)) } } #[cfg(any(feature = "v1_16", all(not(doctest), doc)))] #[cfg_attr(all(not(doctest), doc), doc(cfg(feature = "v1_16")))] pub fn get_subtitle_video_offset(&self) -> i64 { unsafe { ffi::gst_player_get_subtitle_video_offset(self.to_glib_none().0) } } pub fn get_uri(&self) -> Option { unsafe { from_glib_full(ffi::gst_player_get_uri(self.to_glib_none().0)) } } pub fn get_video_snapshot( &self, format: PlayerSnapshotFormat, config: Option<&gst::Structure>, ) -> Option { unsafe { from_glib_full(ffi::gst_player_get_video_snapshot( self.to_glib_none().0, format.to_glib(), config.to_glib_none().0, )) } } pub fn get_volume(&self) -> f64 { unsafe { ffi::gst_player_get_volume(self.to_glib_none().0) } } pub fn has_color_balance(&self) -> bool { unsafe { from_glib(ffi::gst_player_has_color_balance(self.to_glib_none().0)) } } pub fn pause(&self) { unsafe { ffi::gst_player_pause(self.to_glib_none().0); } } pub fn play(&self) { unsafe { ffi::gst_player_play(self.to_glib_none().0); } } pub fn seek(&self, position: gst::ClockTime) { unsafe { ffi::gst_player_seek(self.to_glib_none().0, position.to_glib()); } } pub fn set_audio_track(&self, stream_index: i32) -> Result<(), glib::error::BoolError> { unsafe { glib::glib_result_from_gboolean!( ffi::gst_player_set_audio_track(self.to_glib_none().0, stream_index), "Failed to set audio track" ) } } pub fn set_audio_track_enabled(&self, enabled: bool) { unsafe { ffi::gst_player_set_audio_track_enabled(self.to_glib_none().0, enabled.to_glib()); } } pub fn set_audio_video_offset(&self, offset: i64) { unsafe { ffi::gst_player_set_audio_video_offset(self.to_glib_none().0, offset); } } pub fn set_color_balance(&self, type_: PlayerColorBalanceType, value: f64) { unsafe { ffi::gst_player_set_color_balance(self.to_glib_none().0, type_.to_glib(), value); } } pub fn set_multiview_flags(&self, flags: gst_video::VideoMultiviewFlags) { unsafe { ffi::gst_player_set_multiview_flags(self.to_glib_none().0, flags.to_glib()); } } pub fn set_multiview_mode(&self, mode: gst_video::VideoMultiviewFramePacking) { unsafe { ffi::gst_player_set_multiview_mode(self.to_glib_none().0, mode.to_glib()); } } pub fn set_mute(&self, val: bool) { unsafe { ffi::gst_player_set_mute(self.to_glib_none().0, val.to_glib()); } } pub fn set_rate(&self, rate: f64) { unsafe { ffi::gst_player_set_rate(self.to_glib_none().0, rate); } } pub fn set_subtitle_track(&self, stream_index: i32) -> Result<(), glib::error::BoolError> { unsafe { glib::glib_result_from_gboolean!( ffi::gst_player_set_subtitle_track(self.to_glib_none().0, stream_index), "Failed to set subtitle track" ) } } pub fn set_subtitle_track_enabled(&self, enabled: bool) { unsafe { ffi::gst_player_set_subtitle_track_enabled(self.to_glib_none().0, enabled.to_glib()); } } pub fn set_subtitle_uri(&self, uri: &str) { unsafe { ffi::gst_player_set_subtitle_uri(self.to_glib_none().0, uri.to_glib_none().0); } } #[cfg(any(feature = "v1_16", all(not(doctest), doc)))] #[cfg_attr(all(not(doctest), doc), doc(cfg(feature = "v1_16")))] pub fn set_subtitle_video_offset(&self, offset: i64) { unsafe { ffi::gst_player_set_subtitle_video_offset(self.to_glib_none().0, offset); } } pub fn set_uri(&self, uri: &str) { unsafe { ffi::gst_player_set_uri(self.to_glib_none().0, uri.to_glib_none().0); } } pub fn set_video_track(&self, stream_index: i32) -> Result<(), glib::error::BoolError> { unsafe { glib::glib_result_from_gboolean!( ffi::gst_player_set_video_track(self.to_glib_none().0, stream_index), "Failed to set video track" ) } } pub fn set_video_track_enabled(&self, enabled: bool) { unsafe { ffi::gst_player_set_video_track_enabled(self.to_glib_none().0, enabled.to_glib()); } } pub fn set_visualization(&self, name: Option<&str>) -> Result<(), glib::error::BoolError> { unsafe { glib::glib_result_from_gboolean!( ffi::gst_player_set_visualization(self.to_glib_none().0, name.to_glib_none().0), "Failed to set visualization" ) } } pub fn set_visualization_enabled(&self, enabled: bool) { unsafe { ffi::gst_player_set_visualization_enabled(self.to_glib_none().0, enabled.to_glib()); } } pub fn set_volume(&self, val: f64) { unsafe { ffi::gst_player_set_volume(self.to_glib_none().0, val); } } pub fn stop(&self) { unsafe { ffi::gst_player_stop(self.to_glib_none().0); } } pub fn get_property_suburi(&self) -> Option { unsafe { let mut value = Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"suburi\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `suburi` getter") } } pub fn set_property_suburi(&self, suburi: Option<&str>) { unsafe { glib::gobject_ffi::g_object_set_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"suburi\0".as_ptr() as *const _, Value::from(suburi).to_glib_none().0, ); } } pub fn get_property_video_multiview_flags(&self) -> gst_video::VideoMultiviewFlags { unsafe { let mut value = Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"video-multiview-flags\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `video-multiview-flags` getter") .unwrap() } } pub fn set_property_video_multiview_flags( &self, video_multiview_flags: gst_video::VideoMultiviewFlags, ) { unsafe { glib::gobject_ffi::g_object_set_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"video-multiview-flags\0".as_ptr() as *const _, Value::from(&video_multiview_flags).to_glib_none().0, ); } } pub fn get_property_video_multiview_mode(&self) -> gst_video::VideoMultiviewFramePacking { unsafe { let mut value = Value::from_type( ::static_type(), ); glib::gobject_ffi::g_object_get_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"video-multiview-mode\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `video-multiview-mode` getter") .unwrap() } } pub fn set_property_video_multiview_mode( &self, video_multiview_mode: gst_video::VideoMultiviewFramePacking, ) { unsafe { glib::gobject_ffi::g_object_set_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"video-multiview-mode\0".as_ptr() as *const _, Value::from(&video_multiview_mode).to_glib_none().0, ); } } pub fn get_audio_streams(info: &PlayerMediaInfo) -> Vec { skip_assert_initialized!(); unsafe { FromGlibPtrContainer::from_glib_none(ffi::gst_player_get_audio_streams( info.to_glib_none().0, )) } } pub fn get_subtitle_streams(info: &PlayerMediaInfo) -> Vec { skip_assert_initialized!(); unsafe { FromGlibPtrContainer::from_glib_none(ffi::gst_player_get_subtitle_streams( info.to_glib_none().0, )) } } pub fn get_video_streams(info: &PlayerMediaInfo) -> Vec { skip_assert_initialized!(); unsafe { FromGlibPtrContainer::from_glib_none(ffi::gst_player_get_video_streams( info.to_glib_none().0, )) } } pub fn visualizations_get() -> Vec { assert_initialized_main_thread!(); unsafe { FromGlibPtrContainer::from_glib_full(ffi::gst_player_visualizations_get()) } } pub fn connect_buffering(&self, f: F) -> SignalHandlerId { unsafe extern "C" fn buffering_trampoline( this: *mut ffi::GstPlayer, object: libc::c_int, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this), object) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"buffering\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( buffering_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_end_of_stream(&self, f: F) -> SignalHandlerId { unsafe extern "C" fn end_of_stream_trampoline( this: *mut ffi::GstPlayer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"end-of-stream\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( end_of_stream_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_error( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn error_trampoline( this: *mut ffi::GstPlayer, object: *mut glib::ffi::GError, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this), &from_glib_borrow(object)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"error\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( error_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_media_info_updated( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn media_info_updated_trampoline< F: Fn(&Player, &PlayerMediaInfo) + Send + 'static, >( this: *mut ffi::GstPlayer, object: *mut ffi::GstPlayerMediaInfo, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this), &from_glib_borrow(object)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"media-info-updated\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( media_info_updated_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_mute_changed(&self, f: F) -> SignalHandlerId { unsafe extern "C" fn mute_changed_trampoline( this: *mut ffi::GstPlayer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"mute-changed\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( mute_changed_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_state_changed( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn state_changed_trampoline< F: Fn(&Player, PlayerState) + Send + 'static, >( this: *mut ffi::GstPlayer, object: ffi::GstPlayerState, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this), from_glib(object)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"state-changed\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( state_changed_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_uri_loaded( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn uri_loaded_trampoline( this: *mut ffi::GstPlayer, object: *mut libc::c_char, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f( &from_glib_borrow(this), &glib::GString::from_glib_borrow(object), ) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"uri-loaded\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( uri_loaded_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_video_dimensions_changed( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn video_dimensions_changed_trampoline< F: Fn(&Player, i32, i32) + Send + 'static, >( this: *mut ffi::GstPlayer, object: libc::c_int, p0: libc::c_int, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this), object, p0) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"video-dimensions-changed\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( video_dimensions_changed_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_volume_changed(&self, f: F) -> SignalHandlerId { unsafe extern "C" fn volume_changed_trampoline( this: *mut ffi::GstPlayer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"volume-changed\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( volume_changed_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_warning( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn warning_trampoline( this: *mut ffi::GstPlayer, object: *mut glib::ffi::GError, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this), &from_glib_borrow(object)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"warning\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( warning_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_audio_video_offset_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_audio_video_offset_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::audio-video-offset\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_audio_video_offset_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_current_audio_track_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_current_audio_track_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::current-audio-track\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_current_audio_track_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_current_subtitle_track_notify< F: Fn(&Player) + Send + Sync + 'static, >( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_current_subtitle_track_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::current-subtitle-track\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_current_subtitle_track_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_current_video_track_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_current_video_track_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::current-video-track\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_current_video_track_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_duration_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_duration_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::duration\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_duration_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_media_info_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_media_info_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::media-info\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_media_info_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_mute_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_mute_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::mute\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_mute_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_pipeline_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_pipeline_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::pipeline\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_pipeline_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_position_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_position_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::position\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_position_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_rate_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_rate_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::rate\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_rate_trampoline:: as *const (), )), Box_::into_raw(f), ) } } #[cfg(any(feature = "v1_16", all(not(doctest), doc)))] #[cfg_attr(all(not(doctest), doc), doc(cfg(feature = "v1_16")))] pub fn connect_property_subtitle_video_offset_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_subtitle_video_offset_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::subtitle-video-offset\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_subtitle_video_offset_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_suburi_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_suburi_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::suburi\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_suburi_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_uri_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_uri_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::uri\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_uri_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_video_multiview_flags_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_video_multiview_flags_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::video-multiview-flags\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_video_multiview_flags_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_video_multiview_mode_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_video_multiview_mode_trampoline< F: Fn(&Player) + Send + Sync + 'static, >( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::video-multiview-mode\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_video_multiview_mode_trampoline:: as *const (), )), Box_::into_raw(f), ) } } pub fn connect_property_volume_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_volume_trampoline( this: *mut ffi::GstPlayer, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::volume\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_volume_trampoline:: as *const (), )), Box_::into_raw(f), ) } } } unsafe impl Send for Player {} unsafe impl Sync for Player {}