Struct Sdl
pub struct Sdl { /* private fields */ }
dep_sdl3
only.Expand description
The SDL context type. Initialize with sdl3::init()
.
From a thread-safety perspective, Sdl
represents the main thread.
As such, Sdl
is a useful type for ensuring that SDL types that can only
be used on the main thread are initialized that way.
For instance, SDL_PumpEvents()
is not thread safe, and may only be
called on the main thread.
All functionality that calls SDL_PumpEvents()
is thus put into an
EventPump
type, which can only be obtained through Sdl
.
This guarantees that the only way to call event-pumping functions is on
the main thread.
Implementations§
§impl Sdl
impl Sdl
pub fn keyboard(&self) -> KeyboardUtil
§impl Sdl
impl Sdl
pub fn audio(&self) -> Result<AudioSubsystem, Error> ⓘ
pub fn audio(&self) -> Result<AudioSubsystem, Error> ⓘ
Initializes the audio subsystem.
pub fn event(&self) -> Result<EventSubsystem, Error> ⓘ
pub fn event(&self) -> Result<EventSubsystem, Error> ⓘ
Initializes the event subsystem.
pub fn joystick(&self) -> Result<JoystickSubsystem, Error> ⓘ
pub fn joystick(&self) -> Result<JoystickSubsystem, Error> ⓘ
Initializes the joystick subsystem.
pub fn haptic(&self) -> Result<HapticSubsystem, Error> ⓘ
pub fn haptic(&self) -> Result<HapticSubsystem, Error> ⓘ
Initializes the haptic subsystem.
pub fn gamepad(&self) -> Result<GamepadSubsystem, Error> ⓘ
pub fn gamepad(&self) -> Result<GamepadSubsystem, Error> ⓘ
Initializes the gamepad subsystem.
pub fn sensor(&self) -> Result<SensorSubsystem, Error> ⓘ
pub fn sensor(&self) -> Result<SensorSubsystem, Error> ⓘ
Initializes the game controller subsystem.
pub fn video(&self) -> Result<VideoSubsystem, Error> ⓘ
pub fn video(&self) -> Result<VideoSubsystem, Error> ⓘ
Initializes the video subsystem.
pub fn event_pump(&self) -> Result<EventPump, Error> ⓘ
pub fn event_pump(&self) -> Result<EventPump, Error> ⓘ
Obtains the SDL event pump.
At most one EventPump
is allowed to be alive during the program’s execution.
If this function is called while an EventPump
instance is alive, the function will return
an error.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Sdl
impl RefUnwindSafe for Sdl
impl !Send for Sdl
impl !Sync for Sdl
impl Unpin for Sdl
impl UnwindSafe for Sdl
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> ByteSized for T
impl<T> ByteSized for T
Source§const BYTE_ALIGN: usize = _
const BYTE_ALIGN: usize = _
Source§fn byte_align(&self) -> usize
fn byte_align(&self) -> usize
Source§fn ptr_size_ratio(&self) -> [usize; 2]
fn ptr_size_ratio(&self) -> [usize; 2]
Source§impl<T, R> Chain<R> for Twhere
T: ?Sized,
impl<T, R> Chain<R> for Twhere
T: ?Sized,
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> ExtAny for T
impl<T> ExtAny for T
Source§fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
TypeId
of Self
using a custom hasher.Source§fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
Source§impl<T> ExtMem for Twhere
T: ?Sized,
impl<T> ExtMem for Twhere
T: ?Sized,
Source§const NEEDS_DROP: bool = _
const NEEDS_DROP: bool = _
Source§fn mem_align_of<T>() -> usize
fn mem_align_of<T>() -> usize
Source§fn mem_align_of_val(&self) -> usize
fn mem_align_of_val(&self) -> usize
Source§fn mem_size_of<T>() -> usize
fn mem_size_of<T>() -> usize
Source§fn mem_size_of_val(&self) -> usize
fn mem_size_of_val(&self) -> usize
Source§fn mem_needs_drop(&self) -> bool
fn mem_needs_drop(&self) -> bool
true
if dropping values of this type matters. Read moreSource§fn mem_forget(self)where
Self: Sized,
fn mem_forget(self)where
Self: Sized,
self
without running its destructor. Read moreSource§fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
Source§unsafe fn mem_zeroed<T>() -> T
unsafe fn mem_zeroed<T>() -> T
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§fn mem_as_bytes(&self) -> &[u8] ⓘ
fn mem_as_bytes(&self) -> &[u8] ⓘ
unsafe_slice
only.§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> Hook for T
impl<T> Hook for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more