Struct crossterm::terminal::BeginSynchronizedUpdate
source · pub struct BeginSynchronizedUpdate;
Expand description
A command that instructs the terminal emulator to begin a synchronized frame.
Notes
- Commands must be executed/queued for execution otherwise they do nothing.
- Use EndSynchronizedUpdate command to leave the entered 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 BeginSynchronizedUpdate
impl Clone for BeginSynchronizedUpdate
source§fn clone(&self) -> BeginSynchronizedUpdate
fn clone(&self) -> BeginSynchronizedUpdate
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 BeginSynchronizedUpdate
impl Command for BeginSynchronizedUpdate
source§fn write_ansi(&self, f: &mut impl Write) -> Result
fn write_ansi(&self, f: &mut impl Write) -> Result
Write an ANSI representation of this command to the given writer.
An ANSI code can manipulate the terminal by writing it to the terminal buffer.
However, only Windows 10 and UNIX systems support this. Read more
source§fn is_ansi_code_supported(&self) -> bool
fn is_ansi_code_supported(&self) -> bool
Returns whether the ANSI code representation of this command is supported by windows. Read more
source§impl Debug for BeginSynchronizedUpdate
impl Debug for BeginSynchronizedUpdate
source§impl PartialEq<BeginSynchronizedUpdate> for BeginSynchronizedUpdate
impl PartialEq<BeginSynchronizedUpdate> for BeginSynchronizedUpdate
source§fn eq(&self, other: &BeginSynchronizedUpdate) -> bool
fn eq(&self, other: &BeginSynchronizedUpdate) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl Copy for BeginSynchronizedUpdate
impl Eq for BeginSynchronizedUpdate
impl StructuralEq for BeginSynchronizedUpdate
impl StructuralPartialEq for BeginSynchronizedUpdate
Auto Trait Implementations§
impl RefUnwindSafe for BeginSynchronizedUpdate
impl Send for BeginSynchronizedUpdate
impl Sync for BeginSynchronizedUpdate
impl Unpin for BeginSynchronizedUpdate
impl UnwindSafe for BeginSynchronizedUpdate
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