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::{stdout, Write};
use crossterm::{execute, Result, terminal::{BeginSynchronizedUpdate, EndSynchronizedUpdate}};
fn main() -> Result<()> {
execute!(stdout(), BeginSynchronizedUpdate)?;
// Anything performed here will not be rendered until EndSynchronizedUpdate is called.
execute!(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§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 EndSynchronizedUpdate
impl Debug for EndSynchronizedUpdate
source§impl PartialEq<EndSynchronizedUpdate> for EndSynchronizedUpdate
impl PartialEq<EndSynchronizedUpdate> 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 ==
.