Enum PresentMode

Source
#[repr(C)]
pub enum PresentMode { AutoVsync = 0, AutoNoVsync = 1, Fifo = 2, FifoRelaxed = 3, Immediate = 4, Mailbox = 5, }
Expand description

Timing and queueing with which frames are actually displayed to the user.

Use this as part of a SurfaceConfiguration to control the behavior of SurfaceTexture::present().

Some modes are only supported by some backends. You can use one of the Auto* modes, Fifo, or choose one of the supported modes from SurfaceCapabilities::present_modes.

Variants§

§

AutoVsync = 0

Chooses the first supported mode out of:

  1. FifoRelaxed
  2. Fifo

Because of the fallback behavior, this is supported everywhere.

§

AutoNoVsync = 1

Chooses the first supported mode out of:

  1. Immediate
  2. Mailbox
  3. Fifo

Because of the fallback behavior, this is supported everywhere.

§

Fifo = 2

Presentation frames are kept in a First-In-First-Out queue approximately 3 frames long. Every vertical blanking period, the presentation engine will pop a frame off the queue to display. If there is no frame to display, it will present the same frame again until the next vblank.

When a present command is executed on the GPU, the presented image is added on the queue.

Calls to Surface::get_current_texture() will block until there is a spot in the queue.

  • Tearing: No tearing will be observed.
  • Supported on: All platforms.
  • Also known as: “Vsync On”

This is the default value for PresentMode. If you don’t know what mode to choose, choose this mode.

§

FifoRelaxed = 3

Presentation frames are kept in a First-In-First-Out queue approximately 3 frames long. Every vertical blanking period, the presentation engine will pop a frame off the queue to display. If there is no frame to display, it will present the same frame until there is a frame in the queue. The moment there is a frame in the queue, it will immediately pop the frame off the queue.

When a present command is executed on the GPU, the presented image is added on the queue.

Calls to Surface::get_current_texture() will block until there is a spot in the queue.

  • Tearing: Tearing will be observed if frames last more than one vblank as the front buffer.
  • Supported on: AMD on Vulkan.
  • Also known as: “Adaptive Vsync”
§

Immediate = 4

Presentation frames are not queued at all. The moment a present command is executed on the GPU, the presented image is swapped onto the front buffer immediately.

  • Tearing: Tearing can be observed.
  • Supported on: Most platforms except older DX12 and Wayland.
  • Also known as: “Vsync Off”
§

Mailbox = 5

Presentation frames are kept in a single-frame queue. Every vertical blanking period, the presentation engine will pop a frame from the queue. If there is no frame to display, it will present the same frame again until the next vblank.

When a present command is executed on the GPU, the frame will be put into the queue. If there was already a frame in the queue, the new frame will replace the old frame on the queue.

  • Tearing: No tearing will be observed.
  • Supported on: DX12 on Windows 10, NVidia on Vulkan and Wayland on Vulkan.
  • Also known as: “Fast Vsync”

Trait Implementations§

Source§

impl Clone for PresentMode

Source§

fn clone(&self) -> PresentMode

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for PresentMode

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for PresentMode

Source§

fn default() -> PresentMode

Returns the “default value” for a type. Read more
Source§

impl Hash for PresentMode

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for PresentMode

Source§

fn eq(&self, other: &PresentMode) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for PresentMode

Source§

impl Eq for PresentMode

Source§

impl StructuralPartialEq for PresentMode

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WasmNotSend for T
where T: Send,

Source§

impl<T> WasmNotSendSync for T

Source§

impl<T> WasmNotSync for T
where T: Sync,