Struct crossterm::terminal::EndSynchronizedUpdate
source · pub struct EndSynchronizedUpdate;
Expand description
A command that instructs the terminal to end a synchronized frame.
§Notes
- Commands must be executed/queued for execution otherwise they do nothing.
- Use BeginSynchronizedUpdate to enter the alternate screen.
When rendering the screen of the terminal, the Emulator usually iterates through each visible grid cell and renders its current state. With applications updating the screen a at higher frequency this can cause tearing.
This mode attempts to mitigate that.
When the synchronization mode is enabled following render calls will keep rendering the last rendered state. The terminal Emulator keeps processing incoming text and sequences. When the synchronized update mode is disabled again the renderer may fetch the latest screen buffer state again, effectively avoiding the tearing effect by unintentionally rendering in the middle a of an application screen update.
§Examples
use std::io::{self, Write};
use crossterm::{execute, terminal::{BeginSynchronizedUpdate, EndSynchronizedUpdate}};
fn main() -> io::Result<()> {
execute!(io::stdout(), BeginSynchronizedUpdate)?;
// Anything performed here will not be rendered until EndSynchronizedUpdate is called.
execute!(io::stdout(), EndSynchronizedUpdate)?;
Ok(())
}
Trait Implementations§
source§impl Clone for EndSynchronizedUpdate
impl Clone for EndSynchronizedUpdate
source§fn clone(&self) -> EndSynchronizedUpdate
fn clone(&self) -> EndSynchronizedUpdate
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Command for EndSynchronizedUpdate
impl Command for EndSynchronizedUpdate
source§impl Debug for EndSynchronizedUpdate
impl Debug for EndSynchronizedUpdate
source§impl PartialEq for EndSynchronizedUpdate
impl PartialEq for EndSynchronizedUpdate
source§fn eq(&self, other: &EndSynchronizedUpdate) -> bool
fn eq(&self, other: &EndSynchronizedUpdate) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl Copy for EndSynchronizedUpdate
impl Eq for EndSynchronizedUpdate
impl StructuralPartialEq for EndSynchronizedUpdate
Auto Trait Implementations§
impl Freeze for EndSynchronizedUpdate
impl RefUnwindSafe for EndSynchronizedUpdate
impl Send for EndSynchronizedUpdate
impl Sync for EndSynchronizedUpdate
impl Unpin for EndSynchronizedUpdate
impl UnwindSafe for EndSynchronizedUpdate
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
Mutably borrows from an owned value. Read more